@rest-hooks/endpoint
Advanced tools
Comparing version 3.7.4 to 3.8.0-next.0
@@ -55,2 +55,34 @@ 'use strict'; | ||
/** | ||
* Denormalize an immutable entity. | ||
* | ||
* @param {Schema} schema | ||
* @param {Immutable.Map|Immutable.Record} input | ||
* @param {function} unvisit | ||
* @param {function} getDenormalizedEntity | ||
* @return {Immutable.Map|Immutable.Record} | ||
*/ | ||
function denormalizeOnlyImmutable(schema, input, unvisit) { | ||
var _deleted; | ||
let deleted; | ||
const value = Object.keys(schema).reduce((object, key) => { | ||
// Immutable maps cast keys to strings on write so we need to ensure | ||
// we're accessing them using string keys. | ||
const stringKey = `${key}`; | ||
const item = unvisit(object.get(stringKey), schema[stringKey]); | ||
if (typeof item === 'symbol') { | ||
deleted = item; | ||
} | ||
if (object.has(stringKey)) { | ||
return object.set(stringKey, item); | ||
} else { | ||
return object; | ||
} | ||
}, input); | ||
return (_deleted = deleted) != null ? _deleted : value; | ||
} | ||
const DELETED = Symbol('ENTITY WAS DELETED'); | ||
const INVALID = DELETED; | ||
class PolymorphicSchema { | ||
@@ -68,3 +100,9 @@ constructor(definition, schemaAttribute) { | ||
define(definition) { | ||
this.schema = definition; | ||
// sending Union into another Polymorphic gets hoisted | ||
if ('_schemaAttribute' in definition && !this._schemaAttribute) { | ||
this.schema = definition.schema; | ||
this._schemaAttribute = definition._schemaAttribute; | ||
} else { | ||
this.schema = definition; | ||
} | ||
} | ||
@@ -81,3 +119,4 @@ getSchemaAttribute(input, parent, key) { | ||
} | ||
normalizeValue(value, parent, key, visit, addEntity, visitedEntities) { | ||
normalizeValue(value, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
if (!value) return value; | ||
const schema = this.inferSchema(value, parent, key); | ||
@@ -95,3 +134,3 @@ if (!schema) { | ||
} | ||
const normalizedValue = visit(value, parent, key, schema, addEntity, visitedEntities); | ||
const normalizedValue = visit(value, parent, key, schema, addEntity, visitedEntities, storeEntities, args); | ||
return this.isSingleSchema || normalizedValue === undefined || normalizedValue === null ? normalizedValue : { | ||
@@ -112,7 +151,12 @@ id: normalizedValue, | ||
} | ||
return [value, true, false]; | ||
return value; | ||
} | ||
const id = this.isSingleSchema ? undefined : isImmutable(value) ? value.get('id') : value.id; | ||
const schema = this.isSingleSchema ? this.schema : this.schema[schemaKey]; | ||
return unvisit(id || value, schema); | ||
const ret = unvisit(id || value, schema); | ||
if (Array.isArray(ret) && ret.length === 3) { | ||
if (ret[2] === true) return DELETED; | ||
return ret[0]; | ||
} | ||
return ret; | ||
} | ||
@@ -132,4 +176,4 @@ } | ||
} | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
return this.normalizeValue(input, parent, key, visit, addEntity, visitedEntities); | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
return this.normalizeValue(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args); | ||
} | ||
@@ -139,2 +183,6 @@ | ||
denormalize(input, unvisit) { | ||
const value = this.denormalizeValue(input, unvisit); | ||
return [value, value !== undefined, typeof value === 'symbol']; | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return this.denormalizeValue(input, unvisit); | ||
@@ -161,3 +209,3 @@ } | ||
class ValuesSchema extends PolymorphicSchema { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
return Object.keys(input).reduce((output, key, index) => { | ||
@@ -167,3 +215,3 @@ const value = input[key]; | ||
...output, | ||
[key]: this.normalizeValue(value, input, key, visit, addEntity, visitedEntities) | ||
[key]: this.normalizeValue(value, input, key, visit, addEntity, visitedEntities, storeEntities, args) | ||
} : output; | ||
@@ -175,14 +223,6 @@ }, {}); | ||
denormalize(input, unvisit) { | ||
let found = true; | ||
let deleted = false; | ||
return [Object.keys(input).reduce((output, key) => { | ||
const entityOrId = input[key]; | ||
const [value, foundItem, deletedItem] = this.denormalizeValue(entityOrId, unvisit); | ||
if (!foundItem) { | ||
found = false; | ||
} | ||
if (deletedItem) { | ||
deleted = true; | ||
} | ||
if (!foundItem || deletedItem) return output; | ||
const value = this.denormalizeValue(entityOrId, unvisit); | ||
if (!value || typeof value === 'symbol') return output; | ||
return { | ||
@@ -192,4 +232,17 @@ ...output, | ||
}; | ||
}, {}), found, deleted]; | ||
}, {}), true, false]; | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return Object.keys(input).reduce((output, key) => { | ||
const entityOrId = input[key]; | ||
const value = this.denormalizeValue(entityOrId, unvisit); | ||
// remove empty or deleted values | ||
if (!value || typeof value === 'symbol') return output; | ||
return { | ||
...output, | ||
[key]: value | ||
}; | ||
}, {}); | ||
} | ||
infer(args, indexes, recurse) { | ||
@@ -201,3 +254,3 @@ return undefined; | ||
const getValues = input => Array.isArray(input) ? input : Object.keys(input).map(key => input[key]); | ||
const filterEmpty = ([item,, deletedItem]) => item !== undefined && !deletedItem; | ||
const filterEmpty = item => item !== undefined && typeof item !== 'symbol'; | ||
@@ -209,9 +262,12 @@ /** | ||
class ArraySchema extends PolymorphicSchema { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
const values = getValues(input); | ||
return values.map((value, index) => this.normalizeValue(value, parent, key, visit, addEntity, visitedEntities)).filter(value => value !== undefined && value !== null); | ||
return values.map((value, index) => this.normalizeValue(value, parent, key, visit, addEntity, visitedEntities, storeEntities, args)).filter(value => value !== undefined && value !== null); | ||
} | ||
denormalize(input, unvisit) { | ||
return [input.map ? input.map(entityOrId => this.denormalizeValue(entityOrId, unvisit)).filter(filterEmpty).map(([value]) => value) : input, true, false]; | ||
return [this.denormalizeOnly(input, [], unvisit), true, false]; | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return input.map ? input.map(entityOrId => this.denormalizeValue(entityOrId, unvisit)).filter(filterEmpty) : input; | ||
} | ||
infer(args, indexes, recurse, entities) { | ||
@@ -234,5 +290,5 @@ return undefined; | ||
} | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
// we return undefined | ||
super.normalize(input, parent, key, visit, addEntity, visitedEntities); | ||
super.normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args); | ||
} | ||
@@ -260,3 +316,3 @@ infer(args, indexes, recurse, entities) { | ||
const normalize = (schema, input, parent, key, visit, addEntity, visitedEntities) => { | ||
const normalize = (schema, input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) => { | ||
const object = { | ||
@@ -267,3 +323,3 @@ ...input | ||
const localSchema = schema[key]; | ||
const value = visit(input[key], input, key, localSchema, addEntity, visitedEntities); | ||
const value = visit(input[key], input, key, localSchema, addEntity, visitedEntities, storeEntities, args); | ||
if (value === undefined || value === null) { | ||
@@ -300,2 +356,20 @@ delete object[key]; | ||
}; | ||
function denormalizeOnly$1(schema, input, args, unvisit) { | ||
if (isImmutable(input)) { | ||
return denormalizeOnlyImmutable(schema, input, unvisit); | ||
} | ||
const object = { | ||
...input | ||
}; | ||
for (const key of Object.keys(schema)) { | ||
const item = unvisit(object[key], schema[key]); | ||
if (object[key] !== undefined) { | ||
object[key] = item; | ||
} | ||
if (typeof item === 'symbol') { | ||
return item; | ||
} | ||
} | ||
return object; | ||
} | ||
function infer(schema, args, indexes, recurse, entities) { | ||
@@ -308,3 +382,2 @@ const resultObject = {}; | ||
} | ||
/** | ||
@@ -336,2 +409,5 @@ * Represents objects with statically known members | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return denormalizeOnly$1(this.schema, input, args, unvisit); | ||
} | ||
infer(args, indexes, recurse, entities) { | ||
@@ -342,11 +418,12 @@ return infer(this.schema, args, indexes, recurse, entities); | ||
const DELETED = Symbol('ENTITY WAS DELETED'); | ||
/* eslint-disable @typescript-eslint/explicit-module-boundary-types */ | ||
/** | ||
* Marks entity as deleted. | ||
* @see https://resthooks.io/rest/api/Delete | ||
* Marks entity as Invalid. | ||
* | ||
* This triggers suspense for all endpoints requiring it. | ||
* Optional (like variable sized Array and Values) will simply remove the item. | ||
* @see https://resthooks.io/rest/api/Invalidate | ||
*/ | ||
class Delete { | ||
class Invalidate { | ||
constructor(entity) { | ||
@@ -361,6 +438,9 @@ if (process.env.NODE_ENV !== 'production' && !entity) { | ||
} | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
/** Normalize lifecycles **/ | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
// TODO: what's store needs to be a differing type from fromJS | ||
const processedEntity = this._entity.process(input, parent, key); | ||
const id = this._entity.pk(processedEntity, parent, key); | ||
const id = this._entity.pk(processedEntity, parent, key, args); | ||
if (process.env.NODE_ENV !== 'production' && (id === undefined || id === '')) { | ||
@@ -381,9 +461,24 @@ var _name; | ||
} | ||
addEntity(this, DELETED, id); | ||
addEntity(this, INVALID, id); | ||
return id; | ||
} | ||
/* istanbul ignore next */ | ||
merge(existing, incoming) { | ||
return incoming; | ||
} | ||
mergeWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
// any queued updates are meaningless with delete, so we should just set it | ||
return this.merge(existing, incoming); | ||
} | ||
mergeMetaWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
return incomingMeta; | ||
} | ||
/** /End Normalize lifecycles **/ | ||
infer(args, indexes, recurse) { | ||
return undefined; | ||
} | ||
denormalize(id, unvisit) { | ||
denormalizeOnly(id, args, unvisit) { | ||
return unvisit(id, this._entity); | ||
@@ -394,3 +489,3 @@ } | ||
_denormalizeNullable() { | ||
return []; | ||
return {}; | ||
} | ||
@@ -400,13 +495,163 @@ | ||
_normalizeNullable() { | ||
return []; | ||
return {}; | ||
} | ||
} | ||
/* istanbul ignore next */ | ||
/* eslint-disable @typescript-eslint/explicit-module-boundary-types */ | ||
// TODO(breaking): mark deprecated | ||
/** | ||
* Marks entity as deleted. | ||
* @see https://resthooks.io/rest/api/Delete | ||
*/ | ||
class Delete extends Invalidate { | ||
denormalize(id, unvisit) { | ||
return unvisit(id, this._entity); | ||
} | ||
} | ||
const pushMerge = (existing, incoming) => { | ||
return [...existing, ...incoming]; | ||
}; | ||
const unshiftMerge = (existing, incoming) => { | ||
return [...incoming, ...existing]; | ||
}; | ||
const valuesMerge = (existing, incoming) => { | ||
return { | ||
...existing, | ||
...incoming | ||
}; | ||
}; | ||
const createArray = value => [...value]; | ||
const createValue = value => ({ | ||
...value | ||
}); | ||
/** | ||
* Entities but for Arrays instead of classes | ||
* @see https://resthooks.io/rest/api/Collection | ||
*/ | ||
class CollectionSchema { | ||
addWith(merge, createCollectionFilter) { | ||
return CreateAdder(this, merge, createCollectionFilter); | ||
} | ||
constructor(schema, options) { | ||
var _options$createCollec; | ||
this.schema = Array.isArray(schema) ? new ArraySchema(schema[0]) : schema; | ||
if ('nestKey' in options) { | ||
this.nestKey = options.nestKey; | ||
} else { | ||
if (process.env.NODE_ENV !== 'production') { | ||
if (!('argsKey' in options)) throw new Error('argsKey or nestKey needed'); | ||
} | ||
this.argsKey = options.argsKey; | ||
} | ||
this.createCollectionFilter = (_options$createCollec = options.createCollectionFilter) != null ? _options$createCollec : defaultFilter; | ||
// >>>>>>>>>>>>>>CREATION<<<<<<<<<<<<<< | ||
if (this.schema instanceof ArraySchema) { | ||
this.createIfValid = createArray; | ||
this.push = CreateAdder(this, pushMerge); | ||
this.unshift = CreateAdder(this, unshiftMerge); | ||
} else if (schema instanceof ValuesSchema) { | ||
this.createIfValid = createValue; | ||
this.assign = CreateAdder(this, valuesMerge); | ||
} | ||
} | ||
toJSON() { | ||
return { | ||
name: `Collection(${this.schema.schema.name})`, | ||
schema: this.schema.schema, | ||
key: this.key | ||
}; | ||
} | ||
get key() { | ||
// this assumes the definition of Array/Values is Entity | ||
return `COLLECT:${this.schema.constructor.name}(${this.schema.schema.key})`; | ||
} | ||
pk(value, parent, key, args) { | ||
return JSON.stringify(this.argsKey ? this.argsKey(...args) : this.nestKey(parent, key)); | ||
} | ||
// >>>>>>>>>>>>>>NORMALIZE<<<<<<<<<<<<<< | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
if (process.env.NODE_ENV !== 'production') { | ||
if (args === undefined) { | ||
throw new Error('Collections only work with @rest-hooks/react>=7.4'); | ||
} | ||
} | ||
const pkList = this.schema.normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args); | ||
const id = this.pk(pkList, parent, key, args); | ||
addEntity(this, pkList, id); | ||
return id; | ||
} | ||
merge(existing, incoming) { | ||
return incoming; | ||
} | ||
useIncoming(existingMeta, incomingMeta, existing, incoming) { | ||
return existingMeta.date <= incomingMeta.date; | ||
shouldReorder(existingMeta, incomingMeta, existing, incoming) { | ||
return incomingMeta.fetchedAt < existingMeta.fetchedAt; | ||
} | ||
mergeWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
return this.shouldReorder(existingMeta, incomingMeta, existing, incoming) ? this.merge(incoming, existing) : this.merge(existing, incoming); | ||
} | ||
mergeMetaWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
return this.shouldReorder(existingMeta, incomingMeta, existing, incoming) ? existingMeta : incomingMeta; | ||
} | ||
// >>>>>>>>>>>>>>DENORMALIZE<<<<<<<<<<<<<< | ||
infer(args, indexes, recurse, entities) { | ||
return undefined; | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return this.schema.denormalizeOnly(input, args, unvisit); | ||
} | ||
} | ||
// this adds to any list *in store* that has same members as the urlParams | ||
// so fetch(create, { userId: 'bob', completed: true }, data) | ||
// would possibly add to {}, {userId: 'bob'}, {completed: true}, {userId: 'bob', completed: true } - but only those already in the store | ||
// it ignores keys that start with sort as those are presumed to not filter results | ||
const defaultFilter = (urlParams, body) => collectionKey => Object.entries(collectionKey).every(([key, value]) => key.startsWith('order') || urlParams[key] === value || (body == null ? void 0 : body[key]) === value); | ||
function CreateAdder(collection, merge, createCollectionFilter) { | ||
const properties = { | ||
merge: { | ||
value: merge | ||
}, | ||
normalize: { | ||
value: normalizeCreate | ||
} | ||
}; | ||
if (collection.schema instanceof ArraySchema) { | ||
properties.createIfValid = { | ||
value: createIfValid | ||
}; | ||
properties.denormalizeOnly = { | ||
value: denormalizeOnly | ||
}; | ||
} | ||
if (createCollectionFilter) { | ||
properties.createCollectionFilter = { | ||
value: createCollectionFilter | ||
}; | ||
} | ||
return Object.create(collection, properties); | ||
} | ||
function normalizeCreate(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
const pkList = this.schema.normalize(!(this.schema instanceof ArraySchema) || Array.isArray(input) ? input : [input], parent, key, visit, addEntity, visitedEntities, storeEntities, args); | ||
// parent is args when not nested | ||
const filterCollections = this.createCollectionFilter(...args); | ||
Object.keys(storeEntities[this.key]).forEach(collectionPk => { | ||
if (!filterCollections(JSON.parse(collectionPk))) return; | ||
addEntity(this, pkList, collectionPk); | ||
}); | ||
return pkList; | ||
} | ||
function createIfValid(value) { | ||
return Array.isArray(value) ? [...value] : { | ||
...value | ||
}; | ||
} | ||
function denormalizeOnly(input, args, unvisit) { | ||
return Array.isArray(input) ? this.schema.denormalizeOnly(input, args, unvisit) : this.schema.schema.denormalizeOnly(input, args, unvisit); | ||
} | ||
@@ -439,2 +684,14 @@ /* eslint-disable @typescript-eslint/explicit-module-boundary-types */ | ||
* | ||
* @param [parent] When normalizing, the object which included the entity | ||
* @param [key] When normalizing, the key where this entity was found | ||
*/ | ||
/** Returns the globally unique identifier for the static Entity */ | ||
// default implementation in class static block at bottom of definition | ||
/** Defines indexes to enable lookup by */ | ||
/** | ||
* A unique identifier for each Entity | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#pk | ||
* @param [value] POJO of the entity or subset used | ||
@@ -444,4 +701,4 @@ * @param [parent] When normalizing, the object which included the entity | ||
*/ | ||
static pk(value, parent, key) { | ||
return this.prototype.pk.call(value, parent, key); | ||
static pk(value, parent, key, args) { | ||
return this.prototype.pk.call(value, parent, key, args); | ||
} | ||
@@ -466,3 +723,6 @@ | ||
/** Creates new instance copying over defined values of arguments */ | ||
/** Creates new instance copying over defined values of arguments | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#merge | ||
*/ | ||
static merge(existing, incoming) { | ||
@@ -475,3 +735,6 @@ return { | ||
/** Run when an existing entity is found in the store */ | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeWithStore | ||
*/ | ||
static mergeWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
@@ -491,2 +754,10 @@ const useIncoming = this.useIncoming(existingMeta, incomingMeta, existing, incoming); | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeMetaWithStore | ||
*/ | ||
static mergeMetaWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
return this.shouldReorder(existingMeta, incomingMeta, existing, incoming) ? existingMeta : incomingMeta; | ||
} | ||
/** Factory method to convert from Plain JS Objects. | ||
@@ -507,5 +778,6 @@ * | ||
/** Factory method to convert from Plain JS Objects. | ||
/** Called when denormalizing an entity to create an instance when 'valid' | ||
* | ||
* @param [props] Plain Object of properties to assign. | ||
* @see https://resthooks.io/docs/api/schema.Entity#createIfValid | ||
*/ | ||
@@ -521,3 +793,6 @@ static createIfValid( | ||
/** Do any transformations when first receiving input */ | ||
/** Do any transformations when first receiving input | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#process | ||
*/ | ||
static process(input, parent, key) { | ||
@@ -528,5 +803,5 @@ return { | ||
} | ||
static normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
static normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
const processedEntity = this.process(input, parent, key); | ||
const id = this.pk(processedEntity, parent, key); | ||
const id = this.pk(processedEntity, parent, key, args); | ||
if (id === undefined || id === '') { | ||
@@ -547,4 +822,4 @@ if (process.env.NODE_ENV !== 'production') { | ||
} else { | ||
// these make the keys get deleted | ||
return undefined; | ||
// these make the keys get deleted; return undefined | ||
return; | ||
} | ||
@@ -568,3 +843,3 @@ } | ||
const schema = this.schema[key]; | ||
processedEntity[key] = visit(processedEntity[key], processedEntity, key, schema, addEntity, visitedEntities); | ||
processedEntity[key] = visit(processedEntity[key], processedEntity, key, schema, addEntity, visitedEntities, storeEntities, args); | ||
} | ||
@@ -594,22 +869,10 @@ }); | ||
} | ||
static infer(args, indexes, recurse) { | ||
static infer(args, indexes, recurse, entities) { | ||
var _entities$this$key; | ||
if (!args[0]) return undefined; | ||
if (['string', 'number'].includes(typeof args[0])) { | ||
return `${args[0]}`; | ||
} | ||
const id = this.pk(args[0], undefined, ''); | ||
// Was able to infer the entity's primary key from params | ||
if (id !== undefined && id !== '') return id; | ||
// now attempt lookup in indexes | ||
const indexName = indexFromParams(args[0], this.indexes); | ||
if (indexName && indexes[this.key]) { | ||
// 'as Record<string, any>': indexName can only be found if params is a string key'd object | ||
const id = indexes[this.key][indexName][args[0][indexName]]; | ||
return id; | ||
} | ||
const id = inferId(this, args, indexes); | ||
// no entity arg is back-compatibility | ||
if (!entities || (_entities$this$key = entities[this.key]) != null && _entities$this$key[id]) return id; | ||
return undefined; | ||
} | ||
static expiresAt(meta, input) { | ||
return meta.expiresAt; | ||
} | ||
static denormalize(input, unvisit) { | ||
@@ -634,3 +897,24 @@ // TODO: remove codecov ignore once denormalize is modified to expect this | ||
} | ||
static denormalizeOnly(input, args, unvisit) { | ||
if (typeof input === 'symbol') { | ||
return input; | ||
} | ||
// note: iteration order must be stable | ||
for (const key of Object.keys(this.schema)) { | ||
const schema = this.schema[key]; | ||
const value = unvisit(input[key], schema); | ||
if (typeof value === 'symbol') { | ||
// if default is not 'fasly', then this is required, so propagate INVALID symbol | ||
if (this.defaults[key]) { | ||
return value; | ||
} | ||
input[key] = undefined; | ||
} else { | ||
input[key] = value; | ||
} | ||
} | ||
return input; | ||
} | ||
/** All instance defaults set */ | ||
@@ -730,2 +1014,17 @@ static get defaults() { | ||
} | ||
function inferId(schema, args, indexes) { | ||
if (['string', 'number'].includes(typeof args[0])) { | ||
return `${args[0]}`; | ||
} | ||
const id = schema.pk(args[0], undefined, '', args); | ||
// Was able to infer the entity's primary key from params | ||
if (id !== undefined && id !== '') return id; | ||
// now attempt lookup in indexes | ||
const indexName = indexFromParams(args[0], schema.indexes); | ||
if (indexName && indexes[schema.key]) { | ||
// 'as Record<string, any>': indexName can only be found if params is a string key'd object | ||
const id = indexes[schema.key][indexName][args[0][indexName]]; | ||
return id; | ||
} | ||
} | ||
@@ -742,2 +1041,4 @@ /* istanbul ignore file */ | ||
Delete: Delete, | ||
Invalidate: Invalidate, | ||
Collection: CollectionSchema, | ||
Entity: EntitySchema | ||
@@ -761,2 +1062,11 @@ }); | ||
/** Control how automatic schema validation is handled | ||
* | ||
* `undefined`: Defaults - throw error in worst offense | ||
* 'warn': only ever warn | ||
* 'silent': Don't bother with processing at all | ||
* | ||
* Note: this only applies to non-nested members. | ||
*/ | ||
/** Return true to merge incoming data; false keeps existing entity | ||
@@ -786,2 +1096,9 @@ * | ||
} | ||
static mergeMetaWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
return { | ||
expiresAt: Math.max(this.expiresAt(incomingMeta, incoming), existingMeta.expiresAt), | ||
date: Math.max(incomingMeta.date, existingMeta.date), | ||
fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt) | ||
}; | ||
} | ||
@@ -793,2 +1110,10 @@ /** Factory method to convert from Plain JS Objects. | ||
/** | ||
* A unique identifier for each Entity | ||
* | ||
* @param [value] POJO of the entity or subset used | ||
* @param [parent] When normalizing, the object which included the entity | ||
* @param [key] When normalizing, the key where this entity was found | ||
*/ | ||
/** Do any transformations when first receiving input */ | ||
@@ -944,2 +1269,7 @@ static process(input, parent, key) { | ||
// we're avoiding this on the type | ||
Entity.expiresAt = function (meta, input) { | ||
return meta.expiresAt; | ||
}; | ||
function validateRequired(processedEntity, requiredDefaults) { | ||
@@ -1129,6 +1459,14 @@ let missingKey = ''; | ||
}, unvisit) => { | ||
if (input === undefined) return [undefined, false, true]; | ||
if (input === undefined) return [undefined, false, false]; | ||
const [value, found, deleted] = schema.denormalize(input, unvisit); | ||
return [found ? this.process(value, ...args) : undefined, found, deleted]; | ||
}; | ||
if (schema.denormalizeOnly) query.denormalizeOnly = ({ | ||
args, | ||
input | ||
}, _, unvisit) => { | ||
if (input === undefined) return undefined; | ||
const value = schema.denormalizeOnly(input, args, unvisit); | ||
return typeof value === 'symbol' ? undefined : this.process(value, ...args); | ||
}; | ||
query.infer = (args, indexes, recurse, entities) => { | ||
@@ -1155,2 +1493,3 @@ return { | ||
exports.ExtendableEndpoint = ExtendableEndpoint; | ||
exports.INVALID = INVALID; | ||
exports.Index = Index; | ||
@@ -1157,0 +1496,0 @@ exports.Query = Query; |
@@ -1,1 +0,1 @@ | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).restHookEndpoint={})}(this,(function(e){"use strict";function t(e){return!("function"!=typeof e.hasOwnProperty||!(Object.hasOwnProperty.call(e,"__ownerID")||e._map&&Object.hasOwnProperty.call(e._map,"__ownerID")))}function s(e,t,s){let n=!0,r=!1;return[Object.keys(e).reduce(((t,i)=>{const o=`${i}`,[c,a,h]=s(t.get(o),e[o]);return a||(n=!1),h&&(r=!0),t.has(o)?t.set(o,c):t}),t),n,r]}class n{constructor(e,t){this.schema=void 0,t&&(this._schemaAttribute="string"==typeof t?e=>e[t]:t),this.define(e)}get isSingleSchema(){return!this._schemaAttribute}define(e){this.schema=e}getSchemaAttribute(e,t,s){return!this.isSingleSchema&&this._schemaAttribute(e,t,s)}inferSchema(e,t,s){if(this.isSingleSchema)return this.schema;const n=this.getSchemaAttribute(e,t,s);return this.schema[n]}normalizeValue(e,t,s,n,r,i){const o=this.inferSchema(e,t,s);if(!o)return e;const c=n(e,t,s,o,r,i);return this.isSingleSchema||null==c?c:{id:c,schema:this.getSchemaAttribute(e,t,s)}}denormalizeValue(e,s){const n=!this.isSingleSchema&&(t(e)?e.get("schema"):e.schema);if(!this.isSingleSchema&&!n)return[e,!0,!1];return s((this.isSingleSchema?void 0:t(e)?e.get("id"):e.id)||e,this.isSingleSchema?this.schema:this.schema[n])}}const r=([e,,t])=>void 0!==e&&!t;class i extends n{normalize(e,t,s,n,r,i){const o=(e=>Array.isArray(e)?e:Object.keys(e).map((t=>e[t])))(e);return o.map(((e,o)=>this.normalizeValue(e,t,s,n,r,i))).filter((e=>null!=e))}denormalize(e,t){return[e.map?e.map((e=>this.denormalizeValue(e,t))).filter(r).map((([e])=>e)):e,!0,!1]}infer(e,t,s,n){}toJSON(){return[this.schema]}}const o=Symbol("ENTITY WAS DELETED");var c,a=function(e,t){return e(t={exports:{}},t.exports),t.exports}((function(e){e.exports=function(e,t){if(null==e)return{};var s,n,r={},i=Object.keys(e);for(n=0;n<i.length;n++)s=i[n],t.indexOf(s)>=0||(r[s]=e[s]);return r},e.exports.__esModule=!0,e.exports.default=e.exports})),h=(c=a)&&c.__esModule&&Object.prototype.hasOwnProperty.call(c,"default")?c.default:c;const u=["pk","schema","key"];function l(e,t={}){class s extends e{static toString(){return this.key}static toJSON(){return{name:this.name,schema:this.schema,key:this.key}}static pk(e,t,s){return this.prototype.pk.call(e,t,s)}static useIncoming(e,t,s,n){return!0}static shouldReorder(e,t,s,n){return t.fetchedAt<e.fetchedAt}static merge(e,t){return Object.assign({},e,t)}static mergeWithStore(e,t,s,n){return this.useIncoming(e,t,s,n)?typeof n!=typeof s?n:this.shouldReorder(e,t,s,n)?this.merge(n,s):this.merge(s,n):s}static fromJS(e={}){const t=new this(e);return Object.assign(t,e),t}static createIfValid(e){if(!this.validate(e))return this.fromJS(e)}static process(e,t,s){return Object.assign({},e)}static normalize(e,t,s,n,r,i){const o=this.process(e,t,s),c=this.pk(o,t,s);if(void 0===c||""===c)return;const a=this.key;if(a in i||(i[a]={}),c in i[a]||(i[a][c]=[]),i[a][c].some((t=>t===e)))return c;return function(e){if(e){const t=new Error(e);throw t.status=400,t}}(this.validate(o)),i[a][c].push(e),Object.keys(this.schema).forEach((e=>{if(Object.hasOwn(o,e)){const t=this.schema[e];o[e]=n(o[e],o,e,t,r,i)}})),r(this,o,c),c}static validate(e){}static infer(e,t,s){if(!e[0])return;if(["string","number"].includes(typeof e[0]))return`${e[0]}`;const n=this.pk(e[0],void 0,"");if(void 0!==n&&""!==n)return n;const r=function(e,t){return t?t.find((t=>Object.hasOwn(e,t))):void 0}(e[0],this.indexes);if(r&&t[this.key]){return t[this.key][r][e[0][r]]}}static expiresAt(e,t){return e.expiresAt}static denormalize(e,t){if("symbol"==typeof e)return[void 0,!0,!0];let s=!1;return Object.keys(this.schema).forEach((n=>{const r=this.schema[n],i=e[n],[o,,c]=t(i,r);c&&this.defaults[n]&&(s=!0),e[n]=o})),[e,!0,s]}static get defaults(){return Object.hasOwn(this,"__defaults")||Object.defineProperty(this,"__defaults",{value:new this,writable:!0,configurable:!0}),this.__defaults}}const n=h(t,u);if(Object.assign(s,n),"schema"in t?s.schema=t.schema:e.schema||(s.schema={}),"pk"in t?"function"==typeof t.pk?s.prototype.pk=function(e,s){return t.pk(this,e,s)}:s.prototype.pk=function(){return this[t.pk]}:"function"!=typeof e.prototype.pk&&(s.prototype.pk=function(){return this.id}),"key"in t)Object.defineProperty(s,"key",{value:t.key,configurable:!0,writable:!0});else if(!("key"in e)){function r(e){Object.defineProperty(this,"key",{value:e,writable:!0,enumerable:!0})}const i="EntityMixin"!==s.name?function(){const t="EntityMixin"===this.name?e.name:this.name;return console.error("Rest Hooks Error: https://resthooks.io/errors/dklj"),Object.defineProperty(this,"key",{get:()=>t,set:r}),this.key}:function(){return"EntityMixin"===this.name?e.name:this.name};Object.defineProperty(s,"key",{get:i,set:r})}return s}var m=Object.freeze({__proto__:null,Union:class extends n{constructor(e,t){if(!t)throw new Error('Expected option "schemaAttribute" not found on UnionSchema.');super(e,t)}normalize(e,t,s,n,r,i){return this.normalizeValue(e,t,s,n,r,i)}denormalize(e,t){return this.denormalizeValue(e,t)}infer(e,t,s,n){if(!e[0])return;const r=this.getSchemaAttribute(e[0],void 0,""),i=this.schema[r];return void 0!==i?{id:s(i,e,t,n),schema:r}:void 0}},Values:class extends n{normalize(e,t,s,n,r,i){return Object.keys(e).reduce(((t,s,o)=>{const c=e[s];return null!=c?Object.assign({},t,{[s]:this.normalizeValue(c,e,s,n,r,i)}):t}),{})}denormalize(e,t){let s=!0,n=!1;return[Object.keys(e).reduce(((r,i)=>{const o=e[i],[c,a,h]=this.denormalizeValue(o,t);return a||(s=!1),h&&(n=!0),!a||h?r:Object.assign({},r,{[i]:c})}),{}),s,n]}infer(e,t,s){}},Array:i,All:class extends i{constructor(e,t){super(e,t)}normalize(e,t,s,n,r,i){super.normalize(e,t,s,n,r,i)}infer(e,t,s,n){if(this.isSingleSchema){const e=n[this.schema.key];if(void 0===e)return;return Object.values(e).map((e=>e&&this.schema.pk(e)))}let r=!1;const i=Object.values(this.schema).flatMap((e=>n[e.key]?(r=!0,Object.values(n[e.key]).map((t=>({id:t&&e.pk(t),schema:this.getSchemaAttribute(t,void 0,void 0)})))):[]));if(r)return i}},Object:class{constructor(e){this.schema=void 0,this.define(e)}define(e){this.schema=Object.keys(e).reduce(((t,s)=>{const n=e[s];return Object.assign({},t,{[s]:n})}),this.schema||{})}normalize(...e){return((e,t,s,n,r,i,o)=>{const c=Object.assign({},t);return Object.keys(e).forEach((s=>{const n=e[s],a=r(t[s],t,s,n,i,o);null==a?delete c[s]:c[s]=a})),c})(this.schema,...e)}denormalize(...e){return((e,n,r)=>{if(t(n))return s(e,n,r);const i=Object.assign({},n);let o=!0,c=!1;return Object.keys(e).forEach((t=>{const[s,n,a]=r(i[t],e[t]);void 0!==i[t]&&(i[t]=s),a&&(c=!0),n||(o=!1)})),[i,o,c]})(this.schema,...e)}infer(e,t,s,n){return function(e,t,s,n,r){const i={};return Object.keys(e).forEach((o=>{i[o]=n(e[o],t,s,r)})),i}(this.schema,e,t,s,n)}},Delete:class{constructor(e){this._entity=e}get key(){return this._entity.key}normalize(e,t,s,n,r,i){const c=this._entity.process(e,t,s),a=this._entity.pk(c,t,s);return r(this,o,a),a}infer(e,t,s){}denormalize(e,t){return t(e,this._entity)}_denormalizeNullable(){return[]}_normalizeNullable(){return[]}merge(e,t){return t}useIncoming(e,t,s,n){return e.date<=t.date}},Entity:l});const f=class{};class d extends(l(f)){static useIncoming(e,t,s,n){return e.fetchedAt<=t.fetchedAt}static mergeWithStore(e,t,s,n){return!e||this.useIncoming(e,t,s,n)?typeof n!=typeof s?n:this.merge(s,n):s}static process(e,t,s){return super.process(e,t,s)}static validate(e){return super.validate(e)}static denormalize(e,n){if("symbol"==typeof e)return[void 0,!0,!0];if(t(e)){if(this.validate(e.toJS()))return[void 0,!1,!0];null==n.setLocal||n.setLocal(e);const[t,r,i]=s(this.schema,e,n);return[this.fromJS(t.toObject()),!0,i]}let r;if(e instanceof this)r=e;else{if(this.validate(e))return[void 0,!1,!0];r=this.fromJS(e),null==n.setLocal||n.setLocal(r)}let i=!1;return Object.keys(this.schema).forEach((t=>{const s=this.schema[t],o=e[t],[c,,a]=n(o,s);a&&this.defaults[t]&&(i=!0),e[t]!==c&&this.set(r,t,c)})),[r,!0,i]}static set(e,t,s){e[t]=s}}var p;const y="undefined"!=typeof document;let b=y&&!(null!=(p=document.querySelector("meta[http-equiv='Content-Security-Policy']"))&&p.getAttribute("content"));try{b||Function()}catch(e){b=!0,y&&console.error("Content Security Policy: The previous CSP log can be safely ignored - @rest-hooks/endpoint will use setPrototypeOf instead")}function g(e,t){e.type=e.sideEffect?"mutate":"read",e.options=Object.assign({},t),delete e.options.key,delete e.options.schema,delete e.options.sideEffect,delete e.options.fetch,delete e.options.getFetchKey,delete e.options.options,0===Object.keys(e.options).length&&delete e.options,void 0===e.schema&&(e.schema=null)}class O extends Function{constructor(e,t){let s,n;return b?(s=(...e)=>s.fetch(...e),Object.setPrototypeOf(s,new.target.prototype)):(super("return arguments.callee.fetch.apply(arguments.callee, arguments)"),s=this),s.getFetchKey=e=>s.key(e),e&&(s.fetch=e),t&&"name"in t||!e||!e.name||"anonymous"===e.name||(n=e.name),Object.defineProperty(s,"name",{get(){return n||this.__name},set(e){this.__name=e}}),Object.assign(s,t),g(s,t),s}key(...e){return`${this.name} ${JSON.stringify(e)}`}testKey(e){return e.startsWith(this.name)}bind(e,...t){const s=this.fetch,n=this.key;return this.extend({fetch(){return s.apply(null!=e?e:this,t)},key(){return n.apply(this,t)}})}extend(e){class t extends this.constructor{}Object.assign(t.prototype,this);const s=new t(e.fetch,e);return g(s,Object.assign({},this.options,e)),s}}"runCompat"!==g.name&&(O.prototype.key=function(...e){return console.error("Rest Hooks Error: https://resthooks.io/errors/osid"),`${this.name} ${JSON.stringify(e)}`});const k=O;class j extends Error{}Object.hasOwn=Object.hasOwn||function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},e.AbortOptimistic=j,e.DELETED=o,e.Endpoint=O,e.Entity=d,e.ExtendableEndpoint=k,e.Index=class{constructor(e,t){this.getFetchKey=e=>this.key(e),this.schema=e,t&&(this.key=t)}key(e){return JSON.stringify(e)}},e.Query=class{constructor(e,t){this.sideEffect=void 0,this.schema=this.createQuerySchema(e),t?this.process=t:this.process||(this.process=e=>e)}key(...e){return`QUERY ${JSON.stringify(e)}`}createQuerySchema(e){const t=Object.create(e);return t.denormalize=({args:t,input:s},n)=>{if(void 0===s)return[void 0,!1,!0];const[r,i,o]=e.denormalize(s,n);return[i?this.process(r,...t):void 0,i,o]},t.infer=(t,s,n,r)=>({args:t,input:n(e,t,s,r)}),t}},e.schema=m,e.validateRequired=function(e,t){let s="";if(Object.keys(t).some((t=>!Object.hasOwn(e,t)&&(s=t,!0))))return`Missing key ${s}`},Object.defineProperty(e,"__esModule",{value:!0})})); | ||
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).restHookEndpoint={})}(this,(function(e){"use strict";function t(e){return!("function"!=typeof e.hasOwnProperty||!(Object.hasOwnProperty.call(e,"__ownerID")||e._map&&Object.hasOwnProperty.call(e._map,"__ownerID")))}function s(e,t,s){let r=!0,n=!1;return[Object.keys(e).reduce(((t,i)=>{const o=`${i}`,[c,a,h]=s(t.get(o),e[o]);return a||(r=!1),h&&(n=!0),t.has(o)?t.set(o,c):t}),t),r,n]}const r=Symbol("ENTITY WAS DELETED"),n=r;class i{constructor(e,t){this.schema=void 0,t&&(this._schemaAttribute="string"==typeof t?e=>e[t]:t),this.define(e)}get isSingleSchema(){return!this._schemaAttribute}define(e){"_schemaAttribute"in e&&!this._schemaAttribute?(this.schema=e.schema,this._schemaAttribute=e._schemaAttribute):this.schema=e}getSchemaAttribute(e,t,s){return!this.isSingleSchema&&this._schemaAttribute(e,t,s)}inferSchema(e,t,s){if(this.isSingleSchema)return this.schema;const r=this.getSchemaAttribute(e,t,s);return this.schema[r]}normalizeValue(e,t,s,r,n,i,o,c){if(!e)return e;const a=this.inferSchema(e,t,s);if(!a)return e;const h=r(e,t,s,a,n,i,o,c);return this.isSingleSchema||null==h?h:{id:h,schema:this.getSchemaAttribute(e,t,s)}}denormalizeValue(e,s){const n=!this.isSingleSchema&&(t(e)?e.get("schema"):e.schema);if(!this.isSingleSchema&&!n)return e;const i=s((this.isSingleSchema?void 0:t(e)?e.get("id"):e.id)||e,this.isSingleSchema?this.schema:this.schema[n]);return Array.isArray(i)&&3===i.length?!0===i[2]?r:i[0]:i}}class o extends i{normalize(e,t,s,r,n,i,o,c){return Object.keys(e).reduce(((t,s,a)=>{const h=e[s];return null!=h?Object.assign({},t,{[s]:this.normalizeValue(h,e,s,r,n,i,o,c)}):t}),{})}denormalize(e,t){return[Object.keys(e).reduce(((s,r)=>{const n=e[r],i=this.denormalizeValue(n,t);return i&&"symbol"!=typeof i?Object.assign({},s,{[r]:i}):s}),{}),!0,!1]}denormalizeOnly(e,t,s){return Object.keys(e).reduce(((t,r)=>{const n=e[r],i=this.denormalizeValue(n,s);return i&&"symbol"!=typeof i?Object.assign({},t,{[r]:i}):t}),{})}infer(e,t,s){}}const c=e=>void 0!==e&&"symbol"!=typeof e;class a extends i{normalize(e,t,s,r,n,i,o,c){const a=(e=>Array.isArray(e)?e:Object.keys(e).map((t=>e[t])))(e);return a.map(((e,a)=>this.normalizeValue(e,t,s,r,n,i,o,c))).filter((e=>null!=e))}denormalize(e,t){return[this.denormalizeOnly(e,[],t),!0,!1]}denormalizeOnly(e,t,s){return e.map?e.map((e=>this.denormalizeValue(e,s))).filter(c):e}infer(e,t,s,r){}toJSON(){return[this.schema]}}function h(e,s,r,n){if(t(s))return function(e,t,s){var r;let n;const i=Object.keys(e).reduce(((t,r)=>{const i=`${r}`,o=s(t.get(i),e[i]);return"symbol"==typeof o&&(n=o),t.has(i)?t.set(i,o):t}),t);return null!=(r=n)?r:i}(e,s,n);const i=Object.assign({},s);for(const t of Object.keys(e)){const s=n(i[t],e[t]);if(void 0!==i[t]&&(i[t]=s),"symbol"==typeof s)return s}return i}class u{constructor(e){this._entity=e}get key(){return this._entity.key}normalize(e,t,s,r,i,o,c,a){const h=this._entity.process(e,t,s),u=this._entity.pk(h,t,s,a);return i(this,n,u),u}merge(e,t){return t}mergeWithStore(e,t,s,r){return this.merge(s,r)}mergeMetaWithStore(e,t,s,r){return t}infer(e,t,s){}denormalizeOnly(e,t,s){return s(e,this._entity)}_denormalizeNullable(){return{}}_normalizeNullable(){return{}}}const l=(e,t)=>[...e,...t],m=(e,t)=>[...t,...e],f=(e,t)=>Object.assign({},e,t),d=e=>[...e],y=e=>Object.assign({},e);const p=(e,t)=>s=>Object.entries(s).every((([s,r])=>s.startsWith("order")||e[s]===r||(null==t?void 0:t[s])===r));function b(e,t,s){const r={merge:{value:t},normalize:{value:O}};return e.schema instanceof a&&(r.createIfValid={value:g},r.denormalizeOnly={value:k}),s&&(r.createCollectionFilter={value:s}),Object.create(e,r)}function O(e,t,s,r,n,i,o,c){const h=this.schema.normalize(this.schema instanceof a&&!Array.isArray(e)?[e]:e,t,s,r,n,i,o,c),u=this.createCollectionFilter(...c);return Object.keys(o[this.key]).forEach((e=>{u(JSON.parse(e))&&n(this,h,e)})),h}function g(e){return Array.isArray(e)?[...e]:Object.assign({},e)}function k(e,t,s){return Array.isArray(e)?this.schema.denormalizeOnly(e,t,s):this.schema.schema.denormalizeOnly(e,t,s)}var j,v=function(e,t){return e(t={exports:{}},t.exports),t.exports}((function(e){e.exports=function(e,t){if(null==e)return{};var s,r,n={},i=Object.keys(e);for(r=0;r<i.length;r++)s=i[r],t.indexOf(s)>=0||(n[s]=e[s]);return n},e.exports.__esModule=!0,e.exports.default=e.exports})),S=(j=v)&&j.__esModule&&Object.prototype.hasOwnProperty.call(j,"default")?j.default:j;const z=["pk","schema","key"];function A(e,t={}){class s extends e{static toString(){return this.key}static toJSON(){return{name:this.name,schema:this.schema,key:this.key}}static pk(e,t,s,r){return this.prototype.pk.call(e,t,s,r)}static useIncoming(e,t,s,r){return!0}static shouldReorder(e,t,s,r){return t.fetchedAt<e.fetchedAt}static merge(e,t){return Object.assign({},e,t)}static mergeWithStore(e,t,s,r){return this.useIncoming(e,t,s,r)?typeof r!=typeof s?r:this.shouldReorder(e,t,s,r)?this.merge(r,s):this.merge(s,r):s}static mergeMetaWithStore(e,t,s,r){return this.shouldReorder(e,t,s,r)?e:t}static fromJS(e={}){const t=new this(e);return Object.assign(t,e),t}static createIfValid(e){if(!this.validate(e))return this.fromJS(e)}static process(e,t,s){return Object.assign({},e)}static normalize(e,t,s,r,n,i,o,c){const a=this.process(e,t,s),h=this.pk(a,t,s,c);if(void 0===h||""===h)return;const u=this.key;if(u in i||(i[u]={}),h in i[u]||(i[u][h]=[]),i[u][h].some((t=>t===e)))return h;return function(e){if(e){const t=new Error(e);throw t.status=400,t}}(this.validate(a)),i[u][h].push(e),Object.keys(this.schema).forEach((e=>{if(Object.hasOwn(a,e)){const t=this.schema[e];a[e]=r(a[e],a,e,t,n,i,o,c)}})),n(this,a,h),h}static validate(e){}static infer(e,t,s,r){var n;if(!e[0])return;const i=function(e,t,s){if(["string","number"].includes(typeof t[0]))return`${t[0]}`;const r=e.pk(t[0],void 0,"",t);if(void 0!==r&&""!==r)return r;const n=function(e,t){return t?t.find((t=>Object.hasOwn(e,t))):void 0}(t[0],e.indexes);if(n&&s[e.key]){return s[e.key][n][t[0][n]]}}(this,e,t);return!r||null!=(n=r[this.key])&&n[i]?i:void 0}static denormalize(e,t){if("symbol"==typeof e)return[void 0,!0,!0];let s=!1;return Object.keys(this.schema).forEach((r=>{const n=this.schema[r],i=e[r],[o,,c]=t(i,n);c&&this.defaults[r]&&(s=!0),e[r]=o})),[e,!0,s]}static denormalizeOnly(e,t,s){if("symbol"==typeof e)return e;for(const t of Object.keys(this.schema)){const r=this.schema[t],n=s(e[t],r);if("symbol"==typeof n){if(this.defaults[t])return n;e[t]=void 0}else e[t]=n}return e}static get defaults(){return Object.hasOwn(this,"__defaults")||Object.defineProperty(this,"__defaults",{value:new this,writable:!0,configurable:!0}),this.__defaults}}const r=S(t,z);if(Object.assign(s,r),"schema"in t?s.schema=t.schema:e.schema||(s.schema={}),"pk"in t?"function"==typeof t.pk?s.prototype.pk=function(e,s){return t.pk(this,e,s)}:s.prototype.pk=function(){return this[t.pk]}:"function"!=typeof e.prototype.pk&&(s.prototype.pk=function(){return this.id}),"key"in t)Object.defineProperty(s,"key",{value:t.key,configurable:!0,writable:!0});else if(!("key"in e)){function n(e){Object.defineProperty(this,"key",{value:e,writable:!0,enumerable:!0})}const i="EntityMixin"!==s.name?function(){const t="EntityMixin"===this.name?e.name:this.name;return console.error("Rest Hooks Error: https://resthooks.io/errors/dklj"),Object.defineProperty(this,"key",{get:()=>t,set:n}),this.key}:function(){return"EntityMixin"===this.name?e.name:this.name};Object.defineProperty(s,"key",{get:i,set:n})}return s}var _=Object.freeze({__proto__:null,Union:class extends i{constructor(e,t){if(!t)throw new Error('Expected option "schemaAttribute" not found on UnionSchema.');super(e,t)}normalize(e,t,s,r,n,i,o,c){return this.normalizeValue(e,t,s,r,n,i,o,c)}denormalize(e,t){const s=this.denormalizeValue(e,t);return[s,void 0!==s,"symbol"==typeof s]}denormalizeOnly(e,t,s){return this.denormalizeValue(e,s)}infer(e,t,s,r){if(!e[0])return;const n=this.getSchemaAttribute(e[0],void 0,""),i=this.schema[n];return void 0!==i?{id:s(i,e,t,r),schema:n}:void 0}},Values:o,Array:a,All:class extends a{constructor(e,t){super(e,t)}normalize(e,t,s,r,n,i,o,c){super.normalize(e,t,s,r,n,i,o,c)}infer(e,t,s,r){if(this.isSingleSchema){const e=r[this.schema.key];if(void 0===e)return;return Object.values(e).map((e=>e&&this.schema.pk(e)))}let n=!1;const i=Object.values(this.schema).flatMap((e=>r[e.key]?(n=!0,Object.values(r[e.key]).map((t=>({id:t&&e.pk(t),schema:this.getSchemaAttribute(t,void 0,void 0)})))):[]));if(n)return i}},Object:class{constructor(e){this.schema=void 0,this.define(e)}define(e){this.schema=Object.keys(e).reduce(((t,s)=>{const r=e[s];return Object.assign({},t,{[s]:r})}),this.schema||{})}normalize(...e){return((e,t,s,r,n,i,o,c,a)=>{const h=Object.assign({},t);return Object.keys(e).forEach((s=>{const r=e[s],u=n(t[s],t,s,r,i,o,c,a);null==u?delete h[s]:h[s]=u})),h})(this.schema,...e)}denormalize(...e){return((e,r,n)=>{if(t(r))return s(e,r,n);const i=Object.assign({},r);let o=!0,c=!1;return Object.keys(e).forEach((t=>{const[s,r,a]=n(i[t],e[t]);void 0!==i[t]&&(i[t]=s),a&&(c=!0),r||(o=!1)})),[i,o,c]})(this.schema,...e)}denormalizeOnly(e,t,s){return h(this.schema,e,0,s)}infer(e,t,s,r){return function(e,t,s,r,n){const i={};return Object.keys(e).forEach((o=>{i[o]=r(e[o],t,s,n)})),i}(this.schema,e,t,s,r)}},Delete:class extends u{denormalize(e,t){return t(e,this._entity)}},Invalidate:u,Collection:class{addWith(e,t){return b(this,e,t)}constructor(e,t){var s;this.schema=Array.isArray(e)?new a(e[0]):e,"nestKey"in t?this.nestKey=t.nestKey:this.argsKey=t.argsKey,this.createCollectionFilter=null!=(s=t.createCollectionFilter)?s:p,this.schema instanceof a?(this.createIfValid=d,this.push=b(this,l),this.unshift=b(this,m)):e instanceof o&&(this.createIfValid=y,this.assign=b(this,f))}toJSON(){return{name:`Collection(${this.schema.schema.name})`,schema:this.schema.schema,key:this.key}}get key(){return`COLLECT:${this.schema.constructor.name}(${this.schema.schema.key})`}pk(e,t,s,r){return JSON.stringify(this.argsKey?this.argsKey(...r):this.nestKey(t,s))}normalize(e,t,s,r,n,i,o,c){const a=this.schema.normalize(e,t,s,r,n,i,o,c),h=this.pk(a,t,s,c);return n(this,a,h),h}merge(e,t){return t}shouldReorder(e,t,s,r){return t.fetchedAt<e.fetchedAt}mergeWithStore(e,t,s,r){return this.shouldReorder(e,t,s,r)?this.merge(r,s):this.merge(s,r)}mergeMetaWithStore(e,t,s,r){return this.shouldReorder(e,t,s,r)?e:t}infer(e,t,s,r){}denormalizeOnly(e,t,s){return this.schema.denormalizeOnly(e,t,s)}},Entity:A});const x=class{};class E extends(A(x)){static useIncoming(e,t,s,r){return e.fetchedAt<=t.fetchedAt}static mergeWithStore(e,t,s,r){return!e||this.useIncoming(e,t,s,r)?typeof r!=typeof s?r:this.merge(s,r):s}static mergeMetaWithStore(e,t,s,r){return{expiresAt:Math.max(this.expiresAt(t,r),e.expiresAt),date:Math.max(t.date,e.date),fetchedAt:Math.max(t.fetchedAt,e.fetchedAt)}}static process(e,t,s){return super.process(e,t,s)}static validate(e){return super.validate(e)}static denormalize(e,r){if("symbol"==typeof e)return[void 0,!0,!0];if(t(e)){if(this.validate(e.toJS()))return[void 0,!1,!0];null==r.setLocal||r.setLocal(e);const[t,n,i]=s(this.schema,e,r);return[this.fromJS(t.toObject()),!0,i]}let n;if(e instanceof this)n=e;else{if(this.validate(e))return[void 0,!1,!0];n=this.fromJS(e),null==r.setLocal||r.setLocal(n)}let i=!1;return Object.keys(this.schema).forEach((t=>{const s=this.schema[t],o=e[t],[c,,a]=r(o,s);a&&this.defaults[t]&&(i=!0),e[t]!==c&&this.set(n,t,c)})),[n,!0,i]}static set(e,t,s){e[t]=s}}var w;E.expiresAt=function(e,t){return e.expiresAt};const P="undefined"!=typeof document;let V=P&&!(null!=(w=document.querySelector("meta[http-equiv='Content-Security-Policy']"))&&w.getAttribute("content"));try{V||Function()}catch(e){V=!0,P&&console.error("Content Security Policy: The previous CSP log can be safely ignored - @rest-hooks/endpoint will use setPrototypeOf instead")}function I(e,t){e.type=e.sideEffect?"mutate":"read",e.options=Object.assign({},t),delete e.options.key,delete e.options.schema,delete e.options.sideEffect,delete e.options.fetch,delete e.options.getFetchKey,delete e.options.options,0===Object.keys(e.options).length&&delete e.options,void 0===e.schema&&(e.schema=null)}class M extends Function{constructor(e,t){let s,r;return V?(s=(...e)=>s.fetch(...e),Object.setPrototypeOf(s,new.target.prototype)):(super("return arguments.callee.fetch.apply(arguments.callee, arguments)"),s=this),s.getFetchKey=e=>s.key(e),e&&(s.fetch=e),t&&"name"in t||!e||!e.name||"anonymous"===e.name||(r=e.name),Object.defineProperty(s,"name",{get(){return r||this.__name},set(e){this.__name=e}}),Object.assign(s,t),I(s,t),s}key(...e){return`${this.name} ${JSON.stringify(e)}`}testKey(e){return e.startsWith(this.name)}bind(e,...t){const s=this.fetch,r=this.key;return this.extend({fetch(){return s.apply(null!=e?e:this,t)},key(){return r.apply(this,t)}})}extend(e){class t extends this.constructor{}Object.assign(t.prototype,this);const s=new t(e.fetch,e);return I(s,Object.assign({},this.options,e)),s}}"runCompat"!==I.name&&(M.prototype.key=function(...e){return console.error("Rest Hooks Error: https://resthooks.io/errors/osid"),`${this.name} ${JSON.stringify(e)}`});const J=M;class N extends Error{}Object.hasOwn=Object.hasOwn||function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},e.AbortOptimistic=N,e.DELETED=r,e.Endpoint=M,e.Entity=E,e.ExtendableEndpoint=J,e.INVALID=n,e.Index=class{constructor(e,t){this.getFetchKey=e=>this.key(e),this.schema=e,t&&(this.key=t)}key(e){return JSON.stringify(e)}},e.Query=class{constructor(e,t){this.sideEffect=void 0,this.schema=this.createQuerySchema(e),t?this.process=t:this.process||(this.process=e=>e)}key(...e){return`QUERY ${JSON.stringify(e)}`}createQuerySchema(e){const t=Object.create(e);return t.denormalize=({args:t,input:s},r)=>{if(void 0===s)return[void 0,!1,!1];const[n,i,o]=e.denormalize(s,r);return[i?this.process(n,...t):void 0,i,o]},e.denormalizeOnly&&(t.denormalizeOnly=({args:t,input:s},r,n)=>{if(void 0===s)return;const i=e.denormalizeOnly(s,t,n);return"symbol"==typeof i?void 0:this.process(i,...t)}),t.infer=(t,s,r,n)=>({args:t,input:r(e,t,s,n)}),t}},e.schema=_,e.validateRequired=function(e,t){let s="";if(Object.keys(t).some((t=>!Object.hasOwn(e,t)&&(s=t,!0))))return`Missing key ${s}`},Object.defineProperty(e,"__esModule",{value:!0})})); |
@@ -7,4 +7,4 @@ Object.hasOwn = Object.hasOwn || /* istanbul ignore next */function hasOwn(it, key) { | ||
export { default as Entity } from './schemas/Entity.js'; | ||
export { default as validateRequired } from './schemas/validatRequired.js'; | ||
export { DELETED } from './special.js'; | ||
export { default as validateRequired } from './validateRequired.js'; | ||
export { DELETED, INVALID } from './special.js'; | ||
export { default as Endpoint, ExtendableEndpoint } from './endpoint.js'; | ||
@@ -14,2 +14,2 @@ export * from './indexEndpoint.js'; | ||
export { default as AbortOptimistic } from './AbortOptimistic.js'; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPYmplY3QiLCJoYXNPd24iLCJpdCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIl9zY2hlbWEiLCJzY2hlbWEiLCJkZWZhdWx0IiwiRW50aXR5IiwidmFsaWRhdGVSZXF1aXJlZCIsIkRFTEVURUQiLCJFbmRwb2ludCIsIkV4dGVuZGFibGVFbmRwb2ludCIsIkFib3J0T3B0aW1pc3RpYyJdLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuaGFzT3duID1cbiAgT2JqZWN0Lmhhc093biB8fFxuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqLyBmdW5jdGlvbiBoYXNPd24oaXQsIGtleSkge1xuICAgIHJldHVybiBPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoaXQsIGtleSk7XG4gIH07XG5cbmV4cG9ydCB0eXBlIHtcbiAgRW5kcG9pbnRJbnRlcmZhY2UsXG4gIFJlYWRFbmRwb2ludCxcbiAgTXV0YXRlRW5kcG9pbnQsXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcbmV4cG9ydCB0eXBlIHtcbiAgRW5kcG9pbnRPcHRpb25zLFxuICBFbmRwb2ludEluc3RhbmNlLFxuICBFbmRwb2ludEluc3RhbmNlSW50ZXJmYWNlLFxuICBFbmRwb2ludEV4dGVuZE9wdGlvbnMsXG59IGZyb20gJy4vZW5kcG9pbnQuanMnO1xuZXhwb3J0ICogYXMgc2NoZW1hIGZyb20gJy4vc2NoZW1hLmpzJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRW50aXR5IH0gZnJvbSAnLi9zY2hlbWFzL0VudGl0eS5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIHZhbGlkYXRlUmVxdWlyZWQgfSBmcm9tICcuL3NjaGVtYXMvdmFsaWRhdFJlcXVpcmVkLmpzJztcbmV4cG9ydCB7IERFTEVURUQgfSBmcm9tICcuL3NwZWNpYWwuanMnO1xuZXhwb3J0IHR5cGUge1xuICBTY2hlbWEsXG4gIFNuYXBzaG90SW50ZXJmYWNlLFxuICBFeHBpcnlTdGF0dXNJbnRlcmZhY2UsXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcbmV4cG9ydCB0eXBlIHtcbiAgQWJzdHJhY3RJbnN0YW5jZVR5cGUsXG4gIE5vcm1hbGl6ZSxcbiAgTm9ybWFsaXplTnVsbGFibGUsXG4gIERlbm9ybWFsaXplLFxuICBEZW5vcm1hbGl6ZU51bGxhYmxlLFxufSBmcm9tICcuL25vcm1hbC5qcyc7XG5leHBvcnQgdHlwZSB7XG4gIEVuZHBvaW50RXh0cmFPcHRpb25zLFxuICBGZXRjaEZ1bmN0aW9uLFxuICBTY2hlbWFEZXRhaWwsXG4gIFNjaGVtYUxpc3QsXG4gIFJlc29sdmVUeXBlLFxuICBFbmRwb2ludFBhcmFtLFxuICBOZXR3b3JrRXJyb3IsXG4gIFVua25vd25FcnJvcixcbiAgRXJyb3JUeXBlcyxcbn0gZnJvbSAnLi90eXBlcy5qcyc7XG5cbmV4cG9ydCB7IGRlZmF1bHQgYXMgRW5kcG9pbnQsIEV4dGVuZGFibGVFbmRwb2ludCB9IGZyb20gJy4vZW5kcG9pbnQuanMnO1xuZXhwb3J0IHR5cGUgeyBLZXlvZkVuZHBvaW50SW5zdGFuY2UgfSBmcm9tICcuL2VuZHBvaW50LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vaW5kZXhFbmRwb2ludC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL3F1ZXJ5RW5kcG9pbnQuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBBYm9ydE9wdGltaXN0aWMgfSBmcm9tICcuL0Fib3J0T3B0aW1pc3RpYy5qcyc7XG4iXSwibWFwcGluZ3MiOiJBQUFBQSxNQUFNLENBQUNDLE1BQU0sR0FDWEQsTUFBTSxDQUFDQyxNQUFNLElBQ2IsMEJBQTJCLFNBQVNBLE1BQU1BLENBQUNDLEVBQUUsRUFBRUMsR0FBRyxFQUFFO0VBQ2xELE9BQU9ILE1BQU0sQ0FBQ0ksU0FBUyxDQUFDQyxjQUFjLENBQUNDLElBQUksQ0FBQ0osRUFBRSxFQUFFQyxHQUFHLENBQUM7QUFDdEQsQ0FBQztBQUFDLFlBQUFJLE9BQUEsTUFhb0IsYUFBYTtBQUFBLFNBQUFBLE9BQUEsSUFBekJDLE1BQU07QUFDbEIsU0FBU0MsT0FBTyxJQUFJQyxNQUFNLFFBQVEscUJBQXFCO0FBQ3ZELFNBQVNELE9BQU8sSUFBSUUsZ0JBQWdCLFFBQVEsOEJBQThCO0FBQzFFLFNBQVNDLE9BQU8sUUFBUSxjQUFjO0FBeUJ0QyxTQUFTSCxPQUFPLElBQUlJLFFBQVEsRUFBRUMsa0JBQWtCLFFBQVEsZUFBZTtBQUV2RSxjQUFjLG9CQUFvQjtBQUNsQyxjQUFjLG9CQUFvQjtBQUNsQyxTQUFTTCxPQUFPLElBQUlNLGVBQWUsUUFBUSxzQkFBc0IifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPYmplY3QiLCJoYXNPd24iLCJpdCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIl9zY2hlbWEiLCJzY2hlbWEiLCJkZWZhdWx0IiwiRW50aXR5IiwidmFsaWRhdGVSZXF1aXJlZCIsIkRFTEVURUQiLCJJTlZBTElEIiwiRW5kcG9pbnQiLCJFeHRlbmRhYmxlRW5kcG9pbnQiLCJBYm9ydE9wdGltaXN0aWMiXSwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0Lmhhc093biA9XG4gIE9iamVjdC5oYXNPd24gfHxcbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi8gZnVuY3Rpb24gaGFzT3duKGl0LCBrZXkpIHtcbiAgICByZXR1cm4gT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKGl0LCBrZXkpO1xuICB9O1xuXG5leHBvcnQgdHlwZSB7XG4gIEVuZHBvaW50SW50ZXJmYWNlLFxuICBSZWFkRW5kcG9pbnQsXG4gIE11dGF0ZUVuZHBvaW50LFxufSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5leHBvcnQgdHlwZSB7XG4gIEVuZHBvaW50T3B0aW9ucyxcbiAgRW5kcG9pbnRJbnN0YW5jZSxcbiAgRW5kcG9pbnRJbnN0YW5jZUludGVyZmFjZSxcbiAgRW5kcG9pbnRFeHRlbmRPcHRpb25zLFxufSBmcm9tICcuL2VuZHBvaW50LmpzJztcbmV4cG9ydCAqIGFzIHNjaGVtYSBmcm9tICcuL3NjaGVtYS5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEVudGl0eSB9IGZyb20gJy4vc2NoZW1hcy9FbnRpdHkuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyB2YWxpZGF0ZVJlcXVpcmVkIH0gZnJvbSAnLi92YWxpZGF0ZVJlcXVpcmVkLmpzJztcbmV4cG9ydCB7IERFTEVURUQsIElOVkFMSUQgfSBmcm9tICcuL3NwZWNpYWwuanMnO1xuZXhwb3J0IHR5cGUge1xuICBTY2hlbWEsXG4gIFNuYXBzaG90SW50ZXJmYWNlLFxuICBFeHBpcnlTdGF0dXNJbnRlcmZhY2UsXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcbmV4cG9ydCB0eXBlIHtcbiAgQWJzdHJhY3RJbnN0YW5jZVR5cGUsXG4gIE5vcm1hbGl6ZSxcbiAgTm9ybWFsaXplTnVsbGFibGUsXG4gIERlbm9ybWFsaXplLFxuICBEZW5vcm1hbGl6ZU51bGxhYmxlLFxufSBmcm9tICcuL25vcm1hbC5qcyc7XG5leHBvcnQgdHlwZSB7XG4gIEVuZHBvaW50RXh0cmFPcHRpb25zLFxuICBGZXRjaEZ1bmN0aW9uLFxuICBTY2hlbWFEZXRhaWwsXG4gIFNjaGVtYUxpc3QsXG4gIFJlc29sdmVUeXBlLFxuICBFbmRwb2ludFBhcmFtLFxuICBOZXR3b3JrRXJyb3IsXG4gIFVua25vd25FcnJvcixcbiAgRXJyb3JUeXBlcyxcbn0gZnJvbSAnLi90eXBlcy5qcyc7XG5cbmV4cG9ydCB7IGRlZmF1bHQgYXMgRW5kcG9pbnQsIEV4dGVuZGFibGVFbmRwb2ludCB9IGZyb20gJy4vZW5kcG9pbnQuanMnO1xuZXhwb3J0IHR5cGUgeyBLZXlvZkVuZHBvaW50SW5zdGFuY2UgfSBmcm9tICcuL2VuZHBvaW50LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vaW5kZXhFbmRwb2ludC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL3F1ZXJ5RW5kcG9pbnQuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBBYm9ydE9wdGltaXN0aWMgfSBmcm9tICcuL0Fib3J0T3B0aW1pc3RpYy5qcyc7XG4iXSwibWFwcGluZ3MiOiJBQUFBQSxNQUFNLENBQUNDLE1BQU0sR0FDWEQsTUFBTSxDQUFDQyxNQUFNLElBQ2IsMEJBQTJCLFNBQVNBLE1BQU1BLENBQUNDLEVBQUUsRUFBRUMsR0FBRyxFQUFFO0VBQ2xELE9BQU9ILE1BQU0sQ0FBQ0ksU0FBUyxDQUFDQyxjQUFjLENBQUNDLElBQUksQ0FBQ0osRUFBRSxFQUFFQyxHQUFHLENBQUM7QUFDdEQsQ0FBQztBQUFDLFlBQUFJLE9BQUEsTUFhb0IsYUFBYTtBQUFBLFNBQUFBLE9BQUEsSUFBekJDLE1BQU07QUFDbEIsU0FBU0MsT0FBTyxJQUFJQyxNQUFNLFFBQVEscUJBQXFCO0FBQ3ZELFNBQVNELE9BQU8sSUFBSUUsZ0JBQWdCLFFBQVEsdUJBQXVCO0FBQ25FLFNBQVNDLE9BQU8sRUFBRUMsT0FBTyxRQUFRLGNBQWM7QUF5Qi9DLFNBQVNKLE9BQU8sSUFBSUssUUFBUSxFQUFFQyxrQkFBa0IsUUFBUSxlQUFlO0FBRXZFLGNBQWMsb0JBQW9CO0FBQ2xDLGNBQWMsb0JBQW9CO0FBQ2xDLFNBQVNOLE9BQU8sSUFBSU8sZUFBZSxRQUFRLHNCQUFzQiJ9 |
export * from './SnapshotInterface.js'; | ||
/** Defines a networking endpoint */ | ||
/** To change values on the server */ | ||
/** For retrieval requests */ | ||
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2ludGVyZmFjZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdEluc3RhbmNlVHlwZSwgRGVub3JtYWxpemUsIEVudGl0eU1hcCB9IGZyb20gJy4vbm9ybWFsLmpzJztcbmltcG9ydCB0eXBlIHsgRW5kcG9pbnRFeHRyYU9wdGlvbnMsIEZldGNoRnVuY3Rpb24gfSBmcm9tICcuL3R5cGVzLmpzJztcblxuZXhwb3J0ICogZnJvbSAnLi9TbmFwc2hvdEludGVyZmFjZS5qcyc7XG5cbmV4cG9ydCB0eXBlIFNjaGVtYSA9XG4gIHwgbnVsbFxuICB8IHN0cmluZ1xuICB8IHsgW0s6IHN0cmluZ106IGFueSB9XG4gIHwgU2NoZW1hW11cbiAgfCBTY2hlbWFTaW1wbGVcbiAgfCBTZXJpYWxpemFibGU7XG5cbmV4cG9ydCB0eXBlIFNlcmlhbGl6YWJsZTxcbiAgVCBleHRlbmRzIHsgdG9KU09OKCk6IHN0cmluZyB9ID0geyB0b0pTT04oKTogc3RyaW5nIH0sXG4+ID0ge1xuICBwcm90b3R5cGU6IFQ7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYVNpbXBsZTxUID0gYW55PiB7XG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgYWRkRW50aXR5OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+LFxuICApOiBhbnk7XG4gIGRlbm9ybWFsaXplKFxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG4gICAgaW5wdXQ6IHt9LFxuICAgIHVudmlzaXQ6IFVudmlzaXRGdW5jdGlvbixcbiAgKTogW2Rlbm9ybWFsaXplZDogVCwgZm91bmQ6IGJvb2xlYW4sIHN1c3BlbmQ6IGJvb2xlYW5dO1xuICBpbmZlcihcbiAgICBhcmdzOiByZWFkb25seSBhbnlbXSxcbiAgICBpbmRleGVzOiBOb3JtYWxpemVkSW5kZXgsXG4gICAgcmVjdXJzZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIGVudGl0aWVzOiBFbnRpdHlUYWJsZSxcbiAgKTogYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYUNsYXNzPFQgPSBhbnksIE4gPSBUIHwgdW5kZWZpbmVkPlxuICBleHRlbmRzIFNjaGVtYVNpbXBsZTxUPiB7XG4gIC8vIHRoaXMgaXMgbm90IGFuIGFjdHVhbCBtZW1iZXIsIGJ1dCBpcyBuZWVkZWQgZm9yIHRoZSByZWN1cnNpdmUgTm9ybWFsaXplTnVsbGFibGU8PiB0eXBlIGFsZ29cbiAgX25vcm1hbGl6ZU51bGxhYmxlKCk6IGFueTtcbiAgLy8gdGhpcyBpcyBub3QgYW4gYWN0dWFsIG1lbWJlciwgYnV0IGlzIG5lZWRlZCBmb3IgdGhlIHJlY3Vyc2l2ZSBEZW5vcm1hbGl6ZU51bGxhYmxlPD4gdHlwZSBhbGdvXG4gIF9kZW5vcm1hbGl6ZU51bGxhYmxlKCk6IFtOLCBib29sZWFuLCBib29sZWFuXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbnRpdHlJbnRlcmZhY2U8VCA9IGFueT4gZXh0ZW5kcyBTY2hlbWFTaW1wbGUge1xuICBjcmVhdGVJZlZhbGlkPyhwcm9wczogYW55KTogYW55O1xuICBwayhwYXJhbXM6IGFueSwgcGFyZW50PzogYW55LCBrZXk/OiBzdHJpbmcpOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIHJlYWRvbmx5IGtleTogc3RyaW5nO1xuICBtZXJnZShleGlzdGluZzogYW55LCBpbmNvbWluZzogYW55KTogYW55O1xuICBleHBpcmVzQXQ/KG1ldGE6IGFueSwgaW5wdXQ6IGFueSk6IG51bWJlcjtcbiAgbWVyZ2VXaXRoU3RvcmU/KFxuICAgIGV4aXN0aW5nTWV0YTogYW55LFxuICAgIGluY29taW5nTWV0YTogYW55LFxuICAgIGV4aXN0aW5nOiBhbnksXG4gICAgaW5jb21pbmc6IGFueSxcbiAgKTogYW55O1xuICAvLyBUT0RPKGJyZWFraW5nKTogZGVwcmVjYXRlIHRoaXNcbiAgdXNlSW5jb21pbmc/KFxuICAgIGV4aXN0aW5nTWV0YTogYW55LFxuICAgIGluY29taW5nTWV0YTogYW55LFxuICAgIGV4aXN0aW5nOiBhbnksXG4gICAgaW5jb21pbmc6IGFueSxcbiAgKTogYm9vbGVhbjtcbiAgaW5kZXhlcz86IGFueTtcbiAgc2NoZW1hOiBSZWNvcmQ8c3RyaW5nLCBTY2hlbWE+O1xuICBwcm90b3R5cGU6IFQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVW52aXNpdEZ1bmN0aW9uIHtcbiAgKGlucHV0OiBhbnksIHNjaGVtYTogYW55KTogW2FueSwgYm9vbGVhbiwgYm9vbGVhbl07XG4gIG9nPzogVW52aXNpdEZ1bmN0aW9uO1xuICBzZXRMb2NhbD86IChlbnRpdHk6IGFueSkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBOb3JtYWxpemVkSW5kZXgge1xuICByZWFkb25seSBbZW50aXR5S2V5OiBzdHJpbmddOiB7XG4gICAgcmVhZG9ubHkgW2luZGV4TmFtZTogc3RyaW5nXTogeyByZWFkb25seSBbbG9va3VwOiBzdHJpbmddOiBzdHJpbmcgfTtcbiAgfTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbnRpdHlUYWJsZSB7XG4gIFtlbnRpdHlLZXk6IHN0cmluZ106XG4gICAgfCB7XG4gICAgICAgIFtwazogc3RyaW5nXTogdW5rbm93bjtcbiAgICAgIH1cbiAgICB8IHVuZGVmaW5lZDtcbn1cblxuLyoqIERlZmluZXMgYSBuZXR3b3JraW5nIGVuZHBvaW50ICovXG5leHBvcnQgaW50ZXJmYWNlIEVuZHBvaW50SW50ZXJmYWNlPFxuICBGIGV4dGVuZHMgRmV0Y2hGdW5jdGlvbiA9IEZldGNoRnVuY3Rpb24sXG4gIFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBTY2hlbWEgfCB1bmRlZmluZWQsXG4gIE0gZXh0ZW5kcyB0cnVlIHwgdW5kZWZpbmVkID0gdHJ1ZSB8IHVuZGVmaW5lZCxcbj4gZXh0ZW5kcyBFbmRwb2ludEV4dHJhT3B0aW9uczxGPiB7XG4gICguLi5hcmdzOiBQYXJhbWV0ZXJzPEY+KTogUmV0dXJuVHlwZTxGPjtcbiAga2V5KC4uLmFyZ3M6IFBhcmFtZXRlcnM8Rj4pOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHNpZGVFZmZlY3Q/OiBNO1xuICByZWFkb25seSBzY2hlbWE/OiBTO1xufVxuXG4vKiogVG8gY2hhbmdlIHZhbHVlcyBvbiB0aGUgc2VydmVyICovXG5leHBvcnQgaW50ZXJmYWNlIE11dGF0ZUVuZHBvaW50PFxuICBGIGV4dGVuZHMgRmV0Y2hGdW5jdGlvbiA9IEZldGNoRnVuY3Rpb24sXG4gIFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBTY2hlbWEgfCB1bmRlZmluZWQsXG4+IGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2U8RiwgUywgdHJ1ZT4ge1xuICBzaWRlRWZmZWN0OiB0cnVlO1xufVxuXG4vKiogRm9yIHJldHJpZXZhbCByZXF1ZXN0cyAqL1xuZXhwb3J0IHR5cGUgUmVhZEVuZHBvaW50PFxuICBGIGV4dGVuZHMgRmV0Y2hGdW5jdGlvbiA9IEZldGNoRnVuY3Rpb24sXG4gIFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBTY2hlbWEgfCB1bmRlZmluZWQsXG4+ID0gRW5kcG9pbnRJbnRlcmZhY2U8RiwgUywgdW5kZWZpbmVkPjtcbiJdLCJtYXBwaW5ncyI6IkFBR0EsY0FBYyx3QkFBd0I7QUFBQyJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2ludGVyZmFjZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdEluc3RhbmNlVHlwZSwgRGVub3JtYWxpemUsIEVudGl0eU1hcCB9IGZyb20gJy4vbm9ybWFsLmpzJztcbmltcG9ydCB0eXBlIHsgRW5kcG9pbnRFeHRyYU9wdGlvbnMsIEZldGNoRnVuY3Rpb24gfSBmcm9tICcuL3R5cGVzLmpzJztcblxuZXhwb3J0ICogZnJvbSAnLi9TbmFwc2hvdEludGVyZmFjZS5qcyc7XG5cbmV4cG9ydCB0eXBlIFNjaGVtYSA9XG4gIHwgbnVsbFxuICB8IHN0cmluZ1xuICB8IHsgW0s6IHN0cmluZ106IGFueSB9XG4gIHwgU2NoZW1hW11cbiAgfCBTY2hlbWFTaW1wbGVcbiAgfCBTZXJpYWxpemFibGU7XG5cbmV4cG9ydCB0eXBlIFNlcmlhbGl6YWJsZTxcbiAgVCBleHRlbmRzIHsgdG9KU09OKCk6IHN0cmluZyB9ID0geyB0b0pTT04oKTogc3RyaW5nIH0sXG4+ID0ge1xuICBwcm90b3R5cGU6IFQ7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYVNpbXBsZTxUID0gYW55PiB7XG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgYWRkRW50aXR5OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+LFxuICAgIHN0b3JlRW50aXRpZXM6IGFueSxcbiAgICBhcmdzOiBhbnlbXSxcbiAgKTogYW55O1xuICBkZW5vcm1hbGl6ZShcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuICAgIGlucHV0OiB7fSxcbiAgICB1bnZpc2l0OiBVbnZpc2l0RnVuY3Rpb24sXG4gICk6IFtkZW5vcm1hbGl6ZWQ6IFQsIGZvdW5kOiBib29sZWFuLCBzdXNwZW5kOiBib29sZWFuXTtcbiAgZGVub3JtYWxpemVPbmx5PyhcbiAgICBpbnB1dDoge30sXG4gICAgYXJnczogYW55LFxuICAgIHVudmlzaXQ6IChpbnB1dDogYW55LCBzY2hlbWE6IGFueSkgPT4gYW55LFxuICApOiBUO1xuICBpbmZlcihcbiAgICBhcmdzOiByZWFkb25seSBhbnlbXSxcbiAgICBpbmRleGVzOiBOb3JtYWxpemVkSW5kZXgsXG4gICAgcmVjdXJzZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIGVudGl0aWVzOiBFbnRpdHlUYWJsZSxcbiAgKTogYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYUNsYXNzPFQgPSBhbnksIE4gPSBUIHwgdW5kZWZpbmVkPlxuICBleHRlbmRzIFNjaGVtYVNpbXBsZTxUPiB7XG4gIC8vIHRoaXMgaXMgbm90IGFuIGFjdHVhbCBtZW1iZXIsIGJ1dCBpcyBuZWVkZWQgZm9yIHRoZSByZWN1cnNpdmUgTm9ybWFsaXplTnVsbGFibGU8PiB0eXBlIGFsZ29cbiAgX25vcm1hbGl6ZU51bGxhYmxlKCk6IGFueTtcbiAgLy8gdGhpcyBpcyBub3QgYW4gYWN0dWFsIG1lbWJlciwgYnV0IGlzIG5lZWRlZCBmb3IgdGhlIHJlY3Vyc2l2ZSBEZW5vcm1hbGl6ZU51bGxhYmxlPD4gdHlwZSBhbGdvXG4gIF9kZW5vcm1hbGl6ZU51bGxhYmxlKCk6IFtOLCBib29sZWFuLCBib29sZWFuXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbnRpdHlJbnRlcmZhY2U8VCA9IGFueT4gZXh0ZW5kcyBTY2hlbWFTaW1wbGUge1xuICBjcmVhdGVJZlZhbGlkPyhwcm9wczogYW55KTogYW55O1xuICBwayhwYXJhbXM6IGFueSwgcGFyZW50PzogYW55LCBrZXk/OiBzdHJpbmcsIGFyZ3M/OiBhbnlbXSk6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgcmVhZG9ubHkga2V5OiBzdHJpbmc7XG4gIG1lcmdlKGV4aXN0aW5nOiBhbnksIGluY29taW5nOiBhbnkpOiBhbnk7XG4gIGV4cGlyZXNBdD8obWV0YTogYW55LCBpbnB1dDogYW55KTogbnVtYmVyO1xuICBtZXJnZVdpdGhTdG9yZT8oXG4gICAgZXhpc3RpbmdNZXRhOiBhbnksXG4gICAgaW5jb21pbmdNZXRhOiBhbnksXG4gICAgZXhpc3Rpbmc6IGFueSxcbiAgICBpbmNvbWluZzogYW55LFxuICApOiBhbnk7XG4gIG1lcmdlTWV0YVdpdGhTdG9yZT8oXG4gICAgZXhpc3RpbmdNZXRhOiBhbnksXG4gICAgaW5jb21pbmdNZXRhOiBhbnksXG4gICAgZXhpc3Rpbmc6IGFueSxcbiAgICBpbmNvbWluZzogYW55LFxuICApOiBhbnk7XG4gIC8vIFRPRE8oYnJlYWtpbmcpOiBkZXByZWNhdGUgdGhpc1xuICB1c2VJbmNvbWluZz8oXG4gICAgZXhpc3RpbmdNZXRhOiBhbnksXG4gICAgaW5jb21pbmdNZXRhOiBhbnksXG4gICAgZXhpc3Rpbmc6IGFueSxcbiAgICBpbmNvbWluZzogYW55LFxuICApOiBib29sZWFuO1xuICBpbmRleGVzPzogYW55O1xuICBzY2hlbWE6IFJlY29yZDxzdHJpbmcsIFNjaGVtYT47XG4gIHByb3RvdHlwZTogVDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVbnZpc2l0RnVuY3Rpb24ge1xuICAoaW5wdXQ6IGFueSwgc2NoZW1hOiBhbnkpOiBbYW55LCBib29sZWFuLCBib29sZWFuXSB8IGFueTtcbiAgb2c/OiBVbnZpc2l0RnVuY3Rpb247XG4gIHNldExvY2FsPzogKGVudGl0eTogYW55KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE5vcm1hbGl6ZWRJbmRleCB7XG4gIHJlYWRvbmx5IFtlbnRpdHlLZXk6IHN0cmluZ106IHtcbiAgICByZWFkb25seSBbaW5kZXhOYW1lOiBzdHJpbmddOiB7IHJlYWRvbmx5IFtsb29rdXA6IHN0cmluZ106IHN0cmluZyB9O1xuICB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVudGl0eVRhYmxlIHtcbiAgW2VudGl0eUtleTogc3RyaW5nXTpcbiAgICB8IHtcbiAgICAgICAgW3BrOiBzdHJpbmddOiB1bmtub3duO1xuICAgICAgfVxuICAgIHwgdW5kZWZpbmVkO1xufVxuXG4vKiogRGVmaW5lcyBhIG5ldHdvcmtpbmcgZW5kcG9pbnQgKi9cbmV4cG9ydCBpbnRlcmZhY2UgRW5kcG9pbnRJbnRlcmZhY2U8XG4gIEYgZXh0ZW5kcyBGZXRjaEZ1bmN0aW9uID0gRmV0Y2hGdW5jdGlvbixcbiAgUyBleHRlbmRzIFNjaGVtYSB8IHVuZGVmaW5lZCA9IFNjaGVtYSB8IHVuZGVmaW5lZCxcbiAgTSBleHRlbmRzIHRydWUgfCB1bmRlZmluZWQgPSB0cnVlIHwgdW5kZWZpbmVkLFxuPiBleHRlbmRzIEVuZHBvaW50RXh0cmFPcHRpb25zPEY+IHtcbiAgKC4uLmFyZ3M6IFBhcmFtZXRlcnM8Rj4pOiBSZXR1cm5UeXBlPEY+O1xuICBrZXkoLi4uYXJnczogUGFyYW1ldGVyczxGPik6IHN0cmluZztcbiAgcmVhZG9ubHkgc2lkZUVmZmVjdD86IE07XG4gIHJlYWRvbmx5IHNjaGVtYT86IFM7XG59XG5cbi8qKiBUbyBjaGFuZ2UgdmFsdWVzIG9uIHRoZSBzZXJ2ZXIgKi9cbmV4cG9ydCBpbnRlcmZhY2UgTXV0YXRlRW5kcG9pbnQ8XG4gIEYgZXh0ZW5kcyBGZXRjaEZ1bmN0aW9uID0gRmV0Y2hGdW5jdGlvbixcbiAgUyBleHRlbmRzIFNjaGVtYSB8IHVuZGVmaW5lZCA9IFNjaGVtYSB8IHVuZGVmaW5lZCxcbj4gZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZTxGLCBTLCB0cnVlPiB7XG4gIHNpZGVFZmZlY3Q6IHRydWU7XG59XG5cbi8qKiBGb3IgcmV0cmlldmFsIHJlcXVlc3RzICovXG5leHBvcnQgdHlwZSBSZWFkRW5kcG9pbnQ8XG4gIEYgZXh0ZW5kcyBGZXRjaEZ1bmN0aW9uID0gRmV0Y2hGdW5jdGlvbixcbiAgUyBleHRlbmRzIFNjaGVtYSB8IHVuZGVmaW5lZCA9IFNjaGVtYSB8IHVuZGVmaW5lZCxcbj4gPSBFbmRwb2ludEludGVyZmFjZTxGLCBTLCB1bmRlZmluZWQ+O1xuIl0sIm1hcHBpbmdzIjoiQUFHQSxjQUFjLHdCQUF3Qjs7QUF1R3RDOztBQVlBOztBQVFBO0FBQUEifQ== |
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL25vcm1hbC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIFNjaGVtYSxcbiAgU2VyaWFsaXphYmxlLFxuICBFbnRpdHlJbnRlcmZhY2UsXG4gIE5vcm1hbGl6ZWRJbmRleCxcbiAgU2NoZW1hQ2xhc3MsXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcblxuLy8gVHlwZVNjcmlwdCA8NC4yIEluc3RhbmNlVHlwZTw+IGRvZXMgbm90IHdvcmsgb24gYWJzdHJhY3QgY2xhc3Nlc1xuZXhwb3J0IHR5cGUgQWJzdHJhY3RJbnN0YW5jZVR5cGU8VD4gPSBUIGV4dGVuZHMgbmV3ICguLi5hcmdzOiBhbnkpID0+IGluZmVyIFVcbiAgPyBVXG4gIDogVCBleHRlbmRzIHsgcHJvdG90eXBlOiBpbmZlciBVIH1cbiAgPyBVXG4gIDogbmV2ZXI7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRFbnRpdHk8VD4gPSBUIGV4dGVuZHMge1xuICBwcm90b3R5cGU6IGluZmVyIFU7XG4gIHNjaGVtYTogaW5mZXIgUztcbn1cbiAgPyB7IFtLIGluIEV4Y2x1ZGU8a2V5b2YgVSwga2V5b2YgUz5dOiBVW0tdIH0gJiB7IFtLIGluIGtleW9mIFNdOiBzdHJpbmcgfVxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemU8U1tLXT4gOiBTW0tdO1xufTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVOdWxsYWJsZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemVOdWxsYWJsZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZU51bGxhYmxlPFNbS10+IDogU1tLXTtcbn07XG5cbmludGVyZmFjZSBOZXN0ZWRTY2hlbWFDbGFzczxUID0gYW55PiB7XG4gIHNjaGVtYTogUmVjb3JkPHN0cmluZywgU2NoZW1hPjtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlY29yZENsYXNzPFQgPSBhbnk+IGV4dGVuZHMgTmVzdGVkU2NoZW1hQ2xhc3M8VD4ge1xuICBmcm9tSlM6ICguLi5hcmdzOiBhbnkpID0+IEFic3RyYWN0SW5zdGFuY2VUeXBlPFQ+O1xufVxuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU51bGxhYmxlTmVzdGVkU2NoZW1hPFMgZXh0ZW5kcyBOZXN0ZWRTY2hlbWFDbGFzcz4gPVxuICBrZXlvZiBTWydzY2hlbWEnXSBleHRlbmRzIG5ldmVyXG4gICAgPyBTWydwcm90b3R5cGUnXSAvLyB0aGlzIGlzIHRoZSBjYXNlIG9mIGEgbm9uLXNldCBzY2hlbWEsIHdoaWNoIG1lYW5zIGl0IGFjdHVhbGx5IGhhcyBubyBtZW1iZXJzXG4gICAgOiBzdHJpbmcgZXh0ZW5kcyBrZXlvZiBTWydzY2hlbWEnXVxuICAgID8gU1sncHJvdG90eXBlJ11cbiAgICA6IFNbJ3Byb3RvdHlwZSddICYge1xuICAgICAgICBbSyBpbiBrZXlvZiBTWydzY2hlbWEnXV06IERlbm9ybWFsaXplTnVsbGFibGU8U1snc2NoZW1hJ11bS10+O1xuICAgICAgfTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVSZXR1cm5UeXBlPFQ+ID0gVCBleHRlbmRzIChcbiAgaW5wdXQ6IGFueSxcbiAgdW52aXNpdDogYW55LFxuKSA9PiBbaW5mZXIgUiwgYW55LCBhbnldXG4gID8gUlxuICA6IG5ldmVyO1xuZXhwb3J0IHR5cGUgTm9ybWFsaXplUmV0dXJuVHlwZTxUPiA9IFQgZXh0ZW5kcyAoLi4uYXJnczogYW55KSA9PiBpbmZlciBSXG4gID8gUlxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2U8aW5mZXIgVT5cbiAgPyBVXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gQWJzdHJhY3RJbnN0YW5jZVR5cGU8Uz5cbiAgOiBTIGV4dGVuZHMgU2NoZW1hQ2xhc3NcbiAgPyBEZW5vcm1hbGl6ZVJldHVyblR5cGU8U1snZGVub3JtYWxpemUnXT5cbiAgOiBTIGV4dGVuZHMgU2VyaWFsaXphYmxlPGluZmVyIFQ+XG4gID8gVFxuICA6IFMgZXh0ZW5kcyBBcnJheTxpbmZlciBGPlxuICA/IERlbm9ybWFsaXplPEY+W11cbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBEZW5vcm1hbGl6ZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIERlbm9ybWFsaXplTnVsbGFibGU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlPGFueT5cbiAgPyBEZW5vcm1hbGl6ZU51bGxhYmxlTmVzdGVkU2NoZW1hPFM+IHwgdW5kZWZpbmVkXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gRGVub3JtYWxpemVOdWxsYWJsZU5lc3RlZFNjaGVtYTxTPlxuICA6IFMgZXh0ZW5kcyBTY2hlbWFDbGFzc1xuICA/IERlbm9ybWFsaXplUmV0dXJuVHlwZTxTWydfZGVub3JtYWxpemVOdWxsYWJsZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gRGVub3JtYWxpemU8Rj5bXSB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IERlbm9ybWFsaXplTnVsbGFibGVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlXG4gID8gc3RyaW5nXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gTm9ybWFsaXplT2JqZWN0PFNbJ3NjaGVtYSddPlxuICA6IFMgZXh0ZW5kcyBTY2hlbWFDbGFzc1xuICA/IE5vcm1hbGl6ZVJldHVyblR5cGU8U1snbm9ybWFsaXplJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBOb3JtYWxpemU8Rj5bXVxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IE5vcm1hbGl6ZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZU51bGxhYmxlPFM+ID0gUyBleHRlbmRzIEVudGl0eUludGVyZmFjZVxuICA/IHN0cmluZyB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyBSZWNvcmRDbGFzc1xuICA/IE5vcm1hbGl6ZWROdWxsYWJsZU9iamVjdDxTWydzY2hlbWEnXT5cbiAgOiBTIGV4dGVuZHMgU2NoZW1hQ2xhc3NcbiAgPyBOb3JtYWxpemVSZXR1cm5UeXBlPFNbJ19ub3JtYWxpemVOdWxsYWJsZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gTm9ybWFsaXplPEY+W10gfCB1bmRlZmluZWRcbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVkU2NoZW1hPEUsIFI+ID0ge1xuICBlbnRpdGllczogRTtcbiAgcmVzdWx0OiBSO1xuICBpbmRleGVzOiBOb3JtYWxpemVkSW5kZXg7XG4gIGVudGl0eU1ldGE6IHtcbiAgICByZWFkb25seSBbZW50aXR5S2V5OiBzdHJpbmddOiB7XG4gICAgICByZWFkb25seSBbcGs6IHN0cmluZ106IHtcbiAgICAgICAgcmVhZG9ubHkgZGF0ZTogbnVtYmVyO1xuICAgICAgICByZWFkb25seSBleHBpcmVzQXQ6IG51bWJlcjtcbiAgICAgICAgcmVhZG9ubHkgZmV0Y2hlZEF0OiBudW1iZXI7XG4gICAgICB9O1xuICAgIH07XG4gIH07XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIEVudGl0eU1hcDxUID0gYW55PiB7XG4gIHJlYWRvbmx5IFtrOiBzdHJpbmddOiBFbnRpdHlJbnRlcmZhY2U8VD47XG59XG4iXSwibWFwcGluZ3MiOiIifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL25vcm1hbC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIFNjaGVtYSxcbiAgU2VyaWFsaXphYmxlLFxuICBFbnRpdHlJbnRlcmZhY2UsXG4gIE5vcm1hbGl6ZWRJbmRleCxcbiAgU2NoZW1hQ2xhc3MsXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcblxuLy8gVHlwZVNjcmlwdCA8NC4yIEluc3RhbmNlVHlwZTw+IGRvZXMgbm90IHdvcmsgb24gYWJzdHJhY3QgY2xhc3Nlc1xuZXhwb3J0IHR5cGUgQWJzdHJhY3RJbnN0YW5jZVR5cGU8VD4gPSBUIGV4dGVuZHMgbmV3ICguLi5hcmdzOiBhbnkpID0+IGluZmVyIFVcbiAgPyBVXG4gIDogVCBleHRlbmRzIHsgcHJvdG90eXBlOiBpbmZlciBVIH1cbiAgPyBVXG4gIDogbmV2ZXI7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRFbnRpdHk8VD4gPSBUIGV4dGVuZHMge1xuICBwcm90b3R5cGU6IGluZmVyIFU7XG4gIHNjaGVtYTogaW5mZXIgUztcbn1cbiAgPyB7IFtLIGluIEV4Y2x1ZGU8a2V5b2YgVSwga2V5b2YgUz5dOiBVW0tdIH0gJiB7IFtLIGluIGtleW9mIFNdOiBzdHJpbmcgfVxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemU8U1tLXT4gOiBTW0tdO1xufTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVOdWxsYWJsZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemVOdWxsYWJsZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZU51bGxhYmxlPFNbS10+IDogU1tLXTtcbn07XG5cbmludGVyZmFjZSBOZXN0ZWRTY2hlbWFDbGFzczxUID0gYW55PiB7XG4gIHNjaGVtYTogUmVjb3JkPHN0cmluZywgU2NoZW1hPjtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlY29yZENsYXNzPFQgPSBhbnk+IGV4dGVuZHMgTmVzdGVkU2NoZW1hQ2xhc3M8VD4ge1xuICBmcm9tSlM6ICguLi5hcmdzOiBhbnkpID0+IEFic3RyYWN0SW5zdGFuY2VUeXBlPFQ+O1xufVxuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU51bGxhYmxlTmVzdGVkU2NoZW1hPFMgZXh0ZW5kcyBOZXN0ZWRTY2hlbWFDbGFzcz4gPVxuICBrZXlvZiBTWydzY2hlbWEnXSBleHRlbmRzIG5ldmVyXG4gICAgPyBTWydwcm90b3R5cGUnXSAvLyB0aGlzIGlzIHRoZSBjYXNlIG9mIGEgbm9uLXNldCBzY2hlbWEsIHdoaWNoIG1lYW5zIGl0IGFjdHVhbGx5IGhhcyBubyBtZW1iZXJzXG4gICAgOiBzdHJpbmcgZXh0ZW5kcyBrZXlvZiBTWydzY2hlbWEnXVxuICAgID8gU1sncHJvdG90eXBlJ11cbiAgICA6IFNbJ3Byb3RvdHlwZSddICYge1xuICAgICAgICBbSyBpbiBrZXlvZiBTWydzY2hlbWEnXV06IERlbm9ybWFsaXplTnVsbGFibGU8U1snc2NoZW1hJ11bS10+O1xuICAgICAgfTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVSZXR1cm5UeXBlPFQ+ID0gVCBleHRlbmRzIChcbiAgaW5wdXQ6IGFueSxcbiAgdW52aXNpdDogYW55LFxuKSA9PiBbaW5mZXIgUiwgYW55LCBhbnldXG4gID8gUlxuICA6IG5ldmVyO1xuZXhwb3J0IHR5cGUgTm9ybWFsaXplUmV0dXJuVHlwZTxUPiA9IFQgZXh0ZW5kcyAoLi4uYXJnczogYW55KSA9PiBpbmZlciBSXG4gID8gUlxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2U8aW5mZXIgVT5cbiAgPyBVXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gQWJzdHJhY3RJbnN0YW5jZVR5cGU8Uz5cbiAgOiBTIGV4dGVuZHMgeyBkZW5vcm1hbGl6ZU9ubHk6ICguLi5hcmdzOiBhbnkpID0+IGFueSB9XG4gID8gUmV0dXJuVHlwZTxTWydkZW5vcm1hbGl6ZU9ubHknXT5cbiAgOiBTIGV4dGVuZHMgeyBkZW5vcm1hbGl6ZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBEZW5vcm1hbGl6ZVJldHVyblR5cGU8U1snZGVub3JtYWxpemUnXT5cbiAgOiBTIGV4dGVuZHMgU2VyaWFsaXphYmxlPGluZmVyIFQ+XG4gID8gVFxuICA6IFMgZXh0ZW5kcyBBcnJheTxpbmZlciBGPlxuICA/IERlbm9ybWFsaXplPEY+W11cbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBEZW5vcm1hbGl6ZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIERlbm9ybWFsaXplTnVsbGFibGU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlPGFueT5cbiAgPyBEZW5vcm1hbGl6ZU51bGxhYmxlTmVzdGVkU2NoZW1hPFM+IHwgdW5kZWZpbmVkXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gRGVub3JtYWxpemVOdWxsYWJsZU5lc3RlZFNjaGVtYTxTPlxuICA6IFMgZXh0ZW5kcyB7IF9kZW5vcm1hbGl6ZU51bGxhYmxlOiAoLi4uYXJnczogYW55KSA9PiBhbnkgfVxuICA/IERlbm9ybWFsaXplUmV0dXJuVHlwZTxTWydfZGVub3JtYWxpemVOdWxsYWJsZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gRGVub3JtYWxpemU8Rj5bXSB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IERlbm9ybWFsaXplTnVsbGFibGVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlXG4gID8gc3RyaW5nXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gTm9ybWFsaXplT2JqZWN0PFNbJ3NjaGVtYSddPlxuICA6IFMgZXh0ZW5kcyB7IG5vcm1hbGl6ZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBOb3JtYWxpemVSZXR1cm5UeXBlPFNbJ25vcm1hbGl6ZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gTm9ybWFsaXplPEY+W11cbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBOb3JtYWxpemVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVOdWxsYWJsZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2VcbiAgPyBzdHJpbmcgfCB1bmRlZmluZWRcbiAgOiBTIGV4dGVuZHMgUmVjb3JkQ2xhc3NcbiAgPyBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8U1snc2NoZW1hJ10+XG4gIDogUyBleHRlbmRzIHsgX25vcm1hbGl6ZU51bGxhYmxlOiAoLi4uYXJnczogYW55KSA9PiBhbnkgfVxuICA/IE5vcm1hbGl6ZVJldHVyblR5cGU8U1snX25vcm1hbGl6ZU51bGxhYmxlJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBOb3JtYWxpemU8Rj5bXSB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IE5vcm1hbGl6ZWROdWxsYWJsZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRTY2hlbWE8RSwgUj4gPSB7XG4gIGVudGl0aWVzOiBFO1xuICByZXN1bHQ6IFI7XG4gIGluZGV4ZXM6IE5vcm1hbGl6ZWRJbmRleDtcbiAgZW50aXR5TWV0YToge1xuICAgIHJlYWRvbmx5IFtlbnRpdHlLZXk6IHN0cmluZ106IHtcbiAgICAgIHJlYWRvbmx5IFtwazogc3RyaW5nXToge1xuICAgICAgICByZWFkb25seSBkYXRlOiBudW1iZXI7XG4gICAgICAgIHJlYWRvbmx5IGV4cGlyZXNBdDogbnVtYmVyO1xuICAgICAgICByZWFkb25seSBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgICAgIH07XG4gICAgfTtcbiAgfTtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW50aXR5TWFwPFQgPSBhbnk+IHtcbiAgcmVhZG9ubHkgW2s6IHN0cmluZ106IEVudGl0eUludGVyZmFjZTxUPjtcbn1cbiJdLCJtYXBwaW5ncyI6IiJ9 |
@@ -24,6 +24,14 @@ /** | ||
}, unvisit) => { | ||
if (input === undefined) return [undefined, false, true]; | ||
if (input === undefined) return [undefined, false, false]; | ||
const [value, found, deleted] = schema.denormalize(input, unvisit); | ||
return [found ? this.process(value, ...args) : undefined, found, deleted]; | ||
}; | ||
if (schema.denormalizeOnly) query.denormalizeOnly = ({ | ||
args, | ||
input | ||
}, _, unvisit) => { | ||
if (input === undefined) return undefined; | ||
const value = schema.denormalizeOnly(input, args, unvisit); | ||
return typeof value === 'symbol' ? undefined : this.process(value, ...args); | ||
}; | ||
query.infer = (args, indexes, recurse, entities) => { | ||
@@ -38,2 +46,2 @@ return { | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJRdWVyeSIsImNvbnN0cnVjdG9yIiwic2NoZW1hIiwicHJvY2VzcyIsInNpZGVFZmZlY3QiLCJ1bmRlZmluZWQiLCJjcmVhdGVRdWVyeVNjaGVtYSIsImVudHJpZXMiLCJrZXkiLCJhcmdzIiwiSlNPTiIsInN0cmluZ2lmeSIsInF1ZXJ5IiwiT2JqZWN0IiwiY3JlYXRlIiwiZGVub3JtYWxpemUiLCJpbnB1dCIsInVudmlzaXQiLCJ2YWx1ZSIsImZvdW5kIiwiZGVsZXRlZCIsImluZmVyIiwiaW5kZXhlcyIsInJlY3Vyc2UiLCJlbnRpdGllcyJdLCJzb3VyY2VzIjpbIi4uL3NyYy9xdWVyeUVuZHBvaW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtcbiAgRW50aXR5VGFibGUsXG4gIE5vcm1hbGl6ZWRJbmRleCxcbiAgU2NoZW1hU2ltcGxlLFxuICBVbnZpc2l0RnVuY3Rpb24sXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcbmltcG9ydCB0eXBlIHsgRGVub3JtYWxpemUgfSBmcm9tICcuL25vcm1hbC5qcyc7XG5cbi8qKlxuICogUHJvZ3JhbW1hdGljIGNhY2hlIHJlYWRpbmdcbiAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vcmVzdC9hcGkvUXVlcnlcbiAqL1xuZXhwb3J0IGNsYXNzIFF1ZXJ5PFxuICBTIGV4dGVuZHMgU2NoZW1hU2ltcGxlLFxuICBQIGV4dGVuZHMgYW55W10gPSBbXSxcbiAgUiA9IERlbm9ybWFsaXplPFM+LFxuPiB7XG4gIGRlY2xhcmUgc2NoZW1hOiBRdWVyeVNjaGVtYTxTLCBSPjtcbiAgLy8gVE9ETzogYWxsb3cgYXJiaXRyYXJ5IHJldHVybiB0eXBlcyB0aGVuIGluZmVycmluZyBpdCBmcm9tXG4gIGRlY2xhcmUgcHJvY2VzczogKGVudHJpZXM6IERlbm9ybWFsaXplPFM+LCAuLi5hcmdzOiBQKSA9PiBSO1xuXG4gIHJlYWRvbmx5IHNpZGVFZmZlY3QgPSB1bmRlZmluZWQ7XG5cbiAgY29uc3RydWN0b3Ioc2NoZW1hOiBTLCBwcm9jZXNzPzogKGVudHJpZXM6IERlbm9ybWFsaXplPFM+LCAuLi5hcmdzOiBQKSA9PiBSKSB7XG4gICAgdGhpcy5zY2hlbWEgPSB0aGlzLmNyZWF0ZVF1ZXJ5U2NoZW1hKHNjaGVtYSk7XG4gICAgaWYgKHByb2Nlc3MpIHRoaXMucHJvY2VzcyA9IHByb2Nlc3M7XG4gICAgLy8gYWxsb3dzIGZvciBpbmhlcml0YW5jZSBvdmVycmlkZXNcbiAgICBlbHNlIGlmICghdGhpcy5wcm9jZXNzKVxuICAgICAgdGhpcy5wcm9jZXNzID0gKChlbnRyaWVzOiBEZW5vcm1hbGl6ZTxTPikgPT4gZW50cmllcykgYXMgYW55O1xuICB9XG5cbiAga2V5KC4uLmFyZ3M6IFApIHtcbiAgICByZXR1cm4gYFFVRVJZICR7SlNPTi5zdHJpbmdpZnkoYXJncyl9YDtcbiAgfVxuXG4gIHByb3RlY3RlZCBjcmVhdGVRdWVyeVNjaGVtYShzY2hlbWE6IFNjaGVtYVNpbXBsZSkge1xuICAgIGNvbnN0IHF1ZXJ5ID0gT2JqZWN0LmNyZWF0ZShzY2hlbWEpO1xuICAgIHF1ZXJ5LmRlbm9ybWFsaXplID0gKFxuICAgICAgeyBhcmdzLCBpbnB1dCB9OiB7IGFyZ3M6IFA7IGlucHV0OiBhbnkgfSxcbiAgICAgIHVudmlzaXQ6IGFueSxcbiAgICApID0+IHtcbiAgICAgIGlmIChpbnB1dCA9PT0gdW5kZWZpbmVkKSByZXR1cm4gW3VuZGVmaW5lZCwgZmFsc2UsIHRydWVdO1xuICAgICAgY29uc3QgW3ZhbHVlLCBmb3VuZCwgZGVsZXRlZF0gPSBzY2hlbWEuZGVub3JtYWxpemUoaW5wdXQsIHVudmlzaXQpO1xuICAgICAgcmV0dXJuIFtmb3VuZCA/IHRoaXMucHJvY2Vzcyh2YWx1ZSwgLi4uYXJncykgOiB1bmRlZmluZWQsIGZvdW5kLCBkZWxldGVkXTtcbiAgICB9O1xuICAgIHF1ZXJ5LmluZmVyID0gKFxuICAgICAgYXJnczogYW55LFxuICAgICAgaW5kZXhlczogYW55LFxuICAgICAgcmVjdXJzZTogKFxuICAgICAgICBzY2hlbWE6IFNjaGVtYVNpbXBsZSxcbiAgICAgICAgYXJnczogYW55W10sXG4gICAgICAgIGluZGV4ZXM6IE5vcm1hbGl6ZWRJbmRleCxcbiAgICAgICAgZW50aXRpZXM6IEVudGl0eVRhYmxlLFxuICAgICAgKSA9PiBhbnksXG4gICAgICBlbnRpdGllczogRW50aXR5VGFibGUsXG4gICAgKSA9PiB7XG4gICAgICByZXR1cm4geyBhcmdzLCBpbnB1dDogcmVjdXJzZShzY2hlbWEsIGFyZ3MsIGluZGV4ZXMsIGVudGl0aWVzKSB9O1xuICAgIH07XG4gICAgcmV0dXJuIHF1ZXJ5O1xuICB9XG59XG5cbnR5cGUgUXVlcnlTY2hlbWE8U2NoZW1hLCBSPiA9IEV4Y2x1ZGU8XG4gIFNjaGVtYSxcbiAgJ2Rlbm9ybWFsaXplJyB8ICdfZGVub3JtYWxpemVOdWxsYWJsZSdcbj4gJiB7XG4gIGRlbm9ybWFsaXplKFxuICAgIGlucHV0OiB7fSxcbiAgICB1bnZpc2l0OiBVbnZpc2l0RnVuY3Rpb24sXG4gICk6IFtkZW5vcm1hbGl6ZWQ6IFIsIGZvdW5kOiBib29sZWFuLCBzdXNwZW5kOiBib29sZWFuXTtcbiAgX2Rlbm9ybWFsaXplTnVsbGFibGUoXG4gICAgaW5wdXQ6IHt9LFxuICAgIHVudmlzaXQ6IFVudmlzaXRGdW5jdGlvbixcbiAgKTogW2Rlbm9ybWFsaXplZDogUiB8IHVuZGVmaW5lZCwgZm91bmQ6IGJvb2xlYW4sIHN1c3BlbmQ6IGJvb2xlYW5dO1xufTtcbiJdLCJtYXBwaW5ncyI6IkFBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLE1BQU1BLEtBQUssQ0FJaEI7RUFFQTs7RUFLQUMsV0FBV0EsQ0FBQ0MsTUFBUyxFQUFFQyxPQUFvRCxFQUFFO0lBQUEsS0FGcEVDLFVBQVUsR0FBR0MsU0FBUztJQUc3QixJQUFJLENBQUNILE1BQU0sR0FBRyxJQUFJLENBQUNJLGlCQUFpQixDQUFDSixNQUFNLENBQUM7SUFDNUMsSUFBSUMsT0FBTyxFQUFFLElBQUksQ0FBQ0EsT0FBTyxHQUFHQSxPQUFPO0lBQ25DO0lBQUEsS0FDSyxJQUFJLENBQUMsSUFBSSxDQUFDQSxPQUFPLEVBQ3BCLElBQUksQ0FBQ0EsT0FBTyxHQUFLSSxPQUF1QixJQUFLQSxPQUFlO0VBQ2hFO0VBRUFDLEdBQUdBLENBQUMsR0FBR0MsSUFBTyxFQUFFO0lBQ2QsT0FBUSxTQUFRQyxJQUFJLENBQUNDLFNBQVMsQ0FBQ0YsSUFBSSxDQUFFLEVBQUM7RUFDeEM7RUFFVUgsaUJBQWlCQSxDQUFDSixNQUFvQixFQUFFO0lBQ2hELE1BQU1VLEtBQUssR0FBR0MsTUFBTSxDQUFDQyxNQUFNLENBQUNaLE1BQU0sQ0FBQztJQUNuQ1UsS0FBSyxDQUFDRyxXQUFXLEdBQUcsQ0FDbEI7TUFBRU4sSUFBSTtNQUFFTztJQUErQixDQUFDLEVBQ3hDQyxPQUFZLEtBQ1Q7TUFDSCxJQUFJRCxLQUFLLEtBQUtYLFNBQVMsRUFBRSxPQUFPLENBQUNBLFNBQVMsRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDO01BQ3hELE1BQU0sQ0FBQ2EsS0FBSyxFQUFFQyxLQUFLLEVBQUVDLE9BQU8sQ0FBQyxHQUFHbEIsTUFBTSxDQUFDYSxXQUFXLENBQUNDLEtBQUssRUFBRUMsT0FBTyxDQUFDO01BQ2xFLE9BQU8sQ0FBQ0UsS0FBSyxHQUFHLElBQUksQ0FBQ2hCLE9BQU8sQ0FBQ2UsS0FBSyxFQUFFLEdBQUdULElBQUksQ0FBQyxHQUFHSixTQUFTLEVBQUVjLEtBQUssRUFBRUMsT0FBTyxDQUFDO0lBQzNFLENBQUM7SUFDRFIsS0FBSyxDQUFDUyxLQUFLLEdBQUcsQ0FDWlosSUFBUyxFQUNUYSxPQUFZLEVBQ1pDLE9BS1EsRUFDUkMsUUFBcUIsS0FDbEI7TUFDSCxPQUFPO1FBQUVmLElBQUk7UUFBRU8sS0FBSyxFQUFFTyxPQUFPLENBQUNyQixNQUFNLEVBQUVPLElBQUksRUFBRWEsT0FBTyxFQUFFRSxRQUFRO01BQUUsQ0FBQztJQUNsRSxDQUFDO0lBQ0QsT0FBT1osS0FBSztFQUNkO0FBQ0YifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJRdWVyeSIsImNvbnN0cnVjdG9yIiwic2NoZW1hIiwicHJvY2VzcyIsInNpZGVFZmZlY3QiLCJ1bmRlZmluZWQiLCJjcmVhdGVRdWVyeVNjaGVtYSIsImVudHJpZXMiLCJrZXkiLCJhcmdzIiwiSlNPTiIsInN0cmluZ2lmeSIsInF1ZXJ5IiwiT2JqZWN0IiwiY3JlYXRlIiwiZGVub3JtYWxpemUiLCJpbnB1dCIsInVudmlzaXQiLCJ2YWx1ZSIsImZvdW5kIiwiZGVsZXRlZCIsImRlbm9ybWFsaXplT25seSIsIl8iLCJpbmZlciIsImluZGV4ZXMiLCJyZWN1cnNlIiwiZW50aXRpZXMiXSwic291cmNlcyI6WyIuLi9zcmMvcXVlcnlFbmRwb2ludC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIEVudGl0eVRhYmxlLFxuICBOb3JtYWxpemVkSW5kZXgsXG4gIFNjaGVtYVNpbXBsZSxcbiAgVW52aXNpdEZ1bmN0aW9uLFxufSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IERlbm9ybWFsaXplIH0gZnJvbSAnLi9ub3JtYWwuanMnO1xuXG4vKipcbiAqIFByb2dyYW1tYXRpYyBjYWNoZSByZWFkaW5nXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL3Jlc3QvYXBpL1F1ZXJ5XG4gKi9cbmV4cG9ydCBjbGFzcyBRdWVyeTxcbiAgUyBleHRlbmRzIFNjaGVtYVNpbXBsZSxcbiAgUCBleHRlbmRzIGFueVtdID0gW10sXG4gIFIgPSBEZW5vcm1hbGl6ZTxTPixcbj4ge1xuICBkZWNsYXJlIHNjaGVtYTogUXVlcnlTY2hlbWE8UywgUj47XG4gIC8vIFRPRE86IGFsbG93IGFyYml0cmFyeSByZXR1cm4gdHlwZXMgdGhlbiBpbmZlcnJpbmcgaXQgZnJvbVxuICBkZWNsYXJlIHByb2Nlc3M6IChlbnRyaWVzOiBEZW5vcm1hbGl6ZTxTPiwgLi4uYXJnczogUCkgPT4gUjtcblxuICByZWFkb25seSBzaWRlRWZmZWN0ID0gdW5kZWZpbmVkO1xuXG4gIGNvbnN0cnVjdG9yKHNjaGVtYTogUywgcHJvY2Vzcz86IChlbnRyaWVzOiBEZW5vcm1hbGl6ZTxTPiwgLi4uYXJnczogUCkgPT4gUikge1xuICAgIHRoaXMuc2NoZW1hID0gdGhpcy5jcmVhdGVRdWVyeVNjaGVtYShzY2hlbWEpO1xuICAgIGlmIChwcm9jZXNzKSB0aGlzLnByb2Nlc3MgPSBwcm9jZXNzO1xuICAgIC8vIGFsbG93cyBmb3IgaW5oZXJpdGFuY2Ugb3ZlcnJpZGVzXG4gICAgZWxzZSBpZiAoIXRoaXMucHJvY2VzcylcbiAgICAgIHRoaXMucHJvY2VzcyA9ICgoZW50cmllczogRGVub3JtYWxpemU8Uz4pID0+IGVudHJpZXMpIGFzIGFueTtcbiAgfVxuXG4gIGtleSguLi5hcmdzOiBQKSB7XG4gICAgcmV0dXJuIGBRVUVSWSAke0pTT04uc3RyaW5naWZ5KGFyZ3MpfWA7XG4gIH1cblxuICBwcm90ZWN0ZWQgY3JlYXRlUXVlcnlTY2hlbWEoc2NoZW1hOiBTY2hlbWFTaW1wbGUpIHtcbiAgICBjb25zdCBxdWVyeSA9IE9iamVjdC5jcmVhdGUoc2NoZW1hKTtcbiAgICBxdWVyeS5kZW5vcm1hbGl6ZSA9IChcbiAgICAgIHsgYXJncywgaW5wdXQgfTogeyBhcmdzOiBQOyBpbnB1dDogYW55IH0sXG4gICAgICB1bnZpc2l0OiBhbnksXG4gICAgKSA9PiB7XG4gICAgICBpZiAoaW5wdXQgPT09IHVuZGVmaW5lZCkgcmV0dXJuIFt1bmRlZmluZWQsIGZhbHNlLCBmYWxzZV07XG4gICAgICBjb25zdCBbdmFsdWUsIGZvdW5kLCBkZWxldGVkXSA9IHNjaGVtYS5kZW5vcm1hbGl6ZShpbnB1dCwgdW52aXNpdCk7XG4gICAgICByZXR1cm4gW2ZvdW5kID8gdGhpcy5wcm9jZXNzKHZhbHVlLCAuLi5hcmdzKSA6IHVuZGVmaW5lZCwgZm91bmQsIGRlbGV0ZWRdO1xuICAgIH07XG4gICAgaWYgKHNjaGVtYS5kZW5vcm1hbGl6ZU9ubHkpXG4gICAgICBxdWVyeS5kZW5vcm1hbGl6ZU9ubHkgPSAoXG4gICAgICAgIHsgYXJncywgaW5wdXQgfTogeyBhcmdzOiBQOyBpbnB1dDogYW55IH0sXG4gICAgICAgIF86IFAsXG4gICAgICAgIHVudmlzaXQ6IGFueSxcbiAgICAgICkgPT4ge1xuICAgICAgICBpZiAoaW5wdXQgPT09IHVuZGVmaW5lZCkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICAgICAgY29uc3QgdmFsdWUgPSAoc2NoZW1hIGFzIGFueSkuZGVub3JtYWxpemVPbmx5KGlucHV0LCBhcmdzLCB1bnZpc2l0KTtcbiAgICAgICAgcmV0dXJuIHR5cGVvZiB2YWx1ZSA9PT0gJ3N5bWJvbCdcbiAgICAgICAgICA/IHVuZGVmaW5lZFxuICAgICAgICAgIDogdGhpcy5wcm9jZXNzKHZhbHVlLCAuLi5hcmdzKTtcbiAgICAgIH07XG4gICAgcXVlcnkuaW5mZXIgPSAoXG4gICAgICBhcmdzOiBhbnksXG4gICAgICBpbmRleGVzOiBhbnksXG4gICAgICByZWN1cnNlOiAoXG4gICAgICAgIHNjaGVtYTogU2NoZW1hU2ltcGxlLFxuICAgICAgICBhcmdzOiBhbnlbXSxcbiAgICAgICAgaW5kZXhlczogTm9ybWFsaXplZEluZGV4LFxuICAgICAgICBlbnRpdGllczogRW50aXR5VGFibGUsXG4gICAgICApID0+IGFueSxcbiAgICAgIGVudGl0aWVzOiBFbnRpdHlUYWJsZSxcbiAgICApID0+IHtcbiAgICAgIHJldHVybiB7IGFyZ3MsIGlucHV0OiByZWN1cnNlKHNjaGVtYSwgYXJncywgaW5kZXhlcywgZW50aXRpZXMpIH07XG4gICAgfTtcbiAgICByZXR1cm4gcXVlcnk7XG4gIH1cbn1cblxudHlwZSBRdWVyeVNjaGVtYTxTY2hlbWEsIFI+ID0gRXhjbHVkZTxcbiAgU2NoZW1hLFxuICAnZGVub3JtYWxpemUnIHwgJ19kZW5vcm1hbGl6ZU51bGxhYmxlJ1xuPiAmIHtcbiAgZGVub3JtYWxpemUoXG4gICAgaW5wdXQ6IHt9LFxuICAgIHVudmlzaXQ6IFVudmlzaXRGdW5jdGlvbixcbiAgKTogW2Rlbm9ybWFsaXplZDogUiwgZm91bmQ6IGJvb2xlYW4sIHN1c3BlbmQ6IGJvb2xlYW5dO1xuICBfZGVub3JtYWxpemVOdWxsYWJsZShcbiAgICBpbnB1dDoge30sXG4gICAgdW52aXNpdDogVW52aXNpdEZ1bmN0aW9uLFxuICApOiBbZGVub3JtYWxpemVkOiBSIHwgdW5kZWZpbmVkLCBmb3VuZDogYm9vbGVhbiwgc3VzcGVuZDogYm9vbGVhbl07XG4gIGRlbm9ybWFsaXplT25seShcbiAgICBpbnB1dDoge30sXG4gICAgYXJnczogcmVhZG9ubHkgYW55W10sXG4gICAgdW52aXNpdDogKGlucHV0OiBhbnksIHNjaGVtYTogYW55KSA9PiBhbnksXG4gICk6IFI7XG59O1xuIl0sIm1hcHBpbmdzIjoiQUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sTUFBTUEsS0FBSyxDQUloQjtFQUVBOztFQUtBQyxXQUFXQSxDQUFDQyxNQUFTLEVBQUVDLE9BQW9ELEVBQUU7SUFBQSxLQUZwRUMsVUFBVSxHQUFHQyxTQUFTO0lBRzdCLElBQUksQ0FBQ0gsTUFBTSxHQUFHLElBQUksQ0FBQ0ksaUJBQWlCLENBQUNKLE1BQU0sQ0FBQztJQUM1QyxJQUFJQyxPQUFPLEVBQUUsSUFBSSxDQUFDQSxPQUFPLEdBQUdBLE9BQU87SUFDbkM7SUFBQSxLQUNLLElBQUksQ0FBQyxJQUFJLENBQUNBLE9BQU8sRUFDcEIsSUFBSSxDQUFDQSxPQUFPLEdBQUtJLE9BQXVCLElBQUtBLE9BQWU7RUFDaEU7RUFFQUMsR0FBR0EsQ0FBQyxHQUFHQyxJQUFPLEVBQUU7SUFDZCxPQUFRLFNBQVFDLElBQUksQ0FBQ0MsU0FBUyxDQUFDRixJQUFJLENBQUUsRUFBQztFQUN4QztFQUVVSCxpQkFBaUJBLENBQUNKLE1BQW9CLEVBQUU7SUFDaEQsTUFBTVUsS0FBSyxHQUFHQyxNQUFNLENBQUNDLE1BQU0sQ0FBQ1osTUFBTSxDQUFDO0lBQ25DVSxLQUFLLENBQUNHLFdBQVcsR0FBRyxDQUNsQjtNQUFFTixJQUFJO01BQUVPO0lBQStCLENBQUMsRUFDeENDLE9BQVksS0FDVDtNQUNILElBQUlELEtBQUssS0FBS1gsU0FBUyxFQUFFLE9BQU8sQ0FBQ0EsU0FBUyxFQUFFLEtBQUssRUFBRSxLQUFLLENBQUM7TUFDekQsTUFBTSxDQUFDYSxLQUFLLEVBQUVDLEtBQUssRUFBRUMsT0FBTyxDQUFDLEdBQUdsQixNQUFNLENBQUNhLFdBQVcsQ0FBQ0MsS0FBSyxFQUFFQyxPQUFPLENBQUM7TUFDbEUsT0FBTyxDQUFDRSxLQUFLLEdBQUcsSUFBSSxDQUFDaEIsT0FBTyxDQUFDZSxLQUFLLEVBQUUsR0FBR1QsSUFBSSxDQUFDLEdBQUdKLFNBQVMsRUFBRWMsS0FBSyxFQUFFQyxPQUFPLENBQUM7SUFDM0UsQ0FBQztJQUNELElBQUlsQixNQUFNLENBQUNtQixlQUFlLEVBQ3hCVCxLQUFLLENBQUNTLGVBQWUsR0FBRyxDQUN0QjtNQUFFWixJQUFJO01BQUVPO0lBQStCLENBQUMsRUFDeENNLENBQUksRUFDSkwsT0FBWSxLQUNUO01BQ0gsSUFBSUQsS0FBSyxLQUFLWCxTQUFTLEVBQUUsT0FBT0EsU0FBUztNQUN6QyxNQUFNYSxLQUFLLEdBQUloQixNQUFNLENBQVNtQixlQUFlLENBQUNMLEtBQUssRUFBRVAsSUFBSSxFQUFFUSxPQUFPLENBQUM7TUFDbkUsT0FBTyxPQUFPQyxLQUFLLEtBQUssUUFBUSxHQUM1QmIsU0FBUyxHQUNULElBQUksQ0FBQ0YsT0FBTyxDQUFDZSxLQUFLLEVBQUUsR0FBR1QsSUFBSSxDQUFDO0lBQ2xDLENBQUM7SUFDSEcsS0FBSyxDQUFDVyxLQUFLLEdBQUcsQ0FDWmQsSUFBUyxFQUNUZSxPQUFZLEVBQ1pDLE9BS1EsRUFDUkMsUUFBcUIsS0FDbEI7TUFDSCxPQUFPO1FBQUVqQixJQUFJO1FBQUVPLEtBQUssRUFBRVMsT0FBTyxDQUFDdkIsTUFBTSxFQUFFTyxJQUFJLEVBQUVlLE9BQU8sRUFBRUUsUUFBUTtNQUFFLENBQUM7SUFDbEUsQ0FBQztJQUNELE9BQU9kLEtBQUs7RUFDZDtBQUNGIn0= |
@@ -8,3 +8,5 @@ /* istanbul ignore file */ | ||
export { default as Delete } from './schemas/Delete.js'; | ||
export { default as Invalidate } from './schemas/Invalidate.js'; | ||
export { default as Collection } from './schemas/Collection.js'; | ||
export { default as Entity } from './schemas/EntitySchema.js'; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkZWZhdWx0IiwiVW5pb24iLCJWYWx1ZXMiLCJBcnJheSIsIkFsbCIsIk9iamVjdCIsIkRlbGV0ZSIsIkVudGl0eSJdLCJzb3VyY2VzIjpbIi4uL3NyYy9zY2hlbWEuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogaXN0YW5idWwgaWdub3JlIGZpbGUgKi9cbmV4cG9ydCB7IGRlZmF1bHQgYXMgVW5pb24gfSBmcm9tICcuL3NjaGVtYXMvVW5pb24uanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBWYWx1ZXMgfSBmcm9tICcuL3NjaGVtYXMvVmFsdWVzLmpzJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgQXJyYXkgfSBmcm9tICcuL3NjaGVtYXMvQXJyYXkuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBBbGwgfSBmcm9tICcuL3NjaGVtYXMvQWxsLmpzJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgT2JqZWN0IH0gZnJvbSAnLi9zY2hlbWFzL09iamVjdC5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIERlbGV0ZSB9IGZyb20gJy4vc2NoZW1hcy9EZWxldGUuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBFbnRpdHkgfSBmcm9tICcuL3NjaGVtYXMvRW50aXR5U2NoZW1hLmpzJztcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQSxTQUFTQSxPQUFPLElBQUlDLEtBQUssUUFBUSxvQkFBb0I7QUFDckQsU0FBU0QsT0FBTyxJQUFJRSxNQUFNLFFBQVEscUJBQXFCO0FBQ3ZELFNBQVNGLE9BQU8sSUFBSUcsS0FBSyxRQUFRLG9CQUFvQjtBQUNyRCxTQUFTSCxPQUFPLElBQUlJLEdBQUcsUUFBUSxrQkFBa0I7QUFDakQsU0FBU0osT0FBTyxJQUFJSyxNQUFNLFFBQVEscUJBQXFCO0FBQ3ZELFNBQVNMLE9BQU8sSUFBSU0sTUFBTSxRQUFRLHFCQUFxQjtBQUN2RCxTQUFTTixPQUFPLElBQUlPLE1BQU0sUUFBUSwyQkFBMkIifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkZWZhdWx0IiwiVW5pb24iLCJWYWx1ZXMiLCJBcnJheSIsIkFsbCIsIk9iamVjdCIsIkRlbGV0ZSIsIkludmFsaWRhdGUiLCJDb2xsZWN0aW9uIiwiRW50aXR5Il0sInNvdXJjZXMiOlsiLi4vc3JjL3NjaGVtYS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBpc3RhbmJ1bCBpZ25vcmUgZmlsZSAqL1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBVbmlvbiB9IGZyb20gJy4vc2NoZW1hcy9Vbmlvbi5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIFZhbHVlcyB9IGZyb20gJy4vc2NoZW1hcy9WYWx1ZXMuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBBcnJheSB9IGZyb20gJy4vc2NoZW1hcy9BcnJheS5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEFsbCB9IGZyb20gJy4vc2NoZW1hcy9BbGwuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBPYmplY3QgfSBmcm9tICcuL3NjaGVtYXMvT2JqZWN0LmpzJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRGVsZXRlIH0gZnJvbSAnLi9zY2hlbWFzL0RlbGV0ZS5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEludmFsaWRhdGUgfSBmcm9tICcuL3NjaGVtYXMvSW52YWxpZGF0ZS5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIENvbGxlY3Rpb24gfSBmcm9tICcuL3NjaGVtYXMvQ29sbGVjdGlvbi5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEVudGl0eSB9IGZyb20gJy4vc2NoZW1hcy9FbnRpdHlTY2hlbWEuanMnO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBLFNBQVNBLE9BQU8sSUFBSUMsS0FBSyxRQUFRLG9CQUFvQjtBQUNyRCxTQUFTRCxPQUFPLElBQUlFLE1BQU0sUUFBUSxxQkFBcUI7QUFDdkQsU0FBU0YsT0FBTyxJQUFJRyxLQUFLLFFBQVEsb0JBQW9CO0FBQ3JELFNBQVNILE9BQU8sSUFBSUksR0FBRyxRQUFRLGtCQUFrQjtBQUNqRCxTQUFTSixPQUFPLElBQUlLLE1BQU0sUUFBUSxxQkFBcUI7QUFDdkQsU0FBU0wsT0FBTyxJQUFJTSxNQUFNLFFBQVEscUJBQXFCO0FBQ3ZELFNBQVNOLE9BQU8sSUFBSU8sVUFBVSxRQUFRLHlCQUF5QjtBQUMvRCxTQUFTUCxPQUFPLElBQUlRLFVBQVUsUUFBUSx5QkFBeUI7QUFDL0QsU0FBU1IsT0FBTyxJQUFJUyxNQUFNLFFBQVEsMkJBQTJCIn0= |
@@ -11,5 +11,5 @@ import ArraySchema from './Array.js'; | ||
} | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
// we return undefined | ||
super.normalize(input, parent, key, visit, addEntity, visitedEntities); | ||
super.normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args); | ||
} | ||
@@ -36,2 +36,2 @@ infer(args, indexes, recurse, entities) { | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJBcnJheVNjaGVtYSIsIkFsbFNjaGVtYSIsImNvbnN0cnVjdG9yIiwiZGVmaW5pdGlvbiIsInNjaGVtYUF0dHJpYnV0ZSIsIm5vcm1hbGl6ZSIsImlucHV0IiwicGFyZW50Iiwia2V5IiwidmlzaXQiLCJhZGRFbnRpdHkiLCJ2aXNpdGVkRW50aXRpZXMiLCJpbmZlciIsImFyZ3MiLCJpbmRleGVzIiwicmVjdXJzZSIsImVudGl0aWVzIiwiaXNTaW5nbGVTY2hlbWEiLCJlbnRpdGllc0VudHJ5Iiwic2NoZW1hIiwidW5kZWZpbmVkIiwiT2JqZWN0IiwidmFsdWVzIiwibWFwIiwiZW50aXR5IiwicGsiLCJmb3VuZCIsImxpc3QiLCJmbGF0TWFwIiwiaWQiLCJnZXRTY2hlbWFBdHRyaWJ1dGUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9BbGwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFycmF5U2NoZW1hIGZyb20gJy4vQXJyYXkuanMnO1xuaW1wb3J0IHsgRW50aXR5VGFibGUgfSBmcm9tICcuLi9pbnRlcmZhY2UuanMnO1xuaW1wb3J0IHsgRW50aXR5SW50ZXJmYWNlLCBFbnRpdHlNYXAsIFNjaGVtYUZ1bmN0aW9uIH0gZnJvbSAnLi4vc2NoZW1hLmpzJztcblxuLyoqXG4gKiBSZXRyaWV2ZXMgYWxsIGVudGl0aWVzIGluIGNhY2hlXG4gKlxuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9yZXN0L2FwaS9BbGxcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQWxsU2NoZW1hPFxuICBTIGV4dGVuZHMgRW50aXR5TWFwIHwgRW50aXR5SW50ZXJmYWNlID0gRW50aXR5TWFwIHwgRW50aXR5SW50ZXJmYWNlLFxuPiBleHRlbmRzIEFycmF5U2NoZW1hIHtcbiAgY29uc3RydWN0b3IoXG4gICAgZGVmaW5pdGlvbjogUyxcbiAgICBzY2hlbWFBdHRyaWJ1dGU/OiBTIGV4dGVuZHMgRW50aXR5TWFwPGluZmVyIFQ+XG4gICAgICA/IGtleW9mIFQgfCBTY2hlbWFGdW5jdGlvbjxrZXlvZiBTPlxuICAgICAgOiB1bmRlZmluZWQsXG4gICkge1xuICAgIHN1cGVyKGRlZmluaXRpb24sIHNjaGVtYUF0dHJpYnV0ZSBhcyBhbnkpO1xuICB9XG5cbiAgbm9ybWFsaXplKFxuICAgIGlucHV0OiBhbnksXG4gICAgcGFyZW50OiBhbnksXG4gICAga2V5OiBhbnksXG4gICAgdmlzaXQ6IGFueSxcbiAgICBhZGRFbnRpdHk6IGFueSxcbiAgICB2aXNpdGVkRW50aXRpZXM6IGFueSxcbiAgKTogYW55IHtcbiAgICAvLyB3ZSByZXR1cm4gdW5kZWZpbmVkXG4gICAgc3VwZXIubm9ybWFsaXplKGlucHV0LCBwYXJlbnQsIGtleSwgdmlzaXQsIGFkZEVudGl0eSwgdmlzaXRlZEVudGl0aWVzKTtcbiAgfVxuXG4gIGluZmVyKGFyZ3M6IGFueSwgaW5kZXhlczogYW55LCByZWN1cnNlOiBhbnksIGVudGl0aWVzOiBFbnRpdHlUYWJsZSk6IGFueSB7XG4gICAgaWYgKHRoaXMuaXNTaW5nbGVTY2hlbWEpIHtcbiAgICAgIGNvbnN0IGVudGl0aWVzRW50cnkgPSBlbnRpdGllc1t0aGlzLnNjaGVtYS5rZXldO1xuICAgICAgaWYgKGVudGl0aWVzRW50cnkgPT09IHVuZGVmaW5lZCkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKGVudGl0aWVzRW50cnkpLm1hcChcbiAgICAgICAgZW50aXR5ID0+IGVudGl0eSAmJiB0aGlzLnNjaGVtYS5wayhlbnRpdHkpLFxuICAgICAgKTtcbiAgICB9XG4gICAgbGV0IGZvdW5kID0gZmFsc2U7XG4gICAgY29uc3QgbGlzdCA9IE9iamVjdC52YWx1ZXModGhpcy5zY2hlbWEgYXMgUmVjb3JkPHN0cmluZywgYW55PikuZmxhdE1hcChcbiAgICAgIChzY2hlbWE6IEVudGl0eUludGVyZmFjZSkgPT4ge1xuICAgICAgICBpZiAoIWVudGl0aWVzW3NjaGVtYS5rZXldKSByZXR1cm4gW107XG4gICAgICAgIGZvdW5kID0gdHJ1ZTtcbiAgICAgICAgcmV0dXJuIE9iamVjdC52YWx1ZXMoZW50aXRpZXNbc2NoZW1hLmtleV0gYXMgUmVjb3JkPHN0cmluZywgYW55PikubWFwKFxuICAgICAgICAgIGVudGl0eSA9PiAoe1xuICAgICAgICAgICAgaWQ6IGVudGl0eSAmJiBzY2hlbWEucGsoZW50aXR5KSxcbiAgICAgICAgICAgIHNjaGVtYTogdGhpcy5nZXRTY2hlbWFBdHRyaWJ1dGUoZW50aXR5LCB1bmRlZmluZWQsIHVuZGVmaW5lZCksXG4gICAgICAgICAgfSksXG4gICAgICAgICk7XG4gICAgICB9LFxuICAgICk7XG4gICAgLy8gaWYgbm8gdGFibGUgZW50cmllcyBleGlzdCB3ZSBzaG91bGRuJ3QgZ3JhYiBhbnl0aGluZ1xuICAgIGlmICghZm91bmQpIHJldHVybjtcbiAgICByZXR1cm4gbGlzdDtcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxXQUFXLE1BQU0sWUFBWTtBQUlwQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNQyxTQUFTLFNBRXBCRCxXQUFXLENBQUM7RUFDcEJFLFdBQVdBLENBQ1RDLFVBQWEsRUFDYkMsZUFFYSxFQUNiO0lBQ0EsS0FBSyxDQUFDRCxVQUFVLEVBQUVDLGVBQWUsQ0FBUTtFQUMzQztFQUVBQyxTQUFTQSxDQUNQQyxLQUFVLEVBQ1ZDLE1BQVcsRUFDWEMsR0FBUSxFQUNSQyxLQUFVLEVBQ1ZDLFNBQWMsRUFDZEMsZUFBb0IsRUFDZjtJQUNMO0lBQ0EsS0FBSyxDQUFDTixTQUFTLENBQUNDLEtBQUssRUFBRUMsTUFBTSxFQUFFQyxHQUFHLEVBQUVDLEtBQUssRUFBRUMsU0FBUyxFQUFFQyxlQUFlLENBQUM7RUFDeEU7RUFFQUMsS0FBS0EsQ0FBQ0MsSUFBUyxFQUFFQyxPQUFZLEVBQUVDLE9BQVksRUFBRUMsUUFBcUIsRUFBTztJQUN2RSxJQUFJLElBQUksQ0FBQ0MsY0FBYyxFQUFFO01BQ3ZCLE1BQU1DLGFBQWEsR0FBR0YsUUFBUSxDQUFDLElBQUksQ0FBQ0csTUFBTSxDQUFDWCxHQUFHLENBQUM7TUFDL0MsSUFBSVUsYUFBYSxLQUFLRSxTQUFTLEVBQUUsT0FBT0EsU0FBUztNQUNqRCxPQUFPQyxNQUFNLENBQUNDLE1BQU0sQ0FBQ0osYUFBYSxDQUFDLENBQUNLLEdBQUcsQ0FDckNDLE1BQU0sSUFBSUEsTUFBTSxJQUFJLElBQUksQ0FBQ0wsTUFBTSxDQUFDTSxFQUFFLENBQUNELE1BQU0sQ0FBQyxDQUMzQztJQUNIO0lBQ0EsSUFBSUUsS0FBSyxHQUFHLEtBQUs7SUFDakIsTUFBTUMsSUFBSSxHQUFHTixNQUFNLENBQUNDLE1BQU0sQ0FBQyxJQUFJLENBQUNILE1BQU0sQ0FBd0IsQ0FBQ1MsT0FBTyxDQUNuRVQsTUFBdUIsSUFBSztNQUMzQixJQUFJLENBQUNILFFBQVEsQ0FBQ0csTUFBTSxDQUFDWCxHQUFHLENBQUMsRUFBRSxPQUFPLEVBQUU7TUFDcENrQixLQUFLLEdBQUcsSUFBSTtNQUNaLE9BQU9MLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDTixRQUFRLENBQUNHLE1BQU0sQ0FBQ1gsR0FBRyxDQUFDLENBQXdCLENBQUNlLEdBQUcsQ0FDbkVDLE1BQU0sS0FBSztRQUNUSyxFQUFFLEVBQUVMLE1BQU0sSUFBSUwsTUFBTSxDQUFDTSxFQUFFLENBQUNELE1BQU0sQ0FBQztRQUMvQkwsTUFBTSxFQUFFLElBQUksQ0FBQ1csa0JBQWtCLENBQUNOLE1BQU0sRUFBRUosU0FBUyxFQUFFQSxTQUFTO01BQzlELENBQUMsQ0FBQyxDQUNIO0lBQ0gsQ0FBQyxDQUNGO0lBQ0Q7SUFDQSxJQUFJLENBQUNNLEtBQUssRUFBRTtJQUNaLE9BQU9DLElBQUk7RUFDYjtBQUNGIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJBcnJheVNjaGVtYSIsIkFsbFNjaGVtYSIsImNvbnN0cnVjdG9yIiwiZGVmaW5pdGlvbiIsInNjaGVtYUF0dHJpYnV0ZSIsIm5vcm1hbGl6ZSIsImlucHV0IiwicGFyZW50Iiwia2V5IiwidmlzaXQiLCJhZGRFbnRpdHkiLCJ2aXNpdGVkRW50aXRpZXMiLCJzdG9yZUVudGl0aWVzIiwiYXJncyIsImluZmVyIiwiaW5kZXhlcyIsInJlY3Vyc2UiLCJlbnRpdGllcyIsImlzU2luZ2xlU2NoZW1hIiwiZW50aXRpZXNFbnRyeSIsInNjaGVtYSIsInVuZGVmaW5lZCIsIk9iamVjdCIsInZhbHVlcyIsIm1hcCIsImVudGl0eSIsInBrIiwiZm91bmQiLCJsaXN0IiwiZmxhdE1hcCIsImlkIiwiZ2V0U2NoZW1hQXR0cmlidXRlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvQWxsLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBBcnJheVNjaGVtYSBmcm9tICcuL0FycmF5LmpzJztcbmltcG9ydCB7IEVudGl0eVRhYmxlIH0gZnJvbSAnLi4vaW50ZXJmYWNlLmpzJztcbmltcG9ydCB7IEVudGl0eUludGVyZmFjZSwgRW50aXR5TWFwLCBTY2hlbWFGdW5jdGlvbiB9IGZyb20gJy4uL3NjaGVtYS5qcyc7XG5cbi8qKlxuICogUmV0cmlldmVzIGFsbCBlbnRpdGllcyBpbiBjYWNoZVxuICpcbiAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vcmVzdC9hcGkvQWxsXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEFsbFNjaGVtYTxcbiAgUyBleHRlbmRzIEVudGl0eU1hcCB8IEVudGl0eUludGVyZmFjZSA9IEVudGl0eU1hcCB8IEVudGl0eUludGVyZmFjZSxcbj4gZXh0ZW5kcyBBcnJheVNjaGVtYSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIGRlZmluaXRpb246IFMsXG4gICAgc2NoZW1hQXR0cmlidXRlPzogUyBleHRlbmRzIEVudGl0eU1hcDxpbmZlciBUPlxuICAgICAgPyBrZXlvZiBUIHwgU2NoZW1hRnVuY3Rpb248a2V5b2YgUz5cbiAgICAgIDogdW5kZWZpbmVkLFxuICApIHtcbiAgICBzdXBlcihkZWZpbml0aW9uLCBzY2hlbWFBdHRyaWJ1dGUgYXMgYW55KTtcbiAgfVxuXG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiBhbnksXG4gICAgYWRkRW50aXR5OiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBhbnksXG4gICAgc3RvcmVFbnRpdGllczogYW55LFxuICAgIGFyZ3M/OiBhbnlbXSxcbiAgKTogYW55IHtcbiAgICAvLyB3ZSByZXR1cm4gdW5kZWZpbmVkXG4gICAgc3VwZXIubm9ybWFsaXplKFxuICAgICAgaW5wdXQsXG4gICAgICBwYXJlbnQsXG4gICAgICBrZXksXG4gICAgICB2aXNpdCxcbiAgICAgIGFkZEVudGl0eSxcbiAgICAgIHZpc2l0ZWRFbnRpdGllcyxcbiAgICAgIHN0b3JlRW50aXRpZXMsXG4gICAgICBhcmdzLFxuICAgICk7XG4gIH1cblxuICBpbmZlcihhcmdzOiBhbnksIGluZGV4ZXM6IGFueSwgcmVjdXJzZTogYW55LCBlbnRpdGllczogRW50aXR5VGFibGUpOiBhbnkge1xuICAgIGlmICh0aGlzLmlzU2luZ2xlU2NoZW1hKSB7XG4gICAgICBjb25zdCBlbnRpdGllc0VudHJ5ID0gZW50aXRpZXNbdGhpcy5zY2hlbWEua2V5XTtcbiAgICAgIGlmIChlbnRpdGllc0VudHJ5ID09PSB1bmRlZmluZWQpIHJldHVybiB1bmRlZmluZWQ7XG4gICAgICByZXR1cm4gT2JqZWN0LnZhbHVlcyhlbnRpdGllc0VudHJ5KS5tYXAoXG4gICAgICAgIGVudGl0eSA9PiBlbnRpdHkgJiYgdGhpcy5zY2hlbWEucGsoZW50aXR5KSxcbiAgICAgICk7XG4gICAgfVxuICAgIGxldCBmb3VuZCA9IGZhbHNlO1xuICAgIGNvbnN0IGxpc3QgPSBPYmplY3QudmFsdWVzKHRoaXMuc2NoZW1hIGFzIFJlY29yZDxzdHJpbmcsIGFueT4pLmZsYXRNYXAoXG4gICAgICAoc2NoZW1hOiBFbnRpdHlJbnRlcmZhY2UpID0+IHtcbiAgICAgICAgaWYgKCFlbnRpdGllc1tzY2hlbWEua2V5XSkgcmV0dXJuIFtdO1xuICAgICAgICBmb3VuZCA9IHRydWU7XG4gICAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKGVudGl0aWVzW3NjaGVtYS5rZXldIGFzIFJlY29yZDxzdHJpbmcsIGFueT4pLm1hcChcbiAgICAgICAgICBlbnRpdHkgPT4gKHtcbiAgICAgICAgICAgIGlkOiBlbnRpdHkgJiYgc2NoZW1hLnBrKGVudGl0eSksXG4gICAgICAgICAgICBzY2hlbWE6IHRoaXMuZ2V0U2NoZW1hQXR0cmlidXRlKGVudGl0eSwgdW5kZWZpbmVkLCB1bmRlZmluZWQpLFxuICAgICAgICAgIH0pLFxuICAgICAgICApO1xuICAgICAgfSxcbiAgICApO1xuICAgIC8vIGlmIG5vIHRhYmxlIGVudHJpZXMgZXhpc3Qgd2Ugc2hvdWxkbid0IGdyYWIgYW55dGhpbmdcbiAgICBpZiAoIWZvdW5kKSByZXR1cm47XG4gICAgcmV0dXJuIGxpc3Q7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsV0FBVyxNQUFNLFlBQVk7QUFJcEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsTUFBTUMsU0FBUyxTQUVwQkQsV0FBVyxDQUFDO0VBQ3BCRSxXQUFXQSxDQUNUQyxVQUFhLEVBQ2JDLGVBRWEsRUFDYjtJQUNBLEtBQUssQ0FBQ0QsVUFBVSxFQUFFQyxlQUFlLENBQVE7RUFDM0M7RUFFQUMsU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEVBQ3BCQyxhQUFrQixFQUNsQkMsSUFBWSxFQUNQO0lBQ0w7SUFDQSxLQUFLLENBQUNSLFNBQVMsQ0FDYkMsS0FBSyxFQUNMQyxNQUFNLEVBQ05DLEdBQUcsRUFDSEMsS0FBSyxFQUNMQyxTQUFTLEVBQ1RDLGVBQWUsRUFDZkMsYUFBYSxFQUNiQyxJQUFJLENBQ0w7RUFDSDtFQUVBQyxLQUFLQSxDQUFDRCxJQUFTLEVBQUVFLE9BQVksRUFBRUMsT0FBWSxFQUFFQyxRQUFxQixFQUFPO0lBQ3ZFLElBQUksSUFBSSxDQUFDQyxjQUFjLEVBQUU7TUFDdkIsTUFBTUMsYUFBYSxHQUFHRixRQUFRLENBQUMsSUFBSSxDQUFDRyxNQUFNLENBQUNaLEdBQUcsQ0FBQztNQUMvQyxJQUFJVyxhQUFhLEtBQUtFLFNBQVMsRUFBRSxPQUFPQSxTQUFTO01BQ2pELE9BQU9DLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDSixhQUFhLENBQUMsQ0FBQ0ssR0FBRyxDQUNyQ0MsTUFBTSxJQUFJQSxNQUFNLElBQUksSUFBSSxDQUFDTCxNQUFNLENBQUNNLEVBQUUsQ0FBQ0QsTUFBTSxDQUFDLENBQzNDO0lBQ0g7SUFDQSxJQUFJRSxLQUFLLEdBQUcsS0FBSztJQUNqQixNQUFNQyxJQUFJLEdBQUdOLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDLElBQUksQ0FBQ0gsTUFBTSxDQUF3QixDQUFDUyxPQUFPLENBQ25FVCxNQUF1QixJQUFLO01BQzNCLElBQUksQ0FBQ0gsUUFBUSxDQUFDRyxNQUFNLENBQUNaLEdBQUcsQ0FBQyxFQUFFLE9BQU8sRUFBRTtNQUNwQ21CLEtBQUssR0FBRyxJQUFJO01BQ1osT0FBT0wsTUFBTSxDQUFDQyxNQUFNLENBQUNOLFFBQVEsQ0FBQ0csTUFBTSxDQUFDWixHQUFHLENBQUMsQ0FBd0IsQ0FBQ2dCLEdBQUcsQ0FDbkVDLE1BQU0sS0FBSztRQUNUSyxFQUFFLEVBQUVMLE1BQU0sSUFBSUwsTUFBTSxDQUFDTSxFQUFFLENBQUNELE1BQU0sQ0FBQztRQUMvQkwsTUFBTSxFQUFFLElBQUksQ0FBQ1csa0JBQWtCLENBQUNOLE1BQU0sRUFBRUosU0FBUyxFQUFFQSxTQUFTO01BQzlELENBQUMsQ0FBQyxDQUNIO0lBQ0gsQ0FBQyxDQUNGO0lBQ0Q7SUFDQSxJQUFJLENBQUNNLEtBQUssRUFBRTtJQUNaLE9BQU9DLElBQUk7RUFDYjtBQUNGIn0= |
@@ -9,9 +9,12 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ArraySchema extends PolymorphicSchema { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
const values = getValues(input); | ||
return values.map((value, index) => this.normalizeValue(value, parent, key, visit, addEntity, visitedEntities)).filter(value => value !== undefined && value !== null); | ||
return values.map((value, index) => this.normalizeValue(value, parent, key, visit, addEntity, visitedEntities, storeEntities, args)).filter(value => value !== undefined && value !== null); | ||
} | ||
denormalize(input, unvisit) { | ||
return [input.map ? input.map(entityOrId => this.denormalizeValue(entityOrId, unvisit)).filter(filterEmpty).map(([value]) => value) : input, true, false]; | ||
return [this.denormalizeOnly(input, [], unvisit), true, false]; | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return input.map ? input.map(entityOrId => this.denormalizeValue(entityOrId, unvisit)).filter(filterEmpty) : input; | ||
} | ||
infer(args, indexes, recurse, entities) { | ||
@@ -24,2 +27,2 @@ return undefined; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsImZpbHRlckVtcHR5IiwiZ2V0VmFsdWVzIiwiQXJyYXlTY2hlbWEiLCJub3JtYWxpemUiLCJpbnB1dCIsInBhcmVudCIsImtleSIsInZpc2l0IiwiYWRkRW50aXR5IiwidmlzaXRlZEVudGl0aWVzIiwidmFsdWVzIiwibWFwIiwidmFsdWUiLCJpbmRleCIsIm5vcm1hbGl6ZVZhbHVlIiwiZmlsdGVyIiwidW5kZWZpbmVkIiwiZGVub3JtYWxpemUiLCJ1bnZpc2l0IiwiZW50aXR5T3JJZCIsImRlbm9ybWFsaXplVmFsdWUiLCJpbmZlciIsImFyZ3MiLCJpbmRleGVzIiwicmVjdXJzZSIsImVudGl0aWVzIiwidG9KU09OIiwic2NoZW1hIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvQXJyYXkudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFBvbHltb3JwaGljU2NoZW1hIGZyb20gJy4vUG9seW1vcnBoaWMuanMnO1xuaW1wb3J0IHsgZmlsdGVyRW1wdHksIGdldFZhbHVlcyB9IGZyb20gJy4vdXRpbHMuanMnO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYXJyYXlzXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL3Jlc3QvYXBpL0FycmF5XG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEFycmF5U2NoZW1hIGV4dGVuZHMgUG9seW1vcnBoaWNTY2hlbWEge1xuICBub3JtYWxpemUoXG4gICAgaW5wdXQ6IGFueSxcbiAgICBwYXJlbnQ6IGFueSxcbiAgICBrZXk6IGFueSxcbiAgICB2aXNpdDogYW55LFxuICAgIGFkZEVudGl0eTogYW55LFxuICAgIHZpc2l0ZWRFbnRpdGllczogYW55LFxuICApOiBhbnkge1xuICAgIGNvbnN0IHZhbHVlcyA9IGdldFZhbHVlcyhpbnB1dCk7XG5cbiAgICByZXR1cm4gdmFsdWVzXG4gICAgICAubWFwKCh2YWx1ZSwgaW5kZXgpID0+XG4gICAgICAgIHRoaXMubm9ybWFsaXplVmFsdWUoXG4gICAgICAgICAgdmFsdWUsXG4gICAgICAgICAgcGFyZW50LFxuICAgICAgICAgIGtleSxcbiAgICAgICAgICB2aXNpdCxcbiAgICAgICAgICBhZGRFbnRpdHksXG4gICAgICAgICAgdmlzaXRlZEVudGl0aWVzLFxuICAgICAgICApLFxuICAgICAgKVxuICAgICAgLmZpbHRlcih2YWx1ZSA9PiB2YWx1ZSAhPT0gdW5kZWZpbmVkICYmIHZhbHVlICE9PSBudWxsKTtcbiAgfVxuXG4gIGRlbm9ybWFsaXplKFxuICAgIGlucHV0OiBhbnksXG4gICAgdW52aXNpdDogYW55LFxuICApOiBbZGVub3JtYWxpemVkOiBhbnksIGZvdW5kOiBib29sZWFuLCBkZWxldGVkOiBib29sZWFuXSB7XG4gICAgcmV0dXJuIFtcbiAgICAgIGlucHV0Lm1hcFxuICAgICAgICA/IGlucHV0XG4gICAgICAgICAgICAubWFwKChlbnRpdHlPcklkOiBhbnkpID0+XG4gICAgICAgICAgICAgIHRoaXMuZGVub3JtYWxpemVWYWx1ZShlbnRpdHlPcklkLCB1bnZpc2l0KSxcbiAgICAgICAgICAgIClcbiAgICAgICAgICAgIC5maWx0ZXIoZmlsdGVyRW1wdHkpXG4gICAgICAgICAgICAubWFwKChbdmFsdWVdOiBhbnkpID0+IHZhbHVlKVxuICAgICAgICA6IGlucHV0LFxuICAgICAgdHJ1ZSxcbiAgICAgIGZhbHNlLFxuICAgIF07XG4gIH1cblxuICBpbmZlcihcbiAgICBhcmdzOiB1bmtub3duLFxuICAgIGluZGV4ZXM6IHVua25vd24sXG4gICAgcmVjdXJzZTogdW5rbm93bixcbiAgICBlbnRpdGllczogdW5rbm93bixcbiAgKTogYW55IHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgdG9KU09OKCkge1xuICAgIHJldHVybiBbdGhpcy5zY2hlbWFdO1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLGlCQUFpQixNQUFNLGtCQUFrQjtBQUNoRCxTQUFTQyxXQUFXLEVBQUVDLFNBQVMsUUFBUSxZQUFZOztBQUVuRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsTUFBTUMsV0FBVyxTQUFTSCxpQkFBaUIsQ0FBQztFQUN6REksU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEVBQ2Y7SUFDTCxNQUFNQyxNQUFNLEdBQUdULFNBQVMsQ0FBQ0csS0FBSyxDQUFDO0lBRS9CLE9BQU9NLE1BQU0sQ0FDVkMsR0FBRyxDQUFDLENBQUNDLEtBQUssRUFBRUMsS0FBSyxLQUNoQixJQUFJLENBQUNDLGNBQWMsQ0FDakJGLEtBQUssRUFDTFAsTUFBTSxFQUNOQyxHQUFHLEVBQ0hDLEtBQUssRUFDTEMsU0FBUyxFQUNUQyxlQUFlLENBQ2hCLENBQ0YsQ0FDQU0sTUFBTSxDQUFDSCxLQUFLLElBQUlBLEtBQUssS0FBS0ksU0FBUyxJQUFJSixLQUFLLEtBQUssSUFBSSxDQUFDO0VBQzNEO0VBRUFLLFdBQVdBLENBQ1RiLEtBQVUsRUFDVmMsT0FBWSxFQUMyQztJQUN2RCxPQUFPLENBQ0xkLEtBQUssQ0FBQ08sR0FBRyxHQUNMUCxLQUFLLENBQ0ZPLEdBQUcsQ0FBRVEsVUFBZSxJQUNuQixJQUFJLENBQUNDLGdCQUFnQixDQUFDRCxVQUFVLEVBQUVELE9BQU8sQ0FBQyxDQUMzQyxDQUNBSCxNQUFNLENBQUNmLFdBQVcsQ0FBQyxDQUNuQlcsR0FBRyxDQUFDLENBQUMsQ0FBQ0MsS0FBSyxDQUFNLEtBQUtBLEtBQUssQ0FBQyxHQUMvQlIsS0FBSyxFQUNULElBQUksRUFDSixLQUFLLENBQ047RUFDSDtFQUVBaUIsS0FBS0EsQ0FDSEMsSUFBYSxFQUNiQyxPQUFnQixFQUNoQkMsT0FBZ0IsRUFDaEJDLFFBQWlCLEVBQ1o7SUFDTCxPQUFPVCxTQUFTO0VBQ2xCO0VBRUFVLE1BQU1BLENBQUEsRUFBRztJQUNQLE9BQU8sQ0FBQyxJQUFJLENBQUNDLE1BQU0sQ0FBQztFQUN0QjtBQUNGIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsImZpbHRlckVtcHR5IiwiZ2V0VmFsdWVzIiwiQXJyYXlTY2hlbWEiLCJub3JtYWxpemUiLCJpbnB1dCIsInBhcmVudCIsImtleSIsInZpc2l0IiwiYWRkRW50aXR5IiwidmlzaXRlZEVudGl0aWVzIiwic3RvcmVFbnRpdGllcyIsImFyZ3MiLCJ2YWx1ZXMiLCJtYXAiLCJ2YWx1ZSIsImluZGV4Iiwibm9ybWFsaXplVmFsdWUiLCJmaWx0ZXIiLCJ1bmRlZmluZWQiLCJkZW5vcm1hbGl6ZSIsInVudmlzaXQiLCJkZW5vcm1hbGl6ZU9ubHkiLCJlbnRpdHlPcklkIiwiZGVub3JtYWxpemVWYWx1ZSIsImluZmVyIiwiaW5kZXhlcyIsInJlY3Vyc2UiLCJlbnRpdGllcyIsInRvSlNPTiIsInNjaGVtYSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWFzL0FycmF5LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQb2x5bW9ycGhpY1NjaGVtYSBmcm9tICcuL1BvbHltb3JwaGljLmpzJztcbmltcG9ydCB7IGZpbHRlckVtcHR5LCBnZXRWYWx1ZXMgfSBmcm9tICcuL3V0aWxzLmpzJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIGFycmF5c1xuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9yZXN0L2FwaS9BcnJheVxuICovXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBBcnJheVNjaGVtYSBleHRlbmRzIFBvbHltb3JwaGljU2NoZW1hIHtcbiAgbm9ybWFsaXplKFxuICAgIGlucHV0OiBhbnksXG4gICAgcGFyZW50OiBhbnksXG4gICAga2V5OiBhbnksXG4gICAgdmlzaXQ6IGFueSxcbiAgICBhZGRFbnRpdHk6IGFueSxcbiAgICB2aXNpdGVkRW50aXRpZXM6IGFueSxcbiAgICBzdG9yZUVudGl0aWVzOiBhbnksXG4gICAgYXJncz86IGFueVtdLFxuICApOiBhbnkge1xuICAgIGNvbnN0IHZhbHVlcyA9IGdldFZhbHVlcyhpbnB1dCk7XG5cbiAgICByZXR1cm4gdmFsdWVzXG4gICAgICAubWFwKCh2YWx1ZSwgaW5kZXgpID0+XG4gICAgICAgIHRoaXMubm9ybWFsaXplVmFsdWUoXG4gICAgICAgICAgdmFsdWUsXG4gICAgICAgICAgcGFyZW50LFxuICAgICAgICAgIGtleSxcbiAgICAgICAgICB2aXNpdCxcbiAgICAgICAgICBhZGRFbnRpdHksXG4gICAgICAgICAgdmlzaXRlZEVudGl0aWVzLFxuICAgICAgICAgIHN0b3JlRW50aXRpZXMsXG4gICAgICAgICAgYXJncyxcbiAgICAgICAgKSxcbiAgICAgIClcbiAgICAgIC5maWx0ZXIodmFsdWUgPT4gdmFsdWUgIT09IHVuZGVmaW5lZCAmJiB2YWx1ZSAhPT0gbnVsbCk7XG4gIH1cblxuICBkZW5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHVudmlzaXQ6IGFueSxcbiAgKTogW2Rlbm9ybWFsaXplZDogYW55LCBmb3VuZDogYm9vbGVhbiwgZGVsZXRlZDogYm9vbGVhbl0ge1xuICAgIHJldHVybiBbdGhpcy5kZW5vcm1hbGl6ZU9ubHkoaW5wdXQsIFtdLCB1bnZpc2l0KSwgdHJ1ZSwgZmFsc2VdO1xuICB9XG5cbiAgZGVub3JtYWxpemVPbmx5KFxuICAgIGlucHV0OiBhbnksXG4gICAgYXJnczogYW55W10sXG4gICAgdW52aXNpdDogKGlucHV0OiBhbnksIHNjaGVtYTogYW55KSA9PiBhbnksXG4gICkge1xuICAgIHJldHVybiBpbnB1dC5tYXBcbiAgICAgID8gaW5wdXRcbiAgICAgICAgICAubWFwKChlbnRpdHlPcklkOiBhbnkpID0+IHRoaXMuZGVub3JtYWxpemVWYWx1ZShlbnRpdHlPcklkLCB1bnZpc2l0KSlcbiAgICAgICAgICAuZmlsdGVyKGZpbHRlckVtcHR5KVxuICAgICAgOiBpbnB1dDtcbiAgfVxuXG4gIGluZmVyKFxuICAgIGFyZ3M6IHVua25vd24sXG4gICAgaW5kZXhlczogdW5rbm93bixcbiAgICByZWN1cnNlOiB1bmtub3duLFxuICAgIGVudGl0aWVzOiB1bmtub3duLFxuICApOiBhbnkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICB0b0pTT04oKSB7XG4gICAgcmV0dXJuIFt0aGlzLnNjaGVtYV07XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsaUJBQWlCLE1BQU0sa0JBQWtCO0FBQ2hELFNBQVNDLFdBQVcsRUFBRUMsU0FBUyxRQUFRLFlBQVk7O0FBRW5EO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNQyxXQUFXLFNBQVNILGlCQUFpQixDQUFDO0VBQ3pESSxTQUFTQSxDQUNQQyxLQUFVLEVBQ1ZDLE1BQVcsRUFDWEMsR0FBUSxFQUNSQyxLQUFVLEVBQ1ZDLFNBQWMsRUFDZEMsZUFBb0IsRUFDcEJDLGFBQWtCLEVBQ2xCQyxJQUFZLEVBQ1A7SUFDTCxNQUFNQyxNQUFNLEdBQUdYLFNBQVMsQ0FBQ0csS0FBSyxDQUFDO0lBRS9CLE9BQU9RLE1BQU0sQ0FDVkMsR0FBRyxDQUFDLENBQUNDLEtBQUssRUFBRUMsS0FBSyxLQUNoQixJQUFJLENBQUNDLGNBQWMsQ0FDakJGLEtBQUssRUFDTFQsTUFBTSxFQUNOQyxHQUFHLEVBQ0hDLEtBQUssRUFDTEMsU0FBUyxFQUNUQyxlQUFlLEVBQ2ZDLGFBQWEsRUFDYkMsSUFBSSxDQUNMLENBQ0YsQ0FDQU0sTUFBTSxDQUFDSCxLQUFLLElBQUlBLEtBQUssS0FBS0ksU0FBUyxJQUFJSixLQUFLLEtBQUssSUFBSSxDQUFDO0VBQzNEO0VBRUFLLFdBQVdBLENBQ1RmLEtBQVUsRUFDVmdCLE9BQVksRUFDMkM7SUFDdkQsT0FBTyxDQUFDLElBQUksQ0FBQ0MsZUFBZSxDQUFDakIsS0FBSyxFQUFFLEVBQUUsRUFBRWdCLE9BQU8sQ0FBQyxFQUFFLElBQUksRUFBRSxLQUFLLENBQUM7RUFDaEU7RUFFQUMsZUFBZUEsQ0FDYmpCLEtBQVUsRUFDVk8sSUFBVyxFQUNYUyxPQUF5QyxFQUN6QztJQUNBLE9BQU9oQixLQUFLLENBQUNTLEdBQUcsR0FDWlQsS0FBSyxDQUNGUyxHQUFHLENBQUVTLFVBQWUsSUFBSyxJQUFJLENBQUNDLGdCQUFnQixDQUFDRCxVQUFVLEVBQUVGLE9BQU8sQ0FBQyxDQUFDLENBQ3BFSCxNQUFNLENBQUNqQixXQUFXLENBQUMsR0FDdEJJLEtBQUs7RUFDWDtFQUVBb0IsS0FBS0EsQ0FDSGIsSUFBYSxFQUNiYyxPQUFnQixFQUNoQkMsT0FBZ0IsRUFDaEJDLFFBQWlCLEVBQ1o7SUFDTCxPQUFPVCxTQUFTO0VBQ2xCO0VBRUFVLE1BQU1BLENBQUEsRUFBRztJQUNQLE9BQU8sQ0FBQyxJQUFJLENBQUNDLE1BQU0sQ0FBQztFQUN0QjtBQUNGIn0= |
/* eslint-disable @typescript-eslint/explicit-module-boundary-types */ | ||
import { DELETED } from '../special.js'; | ||
import Invalidate from './Invalidate.js'; | ||
// TODO(breaking): mark deprecated | ||
/** | ||
@@ -9,59 +8,7 @@ * Marks entity as deleted. | ||
*/ | ||
export default class Delete { | ||
constructor(entity) { | ||
if (process.env.NODE_ENV !== 'production' && !entity) { | ||
throw new Error('Expected option "entity" not found on DeleteSchema.'); | ||
} | ||
this._entity = entity; | ||
} | ||
get key() { | ||
return this._entity.key; | ||
} | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
// TODO: what's store needs to be a differing type from fromJS | ||
const processedEntity = this._entity.process(input, parent, key); | ||
const id = this._entity.pk(processedEntity, parent, key); | ||
if (process.env.NODE_ENV !== 'production' && (id === undefined || id === '')) { | ||
var _name; | ||
const error = new Error(`Missing usable primary key when normalizing response. | ||
This is likely due to a malformed response. | ||
Try inspecting the network response or fetch() return value. | ||
Or use debugging tools: https://resthooks.io/docs/guides/debugging | ||
Learn more about schemas: https://resthooks.io/docs/api/schema | ||
Delete(Entity): Delete(${(_name = this._entity.name) != null ? _name : this._entity}) | ||
Value: ${input && JSON.stringify(input, null, 2)} | ||
`); | ||
error.status = 400; | ||
throw error; | ||
} | ||
addEntity(this, DELETED, id); | ||
return id; | ||
} | ||
infer(args, indexes, recurse) { | ||
return undefined; | ||
} | ||
export default class Delete extends Invalidate { | ||
denormalize(id, unvisit) { | ||
return unvisit(id, this._entity); | ||
} | ||
/* istanbul ignore next */ | ||
_denormalizeNullable() { | ||
return []; | ||
} | ||
/* istanbul ignore next */ | ||
_normalizeNullable() { | ||
return []; | ||
} | ||
/* istanbul ignore next */ | ||
merge(existing, incoming) { | ||
return incoming; | ||
} | ||
useIncoming(existingMeta, incomingMeta, existing, incoming) { | ||
return existingMeta.date <= incomingMeta.date; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJERUxFVEVEIiwiRGVsZXRlIiwiY29uc3RydWN0b3IiLCJlbnRpdHkiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJFcnJvciIsIl9lbnRpdHkiLCJrZXkiLCJub3JtYWxpemUiLCJpbnB1dCIsInBhcmVudCIsInZpc2l0IiwiYWRkRW50aXR5IiwidmlzaXRlZEVudGl0aWVzIiwicHJvY2Vzc2VkRW50aXR5IiwiaWQiLCJwayIsInVuZGVmaW5lZCIsIl9uYW1lIiwiZXJyb3IiLCJuYW1lIiwiSlNPTiIsInN0cmluZ2lmeSIsInN0YXR1cyIsImluZmVyIiwiYXJncyIsImluZGV4ZXMiLCJyZWN1cnNlIiwiZGVub3JtYWxpemUiLCJ1bnZpc2l0IiwiX2Rlbm9ybWFsaXplTnVsbGFibGUiLCJfbm9ybWFsaXplTnVsbGFibGUiLCJtZXJnZSIsImV4aXN0aW5nIiwiaW5jb21pbmciLCJ1c2VJbmNvbWluZyIsImV4aXN0aW5nTWV0YSIsImluY29taW5nTWV0YSIsImRhdGUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9EZWxldGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L2V4cGxpY2l0LW1vZHVsZS1ib3VuZGFyeS10eXBlcyAqL1xuaW1wb3J0IHR5cGUgeyBFbnRpdHlJbnRlcmZhY2UgfSBmcm9tICcuLi9pbnRlcmZhY2UuanMnO1xuaW1wb3J0IHR5cGUgeyBBYnN0cmFjdEluc3RhbmNlVHlwZSB9IGZyb20gJy4uL25vcm1hbC5qcyc7XG5pbXBvcnQgeyBTY2hlbWFDbGFzcywgVW52aXNpdEZ1bmN0aW9uIH0gZnJvbSAnLi4vc2NoZW1hLmpzJztcbmltcG9ydCB7IERFTEVURUQgfSBmcm9tICcuLi9zcGVjaWFsLmpzJztcblxuLyoqXG4gKiBNYXJrcyBlbnRpdHkgYXMgZGVsZXRlZC5cbiAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vcmVzdC9hcGkvRGVsZXRlXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIERlbGV0ZTxFIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlICYgeyBwcm9jZXNzOiBhbnkgfT5cbiAgaW1wbGVtZW50cyBTY2hlbWFDbGFzc1xue1xuICBwcml2YXRlIGRlY2xhcmUgX2VudGl0eTogRTtcblxuICBjb25zdHJ1Y3RvcihlbnRpdHk6IEUpIHtcbiAgICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJyAmJiAhZW50aXR5KSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0V4cGVjdGVkIG9wdGlvbiBcImVudGl0eVwiIG5vdCBmb3VuZCBvbiBEZWxldGVTY2hlbWEuJyk7XG4gICAgfVxuICAgIHRoaXMuX2VudGl0eSA9IGVudGl0eTtcbiAgfVxuXG4gIGdldCBrZXkoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2VudGl0eS5rZXk7XG4gIH1cblxuICBub3JtYWxpemUoXG4gICAgaW5wdXQ6IGFueSxcbiAgICBwYXJlbnQ6IGFueSxcbiAgICBrZXk6IHN0cmluZyB8IHVuZGVmaW5lZCxcbiAgICB2aXNpdDogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIGFkZEVudGl0eTogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIHZpc2l0ZWRFbnRpdGllczogUmVjb3JkPHN0cmluZywgYW55PixcbiAgKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICAvLyBUT0RPOiB3aGF0J3Mgc3RvcmUgbmVlZHMgdG8gYmUgYSBkaWZmZXJpbmcgdHlwZSBmcm9tIGZyb21KU1xuICAgIGNvbnN0IHByb2Nlc3NlZEVudGl0eSA9IHRoaXMuX2VudGl0eS5wcm9jZXNzKGlucHV0LCBwYXJlbnQsIGtleSk7XG4gICAgY29uc3QgaWQgPSB0aGlzLl9lbnRpdHkucGsocHJvY2Vzc2VkRW50aXR5LCBwYXJlbnQsIGtleSk7XG5cbiAgICBpZiAoXG4gICAgICBwcm9jZXNzLmVudi5OT0RFX0VOViAhPT0gJ3Byb2R1Y3Rpb24nICYmXG4gICAgICAoaWQgPT09IHVuZGVmaW5lZCB8fCBpZCA9PT0gJycpXG4gICAgKSB7XG4gICAgICBjb25zdCBlcnJvciA9IG5ldyBFcnJvcihcbiAgICAgICAgYE1pc3NpbmcgdXNhYmxlIHByaW1hcnkga2V5IHdoZW4gbm9ybWFsaXppbmcgcmVzcG9uc2UuXG5cbiAgVGhpcyBpcyBsaWtlbHkgZHVlIHRvIGEgbWFsZm9ybWVkIHJlc3BvbnNlLlxuICBUcnkgaW5zcGVjdGluZyB0aGUgbmV0d29yayByZXNwb25zZSBvciBmZXRjaCgpIHJldHVybiB2YWx1ZS5cbiAgT3IgdXNlIGRlYnVnZ2luZyB0b29sczogaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9ndWlkZXMvZGVidWdnaW5nXG4gIExlYXJuIG1vcmUgYWJvdXQgc2NoZW1hczogaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9hcGkvc2NoZW1hXG5cbiAgRGVsZXRlKEVudGl0eSk6IERlbGV0ZSgkeyh0aGlzLl9lbnRpdHkgYXMgYW55KS5uYW1lID8/IHRoaXMuX2VudGl0eX0pXG4gIFZhbHVlOiAke2lucHV0ICYmIEpTT04uc3RyaW5naWZ5KGlucHV0LCBudWxsLCAyKX1cbiAgYCxcbiAgICAgICk7XG4gICAgICAoZXJyb3IgYXMgYW55KS5zdGF0dXMgPSA0MDA7XG4gICAgICB0aHJvdyBlcnJvcjtcbiAgICB9XG4gICAgYWRkRW50aXR5KHRoaXMsIERFTEVURUQsIGlkKTtcbiAgICByZXR1cm4gaWQ7XG4gIH1cblxuICBpbmZlcihhcmdzOiBhbnksIGluZGV4ZXM6IGFueSwgcmVjdXJzZTogYW55KTogYW55IHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgZGVub3JtYWxpemUoXG4gICAgaWQ6IHN0cmluZyxcbiAgICB1bnZpc2l0OiBVbnZpc2l0RnVuY3Rpb24sXG4gICk6IFtkZW5vcm1hbGl6ZWQ6IEFic3RyYWN0SW5zdGFuY2VUeXBlPEU+LCBmb3VuZDogYm9vbGVhbiwgc3VzcGVuZDogYm9vbGVhbl0ge1xuICAgIHJldHVybiB1bnZpc2l0KGlkLCB0aGlzLl9lbnRpdHkpIGFzIGFueTtcbiAgfVxuXG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIF9kZW5vcm1hbGl6ZU51bGxhYmxlKCk6IFtcbiAgICBBYnN0cmFjdEluc3RhbmNlVHlwZTxFPiB8IHVuZGVmaW5lZCxcbiAgICBib29sZWFuLFxuICAgIGZhbHNlLFxuICBdIHtcbiAgICByZXR1cm4gW10gYXMgYW55O1xuICB9XG5cbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgX25vcm1hbGl6ZU51bGxhYmxlKCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIFtdIGFzIGFueTtcbiAgfVxuXG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIG1lcmdlKGV4aXN0aW5nOiBhbnksIGluY29taW5nOiBhbnkpIHtcbiAgICByZXR1cm4gaW5jb21pbmc7XG4gIH1cblxuICB1c2VJbmNvbWluZyhcbiAgICBleGlzdGluZ01ldGE6IHsgZGF0ZTogbnVtYmVyOyBmZXRjaGVkQXQ6IG51bWJlciB9LFxuICAgIGluY29taW5nTWV0YTogeyBkYXRlOiBudW1iZXI7IGZldGNoZWRBdDogbnVtYmVyIH0sXG4gICAgZXhpc3Rpbmc6IGFueSxcbiAgICBpbmNvbWluZzogYW55LFxuICApIHtcbiAgICByZXR1cm4gZXhpc3RpbmdNZXRhLmRhdGUgPD0gaW5jb21pbmdNZXRhLmRhdGU7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBSUEsU0FBU0EsT0FBTyxRQUFRLGVBQWU7O0FBRXZDO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNQyxNQUFNLENBRTNCO0VBR0VDLFdBQVdBLENBQUNDLE1BQVMsRUFBRTtJQUNyQixJQUFJQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLFlBQVksSUFBSSxDQUFDSCxNQUFNLEVBQUU7TUFDcEQsTUFBTSxJQUFJSSxLQUFLLENBQUMscURBQXFELENBQUM7SUFDeEU7SUFDQSxJQUFJLENBQUNDLE9BQU8sR0FBR0wsTUFBTTtFQUN2QjtFQUVBLElBQUlNLEdBQUdBLENBQUEsRUFBRztJQUNSLE9BQU8sSUFBSSxDQUFDRCxPQUFPLENBQUNDLEdBQUc7RUFDekI7RUFFQUMsU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hILEdBQXVCLEVBQ3ZCSSxLQUE0QixFQUM1QkMsU0FBZ0MsRUFDaENDLGVBQW9DLEVBQ2hCO0lBQ3BCO0lBQ0EsTUFBTUMsZUFBZSxHQUFHLElBQUksQ0FBQ1IsT0FBTyxDQUFDSixPQUFPLENBQUNPLEtBQUssRUFBRUMsTUFBTSxFQUFFSCxHQUFHLENBQUM7SUFDaEUsTUFBTVEsRUFBRSxHQUFHLElBQUksQ0FBQ1QsT0FBTyxDQUFDVSxFQUFFLENBQUNGLGVBQWUsRUFBRUosTUFBTSxFQUFFSCxHQUFHLENBQUM7SUFFeEQsSUFDRUwsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxZQUFZLEtBQ3BDVyxFQUFFLEtBQUtFLFNBQVMsSUFBSUYsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUMvQjtNQUFBLElBQUFHLEtBQUE7TUFDQSxNQUFNQyxLQUFLLEdBQUcsSUFBSWQsS0FBSyxDQUNwQjtBQUNUO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJCQUF5QixDQUFBYSxLQUFBLEdBQUcsSUFBSSxDQUFDWixPQUFPLENBQVNjLElBQUksWUFBQUYsS0FBQSxHQUFJLElBQUksQ0FBQ1osT0FBUTtBQUN0RSxXQUFXRyxLQUFLLElBQUlZLElBQUksQ0FBQ0MsU0FBUyxDQUFDYixLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBRTtBQUNuRCxHQUFHLENBQ0k7TUFDQVUsS0FBSyxDQUFTSSxNQUFNLEdBQUcsR0FBRztNQUMzQixNQUFNSixLQUFLO0lBQ2I7SUFDQVAsU0FBUyxDQUFDLElBQUksRUFBRWQsT0FBTyxFQUFFaUIsRUFBRSxDQUFDO0lBQzVCLE9BQU9BLEVBQUU7RUFDWDtFQUVBUyxLQUFLQSxDQUFDQyxJQUFTLEVBQUVDLE9BQVksRUFBRUMsT0FBWSxFQUFPO0lBQ2hELE9BQU9WLFNBQVM7RUFDbEI7RUFFQVcsV0FBV0EsQ0FDVGIsRUFBVSxFQUNWYyxPQUF3QixFQUNtRDtJQUMzRSxPQUFPQSxPQUFPLENBQUNkLEVBQUUsRUFBRSxJQUFJLENBQUNULE9BQU8sQ0FBQztFQUNsQzs7RUFFQTtFQUNBd0Isb0JBQW9CQSxDQUFBLEVBSWxCO0lBQ0EsT0FBTyxFQUFFO0VBQ1g7O0VBRUE7RUFDQUMsa0JBQWtCQSxDQUFBLEVBQXVCO0lBQ3ZDLE9BQU8sRUFBRTtFQUNYOztFQUVBO0VBQ0FDLEtBQUtBLENBQUNDLFFBQWEsRUFBRUMsUUFBYSxFQUFFO0lBQ2xDLE9BQU9BLFFBQVE7RUFDakI7RUFFQUMsV0FBV0EsQ0FDVEMsWUFBaUQsRUFDakRDLFlBQWlELEVBQ2pESixRQUFhLEVBQ2JDLFFBQWEsRUFDYjtJQUNBLE9BQU9FLFlBQVksQ0FBQ0UsSUFBSSxJQUFJRCxZQUFZLENBQUNDLElBQUk7RUFDL0M7QUFDRiJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJJbnZhbGlkYXRlIiwiRGVsZXRlIiwiZGVub3JtYWxpemUiLCJpZCIsInVudmlzaXQiLCJfZW50aXR5Il0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvRGVsZXRlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9leHBsaWNpdC1tb2R1bGUtYm91bmRhcnktdHlwZXMgKi9cbmltcG9ydCBJbnZhbGlkYXRlIGZyb20gJy4vSW52YWxpZGF0ZS5qcyc7XG5pbXBvcnQgdHlwZSB7IEVudGl0eUludGVyZmFjZSB9IGZyb20gJy4uL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IEFic3RyYWN0SW5zdGFuY2VUeXBlIH0gZnJvbSAnLi4vbm9ybWFsLmpzJztcbmltcG9ydCB7IFNjaGVtYUNsYXNzLCBVbnZpc2l0RnVuY3Rpb24gfSBmcm9tICcuLi9zY2hlbWEuanMnO1xuXG4vLyBUT0RPKGJyZWFraW5nKTogbWFyayBkZXByZWNhdGVkXG4vKipcbiAqIE1hcmtzIGVudGl0eSBhcyBkZWxldGVkLlxuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9yZXN0L2FwaS9EZWxldGVcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgRGVsZXRlPFxuICAgIEUgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2UgJiB7XG4gICAgICBwcm9jZXNzOiBhbnk7XG4gICAgfSxcbiAgPlxuICBleHRlbmRzIEludmFsaWRhdGU8RT5cbiAgaW1wbGVtZW50cyBTY2hlbWFDbGFzc1xue1xuICBkZW5vcm1hbGl6ZShcbiAgICBpZDogc3RyaW5nLFxuICAgIHVudmlzaXQ6IFVudmlzaXRGdW5jdGlvbixcbiAgKTogW2Rlbm9ybWFsaXplZDogQWJzdHJhY3RJbnN0YW5jZVR5cGU8RT4sIGZvdW5kOiBib29sZWFuLCBzdXNwZW5kOiBib29sZWFuXSB7XG4gICAgcmV0dXJuIHVudmlzaXQoaWQsIHRoaXMuX2VudGl0eSkgYXMgYW55O1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0EsT0FBT0EsVUFBVSxNQUFNLGlCQUFpQjtBQUt4QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNQyxNQUFNLFNBS2pCRCxVQUFVLENBRXBCO0VBQ0VFLFdBQVdBLENBQ1RDLEVBQVUsRUFDVkMsT0FBd0IsRUFDbUQ7SUFDM0UsT0FBT0EsT0FBTyxDQUFDRCxFQUFFLEVBQUUsSUFBSSxDQUFDRSxPQUFPLENBQUM7RUFDbEM7QUFDRiJ9 |
@@ -19,2 +19,11 @@ /* eslint-disable @typescript-eslint/explicit-module-boundary-types */ | ||
/** Control how automatic schema validation is handled | ||
* | ||
* `undefined`: Defaults - throw error in worst offense | ||
* 'warn': only ever warn | ||
* 'silent': Don't bother with processing at all | ||
* | ||
* Note: this only applies to non-nested members. | ||
*/ | ||
/** Return true to merge incoming data; false keeps existing entity | ||
@@ -44,2 +53,9 @@ * | ||
} | ||
static mergeMetaWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
return { | ||
expiresAt: Math.max(this.expiresAt(incomingMeta, incoming), existingMeta.expiresAt), | ||
date: Math.max(incomingMeta.date, existingMeta.date), | ||
fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt) | ||
}; | ||
} | ||
@@ -51,2 +67,10 @@ /** Factory method to convert from Plain JS Objects. | ||
/** | ||
* A unique identifier for each Entity | ||
* | ||
* @param [value] POJO of the entity or subset used | ||
* @param [parent] When normalizing, the object which included the entity | ||
* @param [key] When normalizing, the key where this entity was found | ||
*/ | ||
/** Do any transformations when first receiving input */ | ||
@@ -201,2 +225,7 @@ static process(input, parent, key) { | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["isImmutable","denormalizeImmutable","Entity","EntitySchema","EmptyBase","useIncoming","existingMeta","incomingMeta","existing","incoming","fetchedAt","mergeWithStore","merge","process","input","parent","key","env","NODE_ENV","automaticValidation","Array","isArray","errorMessage","name","JSON","stringify","slice","error","Error","status","console","warn","validate","processedEntity","keysOfRecord","Set","Object","keys","defaults","keysOfProps","found","missing","unexpected","keyOfProps","has","push","keyOfRecord","includes","size","tooManyUnexpected","Math","max","length","foundNothing","min","extra","reason","denormalize","unvisit","undefined","toJS","setLocal","denormEntity","deleted","schema","fromJS","toObject","entityCopy","forEach","nextInput","value","deletedItem","set","entity","superFrom","props","prototype","pk","call"],"sources":["../../src/schemas/Entity.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n\nimport { isImmutable, denormalizeImmutable } from './ImmutableUtils.js';\nimport type { UnvisitFunction } from '../interface.js';\nimport { AbstractInstanceType } from '../normal.js';\nimport { Entity as EntitySchema } from '../schema.js';\n\nconst EmptyBase = class {} as any as abstract new (...args: any[]) => {\n  pk(parent?: any, key?: string): string | undefined;\n};\n\n/**\n * Represents data that should be deduped by specifying a primary key.\n * @see https://resthooks.io/docs/api/Entity\n */\nexport default abstract class Entity extends EntitySchema(EmptyBase) {\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  abstract pk(parent?: any, key?: string): string | undefined;\n\n  /** Control how automatic schema validation is handled\n   *\n   * `undefined`: Defaults - throw error in worst offense\n   * 'warn': only ever warn\n   * 'silent': Don't bother with processing at all\n   *\n   * Note: this only applies to non-nested members.\n   */\n  protected declare static automaticValidation?: 'warn' | 'silent';\n\n  /** Return true to merge incoming data; false keeps existing entity\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n   */\n  static useIncoming(\n    existingMeta: { date: number; fetchedAt: number },\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ) {\n    return existingMeta.fetchedAt <= incomingMeta.fetchedAt;\n  }\n\n  /** Run when an existing entity is found in the store */\n  static mergeWithStore(\n    existingMeta:\n      | {\n          date: number;\n          fetchedAt: number;\n        }\n      | undefined,\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ) {\n    const useIncoming =\n      // we may have in store but not in meta; so this existance check is still important\n      !existingMeta ||\n      this.useIncoming(existingMeta, incomingMeta, existing, incoming);\n\n    if (useIncoming) {\n      // distinct types are not mergeable, so just replace\n      if (typeof incoming !== typeof existing) {\n        return incoming;\n      } else {\n        return this.merge(existing, incoming);\n      }\n    } else {\n      return existing;\n    }\n  }\n\n  /** Factory method to convert from Plain JS Objects.\n   *\n   * @param [props] Plain Object of properties to assign.\n   */\n  declare static fromJS: <T extends typeof Entity>(\n    this: T,\n    // TODO: this should only accept members that are not functions\n    props?: Partial<AbstractInstanceType<T>>,\n  ) => AbstractInstanceType<T>;\n\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [value] POJO of the entity or subset used\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  declare static pk: <T extends typeof Entity>(\n    this: T,\n    value: Partial<AbstractInstanceType<T>>,\n    parent?: any,\n    key?: string,\n  ) => string | undefined;\n\n  /** Do any transformations when first receiving input */\n  static process(input: any, parent: any, key: string | undefined): any {\n    /* istanbul ignore else */\n    if (\n      process.env.NODE_ENV !== 'production' &&\n      this.automaticValidation !== 'silent'\n    ) {\n      if (Array.isArray(input)) {\n        const errorMessage = `Attempted to initialize ${\n          this.name\n        } with an array, but named members were expected\n\nThis is likely due to a malformed response.\nTry inspecting the network response or fetch() return value.\nOr use debugging tools: https://resthooks.io/docs/guides/debugging\nLearn more about schemas: https://resthooks.io/docs/api/schema\nIf this is a mistake, you can disable this check by setting static automaticValidation = 'silent'\n\nFirst three members: ${JSON.stringify(input.slice(0, 3), null, 2)}`;\n        if (this.automaticValidation !== 'warn') {\n          const error = new Error(errorMessage);\n          (error as any).status = 400;\n          throw error;\n        }\n        console.warn(errorMessage);\n      }\n    }\n\n    return super.process(input, parent, key);\n  }\n\n  static validate(processedEntity: any): string | undefined {\n    /* istanbul ignore else */\n    if (\n      process.env.NODE_ENV !== 'production' &&\n      this.automaticValidation !== 'silent'\n    ) {\n      const keysOfRecord = new Set(Object.keys(this.defaults));\n      const keysOfProps = Object.keys(processedEntity);\n      const [found, missing, unexpected] = [[], [], []] as [\n        string[],\n        string[],\n        string[],\n      ];\n      for (const keyOfProps of keysOfProps) {\n        if (keysOfRecord.has(keyOfProps)) {\n          found.push(keyOfProps);\n        } else {\n          unexpected.push(keyOfProps);\n        }\n      }\n      for (const keyOfRecord of keysOfRecord) {\n        if (!found.includes(keyOfRecord)) {\n          missing.push(keyOfRecord);\n        }\n      }\n\n      // only bother with this if they used *any* defaults\n      if (keysOfRecord.size) {\n        const tooManyUnexpected =\n          // unexpected compared to members in response\n          Math.max(keysOfProps.length / 2, 1) <= unexpected.length &&\n          // unexpected compared to what we specified\n          keysOfRecord.size > Math.max(unexpected.length, 2) &&\n          // as we find more and more be more easily assured it is correct\n          found.length ** 1.5 / 2 <= unexpected.length;\n        const foundNothing = found.length < Math.min(1, keysOfRecord.size / 2);\n        // if we find nothing (we expect at least one member for a pk)\n        // or we find too many unexpected members\n        if (tooManyUnexpected || foundNothing) {\n          let extra = '';\n          let reason = 'substantially different than expected keys';\n          if (foundNothing) {\n            extra += `\\n    Missing: ${missing}`;\n            reason = 'no matching keys found';\n          }\n          if (tooManyUnexpected) {\n            extra += `\\n    Unexpected keys: ${unexpected}`;\n            reason = 'a large number of unexpected keys found';\n          }\n          const errorMessage = `Attempted to initialize ${\n            this.name\n          } with ${reason}\n\n  This is likely due to a malformed response.\n  Try inspecting the network response or fetch() return value.\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about schemas: https://resthooks.io/docs/api/schema\n  If this is a mistake, you can disable this check by setting static automaticValidation = 'silent'\n\n  Expected keys:\n    Found: ${found}${extra}\n  Value (processed): ${JSON.stringify(processedEntity, null, 2)}`;\n          if (\n            (found.length >= 4 && tooManyUnexpected) ||\n            this.automaticValidation === 'warn'\n          ) {\n            console.warn(errorMessage);\n          } else {\n            return errorMessage;\n          }\n        }\n      }\n    }\n    return super.validate(processedEntity);\n  }\n\n  static denormalize<T extends typeof Entity>(\n    this: T,\n    input: any,\n    unvisit: UnvisitFunction,\n  ): [denormalized: AbstractInstanceType<T>, found: boolean, suspend: boolean] {\n    // TODO: remove codecov ignore once denormalize is modified to expect this\n    /* istanbul ignore if */\n    if (typeof input === 'symbol') {\n      return [undefined, true, true] as any;\n    }\n    // TODO(breaking): Remove fromJS and setLocal call once old versions are no longer supported\n    if (isImmutable(input)) {\n      if (this.validate((input as any).toJS()))\n        return [undefined as any, false, true];\n      // Need to set this first so that if it is referenced further within the\n      // denormalization the reference will already exist.\n      unvisit.setLocal?.(input);\n      const [denormEntity, found, deleted] = denormalizeImmutable(\n        this.schema,\n        input,\n        unvisit,\n      );\n      return [this.fromJS(denormEntity.toObject()) as any, true, deleted];\n    }\n    let entityCopy: any;\n    // new path\n    if (input instanceof this) {\n      entityCopy = input;\n      // TODO(breaking): Remove fromJS and setLocal call once old versions are no longer supported\n    } else {\n      if (this.validate(input)) {\n        return [undefined as any, false, true];\n      }\n      entityCopy = this.fromJS(input);\n      // Need to set this first so that if it is referenced further within the\n      // denormalization the reference will already exist.\n      unvisit.setLocal?.(entityCopy);\n    }\n\n    let deleted = false;\n\n    // note: iteration order must be stable\n    Object.keys(this.schema).forEach(key => {\n      const schema = this.schema[key];\n      const nextInput = (input as any)[key];\n      const [value, , deletedItem] = unvisit(nextInput, schema);\n\n      if (deletedItem && !!this.defaults[key]) {\n        deleted = true;\n      }\n      if ((input as any)[key] !== value) {\n        // we're cheating because we know it is implemented\n        (this as any).set(entityCopy, key, value);\n      }\n    });\n\n    return [entityCopy, true, deleted];\n  }\n\n  /** Used by denormalize to set nested members */\n  protected static set?(entity: any, key: string, value: any) {\n    entity[key] = value;\n  }\n}\n\nif (process.env.NODE_ENV !== 'production') {\n  /* istanbul ignore else */\n  const superFrom = Entity.fromJS;\n  // for those not using TypeScript this is a good catch to ensure they are defining\n  // the abstract members\n  Entity.fromJS = function fromJS<T extends typeof Entity>(\n    this: T,\n    props?: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T> {\n    if ((this as any).prototype.pk === Entity.prototype.pk)\n      throw new Error('cannot construct on abstract types');\n    return superFrom.call(this, props) as any;\n  };\n}\n"],"mappings":"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"} | ||
// we're avoiding this on the type | ||
Entity.expiresAt = function (meta, input) { | ||
return meta.expiresAt; | ||
}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["isImmutable","denormalizeImmutable","Entity","EntitySchema","EmptyBase","useIncoming","existingMeta","incomingMeta","existing","incoming","fetchedAt","mergeWithStore","merge","mergeMetaWithStore","expiresAt","Math","max","date","process","input","parent","key","env","NODE_ENV","automaticValidation","Array","isArray","errorMessage","name","JSON","stringify","slice","error","Error","status","console","warn","validate","processedEntity","keysOfRecord","Set","Object","keys","defaults","keysOfProps","found","missing","unexpected","keyOfProps","has","push","keyOfRecord","includes","size","tooManyUnexpected","length","foundNothing","min","extra","reason","denormalize","unvisit","undefined","toJS","setLocal","denormEntity","deleted","schema","fromJS","toObject","entityCopy","forEach","nextInput","value","deletedItem","set","entity","superFrom","props","prototype","pk","call","meta"],"sources":["../../src/schemas/Entity.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n\nimport { isImmutable, denormalizeImmutable } from './ImmutableUtils.js';\nimport type { UnvisitFunction } from '../interface.js';\nimport { AbstractInstanceType } from '../normal.js';\nimport { Entity as EntitySchema } from '../schema.js';\n\nconst EmptyBase = class {} as any as abstract new (...args: any[]) => {\n  pk(parent?: any, key?: string, args?: readonly any[]): string | undefined;\n};\n\n/**\n * Represents data that should be deduped by specifying a primary key.\n * @see https://resthooks.io/docs/api/Entity\n */\nexport default abstract class Entity extends EntitySchema(EmptyBase) {\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  abstract pk(\n    parent?: any,\n    key?: string,\n    args?: readonly any[],\n  ): string | undefined;\n\n  /** Control how automatic schema validation is handled\n   *\n   * `undefined`: Defaults - throw error in worst offense\n   * 'warn': only ever warn\n   * 'silent': Don't bother with processing at all\n   *\n   * Note: this only applies to non-nested members.\n   */\n  protected declare static automaticValidation?: 'warn' | 'silent';\n\n  /** Return true to merge incoming data; false keeps existing entity\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n   */\n  static useIncoming(\n    existingMeta: { date: number; fetchedAt: number },\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ) {\n    return existingMeta.fetchedAt <= incomingMeta.fetchedAt;\n  }\n\n  /** Run when an existing entity is found in the store */\n  static mergeWithStore(\n    existingMeta:\n      | {\n          date: number;\n          fetchedAt: number;\n        }\n      | undefined,\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ) {\n    const useIncoming =\n      // we may have in store but not in meta; so this existance check is still important\n      !existingMeta ||\n      this.useIncoming(existingMeta, incomingMeta, existing, incoming);\n\n    if (useIncoming) {\n      // distinct types are not mergeable, so just replace\n      if (typeof incoming !== typeof existing) {\n        return incoming;\n      } else {\n        return this.merge(existing, incoming);\n      }\n    } else {\n      return existing;\n    }\n  }\n\n  static mergeMetaWithStore(\n    existingMeta: {\n      expiresAt: number;\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: { expiresAt: number; date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ) {\n    return {\n      expiresAt: Math.max(\n        (this as any).expiresAt(incomingMeta, incoming),\n        existingMeta.expiresAt,\n      ),\n      date: Math.max(incomingMeta.date, existingMeta.date),\n      fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt),\n    };\n  }\n\n  /** Factory method to convert from Plain JS Objects.\n   *\n   * @param [props] Plain Object of properties to assign.\n   */\n  declare static fromJS: <T extends typeof Entity>(\n    this: T,\n    // TODO: this should only accept members that are not functions\n    props?: Partial<AbstractInstanceType<T>>,\n  ) => AbstractInstanceType<T>;\n\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [value] POJO of the entity or subset used\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  declare static pk: <T extends typeof Entity>(\n    this: T,\n    value: Partial<AbstractInstanceType<T>>,\n    parent?: any,\n    key?: string,\n    args?: any[],\n  ) => string | undefined;\n\n  /** Do any transformations when first receiving input */\n  static process(input: any, parent: any, key: string | undefined): any {\n    /* istanbul ignore else */\n    if (\n      process.env.NODE_ENV !== 'production' &&\n      this.automaticValidation !== 'silent'\n    ) {\n      if (Array.isArray(input)) {\n        const errorMessage = `Attempted to initialize ${\n          this.name\n        } with an array, but named members were expected\n\nThis is likely due to a malformed response.\nTry inspecting the network response or fetch() return value.\nOr use debugging tools: https://resthooks.io/docs/guides/debugging\nLearn more about schemas: https://resthooks.io/docs/api/schema\nIf this is a mistake, you can disable this check by setting static automaticValidation = 'silent'\n\nFirst three members: ${JSON.stringify(input.slice(0, 3), null, 2)}`;\n        if (this.automaticValidation !== 'warn') {\n          const error = new Error(errorMessage);\n          (error as any).status = 400;\n          throw error;\n        }\n        console.warn(errorMessage);\n      }\n    }\n\n    return super.process(input, parent, key);\n  }\n\n  static validate(processedEntity: any): string | undefined {\n    /* istanbul ignore else */\n    if (\n      process.env.NODE_ENV !== 'production' &&\n      this.automaticValidation !== 'silent'\n    ) {\n      const keysOfRecord = new Set(Object.keys(this.defaults));\n      const keysOfProps = Object.keys(processedEntity);\n      const [found, missing, unexpected] = [[], [], []] as [\n        string[],\n        string[],\n        string[],\n      ];\n      for (const keyOfProps of keysOfProps) {\n        if (keysOfRecord.has(keyOfProps)) {\n          found.push(keyOfProps);\n        } else {\n          unexpected.push(keyOfProps);\n        }\n      }\n      for (const keyOfRecord of keysOfRecord) {\n        if (!found.includes(keyOfRecord)) {\n          missing.push(keyOfRecord);\n        }\n      }\n\n      // only bother with this if they used *any* defaults\n      if (keysOfRecord.size) {\n        const tooManyUnexpected =\n          // unexpected compared to members in response\n          Math.max(keysOfProps.length / 2, 1) <= unexpected.length &&\n          // unexpected compared to what we specified\n          keysOfRecord.size > Math.max(unexpected.length, 2) &&\n          // as we find more and more be more easily assured it is correct\n          found.length ** 1.5 / 2 <= unexpected.length;\n        const foundNothing = found.length < Math.min(1, keysOfRecord.size / 2);\n        // if we find nothing (we expect at least one member for a pk)\n        // or we find too many unexpected members\n        if (tooManyUnexpected || foundNothing) {\n          let extra = '';\n          let reason = 'substantially different than expected keys';\n          if (foundNothing) {\n            extra += `\\n    Missing: ${missing}`;\n            reason = 'no matching keys found';\n          }\n          if (tooManyUnexpected) {\n            extra += `\\n    Unexpected keys: ${unexpected}`;\n            reason = 'a large number of unexpected keys found';\n          }\n          const errorMessage = `Attempted to initialize ${\n            this.name\n          } with ${reason}\n\n  This is likely due to a malformed response.\n  Try inspecting the network response or fetch() return value.\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about schemas: https://resthooks.io/docs/api/schema\n  If this is a mistake, you can disable this check by setting static automaticValidation = 'silent'\n\n  Expected keys:\n    Found: ${found}${extra}\n  Value (processed): ${JSON.stringify(processedEntity, null, 2)}`;\n          if (\n            (found.length >= 4 && tooManyUnexpected) ||\n            this.automaticValidation === 'warn'\n          ) {\n            console.warn(errorMessage);\n          } else {\n            return errorMessage;\n          }\n        }\n      }\n    }\n    return super.validate(processedEntity);\n  }\n\n  static denormalize<T extends typeof Entity>(\n    this: T,\n    input: any,\n    unvisit: UnvisitFunction,\n  ): [denormalized: AbstractInstanceType<T>, found: boolean, suspend: boolean] {\n    // TODO: remove codecov ignore once denormalize is modified to expect this\n    /* istanbul ignore if */\n    if (typeof input === 'symbol') {\n      return [undefined, true, true] as any;\n    }\n    // TODO(breaking): Remove fromJS and setLocal call once old versions are no longer supported\n    if (isImmutable(input)) {\n      if (this.validate((input as any).toJS()))\n        return [undefined as any, false, true];\n      // Need to set this first so that if it is referenced further within the\n      // denormalization the reference will already exist.\n      unvisit.setLocal?.(input);\n      const [denormEntity, found, deleted] = denormalizeImmutable(\n        this.schema,\n        input,\n        unvisit,\n      );\n      return [this.fromJS(denormEntity.toObject()) as any, true, deleted];\n    }\n    let entityCopy: any;\n    // new path\n    if (input instanceof this) {\n      entityCopy = input;\n      // TODO(breaking): Remove fromJS and setLocal call once old versions are no longer supported\n    } else {\n      if (this.validate(input)) {\n        return [undefined as any, false, true];\n      }\n      entityCopy = this.fromJS(input);\n      // Need to set this first so that if it is referenced further within the\n      // denormalization the reference will already exist.\n      unvisit.setLocal?.(entityCopy);\n    }\n\n    let deleted = false;\n\n    // note: iteration order must be stable\n    Object.keys(this.schema).forEach(key => {\n      const schema = this.schema[key];\n      const nextInput = (input as any)[key];\n      const [value, , deletedItem] = unvisit(nextInput, schema);\n\n      if (deletedItem && !!this.defaults[key]) {\n        deleted = true;\n      }\n      if ((input as any)[key] !== value) {\n        // we're cheating because we know it is implemented\n        (this as any).set(entityCopy, key, value);\n      }\n    });\n\n    return [entityCopy, true, deleted];\n  }\n\n  /** Used by denormalize to set nested members */\n  protected static set?(entity: any, key: string, value: any) {\n    entity[key] = value;\n  }\n}\n\nif (process.env.NODE_ENV !== 'production') {\n  /* istanbul ignore else */\n  const superFrom = Entity.fromJS;\n  // for those not using TypeScript this is a good catch to ensure they are defining\n  // the abstract members\n  Entity.fromJS = function fromJS<T extends typeof Entity>(\n    this: T,\n    props?: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T> {\n    if ((this as any).prototype.pk === Entity.prototype.pk)\n      throw new Error('cannot construct on abstract types');\n    return superFrom.call(this, props) as any;\n  };\n}\n\n// we're avoiding this on the type\n(Entity as any).expiresAt = function (\n  meta: { expiresAt: number; date: number; fetchedAt: number },\n  input: any,\n): number {\n  return meta.expiresAt;\n};\n"],"mappings":"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"} |
@@ -29,2 +29,14 @@ import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/objectWithoutPropertiesLoose"; | ||
* | ||
* @param [parent] When normalizing, the object which included the entity | ||
* @param [key] When normalizing, the key where this entity was found | ||
*/ | ||
/** Returns the globally unique identifier for the static Entity */ | ||
// default implementation in class static block at bottom of definition | ||
/** Defines indexes to enable lookup by */ | ||
/** | ||
* A unique identifier for each Entity | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#pk | ||
* @param [value] POJO of the entity or subset used | ||
@@ -34,4 +46,4 @@ * @param [parent] When normalizing, the object which included the entity | ||
*/ | ||
static pk(value, parent, key) { | ||
return this.prototype.pk.call(value, parent, key); | ||
static pk(value, parent, key, args) { | ||
return this.prototype.pk.call(value, parent, key, args); | ||
} | ||
@@ -56,3 +68,6 @@ | ||
/** Creates new instance copying over defined values of arguments */ | ||
/** Creates new instance copying over defined values of arguments | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#merge | ||
*/ | ||
static merge(existing, incoming) { | ||
@@ -62,3 +77,6 @@ return Object.assign({}, existing, incoming); | ||
/** Run when an existing entity is found in the store */ | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeWithStore | ||
*/ | ||
static mergeWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
@@ -78,2 +96,10 @@ const useIncoming = this.useIncoming(existingMeta, incomingMeta, existing, incoming); | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeMetaWithStore | ||
*/ | ||
static mergeMetaWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
return this.shouldReorder(existingMeta, incomingMeta, existing, incoming) ? existingMeta : incomingMeta; | ||
} | ||
/** Factory method to convert from Plain JS Objects. | ||
@@ -94,5 +120,6 @@ * | ||
/** Factory method to convert from Plain JS Objects. | ||
/** Called when denormalizing an entity to create an instance when 'valid' | ||
* | ||
* @param [props] Plain Object of properties to assign. | ||
* @see https://resthooks.io/docs/api/schema.Entity#createIfValid | ||
*/ | ||
@@ -108,9 +135,12 @@ static createIfValid( | ||
/** Do any transformations when first receiving input */ | ||
/** Do any transformations when first receiving input | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#process | ||
*/ | ||
static process(input, parent, key) { | ||
return Object.assign({}, input); | ||
} | ||
static normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
static normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
const processedEntity = this.process(input, parent, key); | ||
const id = this.pk(processedEntity, parent, key); | ||
const id = this.pk(processedEntity, parent, key, args); | ||
if (id === undefined || id === '') { | ||
@@ -131,4 +161,4 @@ if (process.env.NODE_ENV !== 'production') { | ||
} else { | ||
// these make the keys get deleted | ||
return undefined; | ||
// these make the keys get deleted; return undefined | ||
return; | ||
} | ||
@@ -152,3 +182,3 @@ } | ||
const schema = this.schema[key]; | ||
processedEntity[key] = visit(processedEntity[key], processedEntity, key, schema, addEntity, visitedEntities); | ||
processedEntity[key] = visit(processedEntity[key], processedEntity, key, schema, addEntity, visitedEntities, storeEntities, args); | ||
} | ||
@@ -178,22 +208,10 @@ }); | ||
} | ||
static infer(args, indexes, recurse) { | ||
static infer(args, indexes, recurse, entities) { | ||
var _entities$this$key; | ||
if (!args[0]) return undefined; | ||
if (['string', 'number'].includes(typeof args[0])) { | ||
return `${args[0]}`; | ||
} | ||
const id = this.pk(args[0], undefined, ''); | ||
// Was able to infer the entity's primary key from params | ||
if (id !== undefined && id !== '') return id; | ||
// now attempt lookup in indexes | ||
const indexName = indexFromParams(args[0], this.indexes); | ||
if (indexName && indexes[this.key]) { | ||
// 'as Record<string, any>': indexName can only be found if params is a string key'd object | ||
const id = indexes[this.key][indexName][args[0][indexName]]; | ||
return id; | ||
} | ||
const id = inferId(this, args, indexes); | ||
// no entity arg is back-compatibility | ||
if (!entities || (_entities$this$key = entities[this.key]) != null && _entities$this$key[id]) return id; | ||
return undefined; | ||
} | ||
static expiresAt(meta, input) { | ||
return meta.expiresAt; | ||
} | ||
static denormalize(input, unvisit) { | ||
@@ -218,3 +236,24 @@ // TODO: remove codecov ignore once denormalize is modified to expect this | ||
} | ||
static denormalizeOnly(input, args, unvisit) { | ||
if (typeof input === 'symbol') { | ||
return input; | ||
} | ||
// note: iteration order must be stable | ||
for (const key of Object.keys(this.schema)) { | ||
const schema = this.schema[key]; | ||
const value = unvisit(input[key], schema); | ||
if (typeof value === 'symbol') { | ||
// if default is not 'fasly', then this is required, so propagate INVALID symbol | ||
if (this.defaults[key]) { | ||
return value; | ||
} | ||
input[key] = undefined; | ||
} else { | ||
input[key] = value; | ||
} | ||
} | ||
return input; | ||
} | ||
/** All instance defaults set */ | ||
@@ -233,2 +272,3 @@ static get defaults() { | ||
pk, | ||
schema, | ||
key | ||
@@ -314,2 +354,17 @@ } = options, | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["EntitySchema","Base","options","EntityMixin","toString","key","toJSON","name","schema","pk","value","parent","prototype","call","useIncoming","existingMeta","incomingMeta","existing","incoming","shouldReorder","fetchedAt","merge","Object","assign","mergeWithStore","fromJS","props","instance","createIfValid","validate","undefined","process","input","normalize","visit","addEntity","visitedEntities","processedEntity","id","env","NODE_ENV","error","Error","JSON","stringify","status","entityType","some","entity","errorMessage","throwValidationError","push","keys","forEach","hasOwn","defaults","infer","args","indexes","recurse","includes","indexName","indexFromParams","expiresAt","meta","denormalize","unvisit","deleted","nextInput","deletedItem","defineProperty","writable","configurable","__defaults","staticProps","_objectWithoutPropertiesLoose","_excluded","set","enumerable","CLASSNAMEMANGLING","get","console","params","find","index"],"sources":["../../src/schemas/EntitySchema.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\nimport type { Schema, NormalizedIndex, UnvisitFunction } from '../interface.js';\nimport { AbstractInstanceType } from '../normal.js';\n\nexport type Constructor = abstract new (...args: any[]) => {};\nexport type IDClass = abstract new (...args: any[]) => {\n  id: string | number | undefined;\n};\nexport type PKClass = abstract new (...args: any[]) => {\n  pk(parent?: any, key?: string): string | undefined;\n};\n\n// TODO: Figure out what Schema must be for each key\ntype ValidSchemas<TInstance> = { [k in keyof TInstance]?: Schema };\n\nexport type EntityOptions<TInstance extends {}> = {\n  readonly schema?: ValidSchemas<TInstance>;\n  readonly pk?:\n    | ((value: TInstance, parent?: any, key?: string) => string | undefined)\n    | keyof TInstance;\n  readonly key?: string;\n} & {\n  readonly [K in Extract<\n    keyof IEntityClass,\n    | 'process'\n    | 'merge'\n    | 'expiresAt'\n    | 'createIfValid'\n    | 'mergeWithStore'\n    | 'validate'\n    | 'shouldReorder'\n    | 'useIncoming'\n  >]?: IEntityClass<abstract new (...args: any[]) => TInstance>[K];\n};\n\nexport interface RequiredPKOptions<TInstance extends {}>\n  extends EntityOptions<TInstance> {\n  readonly pk:\n    | ((value: TInstance, parent?: any, key?: string) => string | undefined)\n    | keyof TInstance;\n}\n\nexport default function EntitySchema<TBase extends Constructor>(\n  Base: TBase,\n  options: EntityOptions<InstanceType<TBase>> = {},\n) {\n  /**\n   * Represents data that should be deduped by specifying a primary key.\n   * @see https://resthooks.io/docs/api/Entity\n   */\n  abstract class EntityMixin extends Base {\n    static toString() {\n      return this.key;\n    }\n\n    static toJSON() {\n      return {\n        name: this.name,\n        schema: this.schema,\n        key: this.key,\n      };\n    }\n\n    /** Defines nested entities */\n    declare static schema: { [k: string]: Schema };\n\n    /**\n     * A unique identifier for each Entity\n     *\n     * @param [parent] When normalizing, the object which included the entity\n     * @param [key] When normalizing, the key where this entity was found\n     */\n    abstract pk(parent?: any, key?: string): string | undefined;\n\n    /** Returns the globally unique identifier for the static Entity */\n    declare static key: string;\n    // default implementation in class static block at bottom of definition\n\n    /** Defines indexes to enable lookup by */\n    declare static indexes?: readonly string[];\n\n    /**\n     * A unique identifier for each Entity\n     *\n     * @param [value] POJO of the entity or subset used\n     * @param [parent] When normalizing, the object which included the entity\n     * @param [key] When normalizing, the key where this entity was found\n     */\n    static pk<T extends typeof EntityMixin>(\n      this: T,\n      value: Partial<AbstractInstanceType<T>>,\n      parent?: any,\n      key?: string,\n    ): string | undefined {\n      return this.prototype.pk.call(value, parent, key);\n    }\n\n    /** Return true to merge incoming data; false keeps existing entity\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n     */\n    static useIncoming(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return true;\n    }\n\n    /** Determines the order of incoming entity vs entity already in store\\\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#shouldReorder\n     * @returns true if incoming entity should be first argument of merge()\n     */\n    static shouldReorder(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return incomingMeta.fetchedAt < existingMeta.fetchedAt;\n    }\n\n    /** Creates new instance copying over defined values of arguments */\n    static merge(existing: any, incoming: any) {\n      return {\n        ...existing,\n        ...incoming,\n      };\n    }\n\n    /** Run when an existing entity is found in the store */\n    static mergeWithStore(\n      existingMeta: {\n        date: number;\n        fetchedAt: number;\n      },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      const useIncoming = this.useIncoming(\n        existingMeta,\n        incomingMeta,\n        existing,\n        incoming,\n      );\n\n      if (useIncoming) {\n        // distinct types are not mergeable (like delete symbol), so just replace\n        if (typeof incoming !== typeof existing) {\n          return incoming;\n        } else {\n          return this.shouldReorder(\n            existingMeta,\n            incomingMeta,\n            existing,\n            incoming,\n          )\n            ? this.merge(incoming, existing)\n            : this.merge(existing, incoming);\n        }\n      } else {\n        return existing;\n      }\n    }\n\n    /** Factory method to convert from Plain JS Objects.\n     *\n     * @param [props] Plain Object of properties to assign.\n     */\n    static fromJS<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>> = {},\n    ): AbstractInstanceType<T> {\n      // we type guarded abstract case above, so ok to force typescript to allow constructor call\n      const instance = new (this as any)(props) as AbstractInstanceType<T>;\n      // we can't rely on constructors and override the defaults provided as property assignments\n      // all occur after the constructor\n      Object.assign(instance, props);\n      return instance;\n    }\n\n    /** Factory method to convert from Plain JS Objects.\n     *\n     * @param [props] Plain Object of properties to assign.\n     */\n    static createIfValid<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>>,\n    ): AbstractInstanceType<T> | undefined {\n      if (this.validate(props)) {\n        return undefined as any;\n      }\n      return this.fromJS(props);\n    }\n\n    /** Do any transformations when first receiving input */\n    static process(input: any, parent: any, key: string | undefined): any {\n      return { ...input };\n    }\n\n    static normalize(\n      input: any,\n      parent: any,\n      key: string | undefined,\n      visit: (...args: any) => any,\n      addEntity: (...args: any) => any,\n      visitedEntities: Record<string, any>,\n    ): any {\n      const processedEntity = this.process(input, parent, key);\n      const id = this.pk(processedEntity, parent, key);\n      if (id === undefined || id === '') {\n        if (process.env.NODE_ENV !== 'production') {\n          const error = new Error(\n            `Missing usable primary key when normalizing response.\n\n  This is likely due to a malformed response.\n  Try inspecting the network response or fetch() return value.\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about primary keys: https://resthooks.io/rest/api/Entity#pk\n\n  Entity: ${this.name}\n  Value (processed): ${\n    processedEntity && JSON.stringify(processedEntity, null, 2)\n  }\n  `,\n          );\n          (error as any).status = 400;\n          throw error;\n        } else {\n          // these make the keys get deleted\n          return undefined;\n        }\n      }\n      const entityType = this.key;\n\n      if (!(entityType in visitedEntities)) {\n        visitedEntities[entityType] = {};\n      }\n      if (!(id in visitedEntities[entityType])) {\n        visitedEntities[entityType][id] = [];\n      }\n      if (\n        visitedEntities[entityType][id].some((entity: any) => entity === input)\n      ) {\n        return id;\n      }\n      const errorMessage = this.validate(processedEntity);\n      throwValidationError(errorMessage);\n\n      visitedEntities[entityType][id].push(input);\n\n      Object.keys(this.schema).forEach(key => {\n        if (Object.hasOwn(processedEntity, key)) {\n          const schema = this.schema[key];\n          processedEntity[key] = visit(\n            processedEntity[key],\n            processedEntity,\n            key,\n            schema,\n            addEntity,\n            visitedEntities,\n          );\n        }\n      });\n\n      addEntity(this, processedEntity, id);\n      return id;\n    }\n\n    static validate(processedEntity: any): string | undefined {\n      if (process.env.NODE_ENV !== 'production') {\n        for (const key of Object.keys(this.schema)) {\n          if (!Object.hasOwn(processedEntity, key)) {\n            if (!Object.hasOwn(this.defaults, key)) {\n              return `Schema key is missing in Entity\n\n  Be sure all schema members are also part of the entity\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about nesting schemas: https://resthooks.io/rest/guides/relational-data\n\n  Entity keys: ${Object.keys(this.defaults)}\n  Schema key(missing): ${key}\n  `;\n            }\n          }\n        }\n      }\n    }\n\n    static infer(\n      args: readonly any[],\n      indexes: NormalizedIndex,\n      recurse: any,\n    ): any {\n      if (!args[0]) return undefined;\n      if (['string', 'number'].includes(typeof args[0])) {\n        return `${args[0]}`;\n      }\n      const id = this.pk(args[0], undefined, '');\n      // Was able to infer the entity's primary key from params\n      if (id !== undefined && id !== '') return id;\n      // now attempt lookup in indexes\n      const indexName = indexFromParams(args[0], this.indexes);\n      if (indexName && indexes[this.key]) {\n        // 'as Record<string, any>': indexName can only be found if params is a string key'd object\n        const id =\n          indexes[this.key][indexName][\n            (args[0] as Record<string, any>)[indexName]\n          ];\n        return id;\n      }\n      return undefined;\n    }\n\n    static expiresAt(\n      meta: { expiresAt: number; date: number; fetchedAt: number },\n      input: any,\n    ): number {\n      return meta.expiresAt;\n    }\n\n    static denormalize<T extends typeof EntityMixin>(\n      this: T,\n      input: any,\n      unvisit: UnvisitFunction,\n    ): [\n      denormalized: AbstractInstanceType<T>,\n      found: boolean,\n      suspend: boolean,\n    ] {\n      // TODO: remove codecov ignore once denormalize is modified to expect this\n      /* istanbul ignore if */\n      if (typeof input === 'symbol') {\n        return [undefined, true, true] as any;\n      }\n\n      let deleted = false;\n      // note: iteration order must be stable\n      Object.keys(this.schema).forEach(key => {\n        const schema = this.schema[key];\n        const nextInput = (input as any)[key];\n        const [value, , deletedItem] = unvisit(nextInput, schema);\n\n        if (deletedItem && !!this.defaults[key]) {\n          deleted = true;\n        }\n        input[key] = value;\n      });\n\n      return [input, true, deleted];\n    }\n\n    /** All instance defaults set */\n    static get defaults() {\n      // we use hasOwn because we don't want to use a parents' defaults\n      if (!Object.hasOwn(this, '__defaults'))\n        Object.defineProperty(this, '__defaults', {\n          value: new (this as any)(),\n          writable: true,\n          configurable: true,\n        });\n      return (this as any).__defaults;\n    }\n  }\n\n  const { pk, schema, key, ...staticProps } = options;\n  // remaining options\n  Object.assign(EntityMixin, staticProps);\n\n  if ('schema' in options) {\n    EntityMixin.schema = options.schema as any;\n  } else if (!(Base as any).schema) {\n    EntityMixin.schema = {};\n  }\n  if ('pk' in options) {\n    if (typeof options.pk === 'function') {\n      EntityMixin.prototype.pk = function (parent?: any, key?: string) {\n        return (options.pk as any)(this, parent, key);\n      };\n    } else {\n      EntityMixin.prototype.pk = function () {\n        return this[options.pk];\n      };\n    }\n    // default to 'id' field if the base class doesn't have a pk\n  } else if (typeof Base.prototype.pk !== 'function') {\n    EntityMixin.prototype.pk = function () {\n      return this.id;\n    };\n  }\n  if ('key' in options) {\n    Object.defineProperty(EntityMixin, 'key', {\n      value: options.key,\n      configurable: true,\n      writable: true,\n    });\n  } else if (!('key' in Base)) {\n    // this allows assignment in strict-mode\n    // eslint-disable-next-line no-inner-declarations\n    function set(this: any, value: string) {\n      Object.defineProperty(this, 'key', {\n        value,\n        writable: true,\n        enumerable: true,\n      });\n    }\n    const CLASSNAMEMANGLING = EntityMixin.name !== 'EntityMixin';\n    const get =\n      /* istanbul ignore if */\n      CLASSNAMEMANGLING\n        ? /* istanbul ignore next */ function (this: {\n            name: string;\n            key: string;\n          }): string {\n            const name = this.name === 'EntityMixin' ? Base.name : this.name;\n            console.error('Rest Hooks Error: https://resthooks.io/errors/dklj');\n            Object.defineProperty(this, 'key', {\n              get() {\n                return name;\n              },\n              set,\n            });\n            return this.key;\n          }\n        : function (this: { name: string }): string {\n            const name = this.name === 'EntityMixin' ? Base.name : this.name;\n            /* istanbul ignore next */\n            if (\n              process.env.NODE_ENV !== 'production' &&\n              (name === '' || name === 'EntityMixin' || name === '_temp')\n            )\n              throw new Error(\n                'Entity classes without a name must define `static key`\\nSee: https://resthooks.io/rest/api/Entity#key',\n              );\n            return name;\n          };\n\n    Object.defineProperty(EntityMixin, 'key', {\n      get,\n      set,\n    });\n  }\n\n  return EntityMixin as any;\n}\n\nfunction indexFromParams<I extends string>(\n  params: Readonly<object>,\n  indexes?: Readonly<I[]>,\n) {\n  if (!indexes) return undefined;\n  return indexes.find(index => Object.hasOwn(params, index));\n}\n\n// part of the reason for pulling this out is that all functions that throw are deoptimized\nfunction throwValidationError(errorMessage: string | undefined) {\n  if (errorMessage) {\n    const error = new Error(errorMessage);\n    (error as any).status = 400;\n    throw error;\n  }\n}\n\nexport interface IEntityClass<TBase extends Constructor = any> {\n  toJSON(): {\n    name: string;\n    schema: {\n      [k: string]: Schema;\n    };\n    key: string;\n  };\n  /** Defines nested entities */\n  schema: {\n    [k: string]: Schema;\n  };\n  /** Returns the globally unique identifier for the static Entity */\n  key: string;\n  /** Defines indexes to enable lookup by */\n  indexes?: readonly string[] | undefined;\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [value] POJO of the entity or subset used\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  pk<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    value: Partial<AbstractInstanceType<T>>,\n    parent?: any,\n    key?: string,\n  ): string | undefined;\n  /** Return true to merge incoming data; false keeps existing entity\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n   */\n  useIncoming(\n    existingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    existing: any,\n    incoming: any,\n  ): boolean;\n  /** Determines the order of incoming entity vs entity already in store\\\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#shouldReorder\n   * @returns true if incoming entity should be first argument of merge()\n   */\n  shouldReorder(\n    existingMeta: { date: number; fetchedAt: number },\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ): boolean;\n  /** Creates new instance copying over defined values of arguments */\n  merge(existing: any, incoming: any): any;\n  /** Run when an existing entity is found in the store */\n  mergeWithStore(\n    existingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    existing: any,\n    incoming: any,\n  ): any;\n  /** Factory method to convert from Plain JS Objects.\n   *\n   * @param [props] Plain Object of properties to assign.\n   */\n  fromJS<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    props?: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T>;\n  /** Factory method to convert from Plain JS Objects.\n   *\n   * @param [props] Plain Object of properties to assign.\n   */\n  createIfValid<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    props: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T> | undefined;\n  /** Do any transformations when first receiving input */\n  process(input: any, parent: any, key: string | undefined): any;\n  normalize(\n    input: any,\n    parent: any,\n    key: string | undefined,\n    visit: (...args: any) => any,\n    addEntity: (...args: any) => any,\n    visitedEntities: Record<string, any>,\n  ): any;\n  validate(processedEntity: any): string | undefined;\n  infer(args: readonly any[], indexes: NormalizedIndex, recurse: any): any;\n  expiresAt(\n    meta: {\n      expiresAt: number;\n      date: number;\n      fetchedAt: number;\n    },\n    input: any,\n  ): number;\n  denormalize<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    input: any,\n    unvisit: UnvisitFunction,\n  ): [denormalized: AbstractInstanceType<T>, found: boolean, suspend: boolean];\n  /** All instance defaults set */\n  readonly defaults: any;\n  //set(entity: any, key: string, value: any): void;\n}\nexport interface IEntityInstance {\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  pk(parent?: any, key?: string): string | undefined;\n}\n"],"mappings":"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"} | ||
function inferId(schema, args, indexes) { | ||
if (['string', 'number'].includes(typeof args[0])) { | ||
return `${args[0]}`; | ||
} | ||
const id = schema.pk(args[0], undefined, '', args); | ||
// Was able to infer the entity's primary key from params | ||
if (id !== undefined && id !== '') return id; | ||
// now attempt lookup in indexes | ||
const indexName = indexFromParams(args[0], schema.indexes); | ||
if (indexName && indexes[schema.key]) { | ||
// 'as Record<string, any>': indexName can only be found if params is a string key'd object | ||
const id = indexes[schema.key][indexName][args[0][indexName]]; | ||
return id; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["EntitySchema","Base","options","EntityMixin","toString","key","toJSON","name","schema","pk","value","parent","args","prototype","call","useIncoming","existingMeta","incomingMeta","existing","incoming","shouldReorder","fetchedAt","merge","Object","assign","mergeWithStore","mergeMetaWithStore","fromJS","props","instance","createIfValid","validate","undefined","process","input","normalize","visit","addEntity","visitedEntities","storeEntities","processedEntity","id","env","NODE_ENV","error","Error","JSON","stringify","status","entityType","some","entity","errorMessage","throwValidationError","push","keys","forEach","hasOwn","defaults","infer","indexes","recurse","entities","_entities$this$key","inferId","denormalize","unvisit","deleted","nextInput","deletedItem","denormalizeOnly","defineProperty","writable","configurable","__defaults","staticProps","_objectWithoutPropertiesLoose","_excluded","set","enumerable","CLASSNAMEMANGLING","get","console","indexFromParams","params","find","index","includes","indexName"],"sources":["../../src/schemas/EntitySchema.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\nimport type { Schema, NormalizedIndex, UnvisitFunction } from '../interface.js';\nimport { AbstractInstanceType } from '../normal.js';\n\nexport type Constructor = abstract new (...args: any[]) => {};\nexport type IDClass = abstract new (...args: any[]) => {\n  id: string | number | undefined;\n};\nexport type PKClass = abstract new (...args: any[]) => {\n  pk(parent?: any, key?: string, args?: readonly any[]): string | undefined;\n};\n\n// TODO: Figure out what Schema must be for each key\ntype ValidSchemas<TInstance> = { [k in keyof TInstance]?: Schema };\n\nexport type EntityOptions<TInstance extends {}> = {\n  readonly schema?: ValidSchemas<TInstance>;\n  readonly pk?:\n    | ((value: TInstance, parent?: any, key?: string) => string | undefined)\n    | keyof TInstance;\n  readonly key?: string;\n} & {\n  readonly [K in Extract<\n    keyof IEntityClass,\n    | 'process'\n    | 'merge'\n    | 'expiresAt'\n    | 'createIfValid'\n    | 'mergeWithStore'\n    | 'validate'\n    | 'shouldReorder'\n    | 'useIncoming'\n  >]?: IEntityClass<abstract new (...args: any[]) => TInstance>[K];\n};\n\nexport interface RequiredPKOptions<TInstance extends {}>\n  extends EntityOptions<TInstance> {\n  readonly pk:\n    | ((value: TInstance, parent?: any, key?: string) => string | undefined)\n    | keyof TInstance;\n}\n\nexport default function EntitySchema<TBase extends Constructor>(\n  Base: TBase,\n  options: EntityOptions<InstanceType<TBase>> = {},\n) {\n  /**\n   * Represents data that should be deduped by specifying a primary key.\n   * @see https://resthooks.io/docs/api/Entity\n   */\n  abstract class EntityMixin extends Base {\n    static toString() {\n      return this.key;\n    }\n\n    static toJSON() {\n      return {\n        name: this.name,\n        schema: this.schema,\n        key: this.key,\n      };\n    }\n\n    /** Defines nested entities */\n    declare static schema: { [k: string]: Schema };\n\n    /**\n     * A unique identifier for each Entity\n     *\n     * @param [parent] When normalizing, the object which included the entity\n     * @param [key] When normalizing, the key where this entity was found\n     */\n    abstract pk(\n      parent?: any,\n      key?: string,\n      args?: readonly any[],\n    ): string | undefined;\n\n    /** Returns the globally unique identifier for the static Entity */\n    declare static key: string;\n    // default implementation in class static block at bottom of definition\n\n    /** Defines indexes to enable lookup by */\n    declare static indexes?: readonly string[];\n\n    /**\n     * A unique identifier for each Entity\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#pk\n     * @param [value] POJO of the entity or subset used\n     * @param [parent] When normalizing, the object which included the entity\n     * @param [key] When normalizing, the key where this entity was found\n     */\n    static pk<T extends typeof EntityMixin>(\n      this: T,\n      value: Partial<AbstractInstanceType<T>>,\n      parent?: any,\n      key?: string,\n      args?: readonly any[],\n    ): string | undefined {\n      return this.prototype.pk.call(value, parent, key, args);\n    }\n\n    /** Return true to merge incoming data; false keeps existing entity\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n     */\n    static useIncoming(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return true;\n    }\n\n    /** Determines the order of incoming entity vs entity already in store\\\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#shouldReorder\n     * @returns true if incoming entity should be first argument of merge()\n     */\n    static shouldReorder(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return incomingMeta.fetchedAt < existingMeta.fetchedAt;\n    }\n\n    /** Creates new instance copying over defined values of arguments\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#merge\n     */\n    static merge(existing: any, incoming: any) {\n      return {\n        ...existing,\n        ...incoming,\n      };\n    }\n\n    /** Run when an existing entity is found in the store\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#mergeWithStore\n     */\n    static mergeWithStore(\n      existingMeta: {\n        date: number;\n        fetchedAt: number;\n      },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      const useIncoming = this.useIncoming(\n        existingMeta,\n        incomingMeta,\n        existing,\n        incoming,\n      );\n\n      if (useIncoming) {\n        // distinct types are not mergeable (like delete symbol), so just replace\n        if (typeof incoming !== typeof existing) {\n          return incoming;\n        } else {\n          return this.shouldReorder(\n            existingMeta,\n            incomingMeta,\n            existing,\n            incoming,\n          )\n            ? this.merge(incoming, existing)\n            : this.merge(existing, incoming);\n        }\n      } else {\n        return existing;\n      }\n    }\n\n    /** Run when an existing entity is found in the store\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#mergeMetaWithStore\n     */\n    static mergeMetaWithStore(\n      existingMeta: {\n        expiresAt: number;\n        date: number;\n        fetchedAt: number;\n      },\n      incomingMeta: { expiresAt: number; date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return this.shouldReorder(existingMeta, incomingMeta, existing, incoming)\n        ? existingMeta\n        : incomingMeta;\n    }\n\n    /** Factory method to convert from Plain JS Objects.\n     *\n     * @param [props] Plain Object of properties to assign.\n     */\n    static fromJS<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>> = {},\n    ): AbstractInstanceType<T> {\n      // we type guarded abstract case above, so ok to force typescript to allow constructor call\n      const instance = new (this as any)(props) as AbstractInstanceType<T>;\n      // we can't rely on constructors and override the defaults provided as property assignments\n      // all occur after the constructor\n      Object.assign(instance, props);\n      return instance;\n    }\n\n    /** Called when denormalizing an entity to create an instance when 'valid'\n     *\n     * @param [props] Plain Object of properties to assign.\n     * @see https://resthooks.io/docs/api/schema.Entity#createIfValid\n     */\n    static createIfValid<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>>,\n    ): AbstractInstanceType<T> | undefined {\n      if (this.validate(props)) {\n        return undefined as any;\n      }\n      return this.fromJS(props);\n    }\n\n    /** Do any transformations when first receiving input\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#process\n     */\n    static process(input: any, parent: any, key: string | undefined): any {\n      return { ...input };\n    }\n\n    static normalize(\n      input: any,\n      parent: any,\n      key: string | undefined,\n      visit: (...args: any) => any,\n      addEntity: (...args: any) => any,\n      visitedEntities: Record<string, any>,\n      storeEntities: any,\n      args?: readonly any[],\n    ): any {\n      const processedEntity = this.process(input, parent, key);\n      const id = this.pk(processedEntity, parent, key, args);\n      if (id === undefined || id === '') {\n        if (process.env.NODE_ENV !== 'production') {\n          const error = new Error(\n            `Missing usable primary key when normalizing response.\n\n  This is likely due to a malformed response.\n  Try inspecting the network response or fetch() return value.\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about primary keys: https://resthooks.io/rest/api/Entity#pk\n\n  Entity: ${this.name}\n  Value (processed): ${\n    processedEntity && JSON.stringify(processedEntity, null, 2)\n  }\n  `,\n          );\n          (error as any).status = 400;\n          throw error;\n        } else {\n          // these make the keys get deleted; return undefined\n          return;\n        }\n      }\n      const entityType = this.key;\n\n      if (!(entityType in visitedEntities)) {\n        visitedEntities[entityType] = {};\n      }\n      if (!(id in visitedEntities[entityType])) {\n        visitedEntities[entityType][id] = [];\n      }\n      if (\n        visitedEntities[entityType][id].some((entity: any) => entity === input)\n      ) {\n        return id;\n      }\n      const errorMessage = this.validate(processedEntity);\n      throwValidationError(errorMessage);\n\n      visitedEntities[entityType][id].push(input);\n\n      Object.keys(this.schema).forEach(key => {\n        if (Object.hasOwn(processedEntity, key)) {\n          const schema = this.schema[key];\n          processedEntity[key] = visit(\n            processedEntity[key],\n            processedEntity,\n            key,\n            schema,\n            addEntity,\n            visitedEntities,\n            storeEntities,\n            args,\n          );\n        }\n      });\n\n      addEntity(this, processedEntity, id);\n      return id;\n    }\n\n    static validate(processedEntity: any): string | undefined {\n      if (process.env.NODE_ENV !== 'production') {\n        for (const key of Object.keys(this.schema)) {\n          if (!Object.hasOwn(processedEntity, key)) {\n            if (!Object.hasOwn(this.defaults, key)) {\n              return `Schema key is missing in Entity\n\n  Be sure all schema members are also part of the entity\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about nesting schemas: https://resthooks.io/rest/guides/relational-data\n\n  Entity keys: ${Object.keys(this.defaults)}\n  Schema key(missing): ${key}\n  `;\n            }\n          }\n        }\n      }\n    }\n\n    static infer(\n      args: readonly any[],\n      indexes: NormalizedIndex,\n      recurse: any,\n      entities: any,\n    ): any {\n      if (!args[0]) return undefined;\n      const id = inferId(this, args, indexes);\n      // no entity arg is back-compatibility\n      if (!entities || entities[this.key]?.[id]) return id;\n      return undefined;\n    }\n\n    static denormalize<T extends typeof EntityMixin>(\n      this: T,\n      input: any,\n      unvisit: UnvisitFunction,\n    ): [\n      denormalized: AbstractInstanceType<T>,\n      found: boolean,\n      suspend: boolean,\n    ] {\n      // TODO: remove codecov ignore once denormalize is modified to expect this\n      /* istanbul ignore if */\n      if (typeof input === 'symbol') {\n        return [undefined, true, true] as any;\n      }\n\n      let deleted = false;\n      // note: iteration order must be stable\n      Object.keys(this.schema).forEach(key => {\n        const schema = this.schema[key];\n        const nextInput = (input as any)[key];\n        const [value, , deletedItem] = unvisit(nextInput, schema);\n\n        if (deletedItem && !!this.defaults[key]) {\n          deleted = true;\n        }\n        input[key] = value;\n      });\n\n      return [input, true, deleted];\n    }\n\n    static denormalizeOnly<T extends typeof EntityMixin>(\n      this: T,\n      input: any,\n      args: any[],\n      unvisit: (input: any, schema: any) => any,\n    ): AbstractInstanceType<T> {\n      if (typeof input === 'symbol') {\n        return input as any;\n      }\n\n      // note: iteration order must be stable\n      for (const key of Object.keys(this.schema)) {\n        const schema = this.schema[key];\n        const value = unvisit(input[key], schema);\n\n        if (typeof value === 'symbol') {\n          // if default is not 'fasly', then this is required, so propagate INVALID symbol\n          if (this.defaults[key]) {\n            return value as any;\n          }\n          input[key] = undefined;\n        } else {\n          input[key] = value;\n        }\n      }\n      return input;\n    }\n\n    /** All instance defaults set */\n    static get defaults() {\n      // we use hasOwn because we don't want to use a parents' defaults\n      if (!Object.hasOwn(this, '__defaults'))\n        Object.defineProperty(this, '__defaults', {\n          value: new (this as any)(),\n          writable: true,\n          configurable: true,\n        });\n      return (this as any).__defaults;\n    }\n  }\n\n  const { pk, schema, key, ...staticProps } = options;\n  // remaining options\n  Object.assign(EntityMixin, staticProps);\n\n  if ('schema' in options) {\n    EntityMixin.schema = options.schema as any;\n  } else if (!(Base as any).schema) {\n    EntityMixin.schema = {};\n  }\n  if ('pk' in options) {\n    if (typeof options.pk === 'function') {\n      EntityMixin.prototype.pk = function (parent?: any, key?: string) {\n        return (options.pk as any)(this, parent, key);\n      };\n    } else {\n      EntityMixin.prototype.pk = function () {\n        return this[options.pk];\n      };\n    }\n    // default to 'id' field if the base class doesn't have a pk\n  } else if (typeof Base.prototype.pk !== 'function') {\n    EntityMixin.prototype.pk = function () {\n      return this.id;\n    };\n  }\n  if ('key' in options) {\n    Object.defineProperty(EntityMixin, 'key', {\n      value: options.key,\n      configurable: true,\n      writable: true,\n    });\n  } else if (!('key' in Base)) {\n    // this allows assignment in strict-mode\n    // eslint-disable-next-line no-inner-declarations\n    function set(this: any, value: string) {\n      Object.defineProperty(this, 'key', {\n        value,\n        writable: true,\n        enumerable: true,\n      });\n    }\n    const CLASSNAMEMANGLING = EntityMixin.name !== 'EntityMixin';\n    const get =\n      /* istanbul ignore if */\n      CLASSNAMEMANGLING\n        ? /* istanbul ignore next */ function (this: {\n            name: string;\n            key: string;\n          }): string {\n            const name = this.name === 'EntityMixin' ? Base.name : this.name;\n            console.error('Rest Hooks Error: https://resthooks.io/errors/dklj');\n            Object.defineProperty(this, 'key', {\n              get() {\n                return name;\n              },\n              set,\n            });\n            return this.key;\n          }\n        : function (this: { name: string }): string {\n            const name = this.name === 'EntityMixin' ? Base.name : this.name;\n            /* istanbul ignore next */\n            if (\n              process.env.NODE_ENV !== 'production' &&\n              (name === '' || name === 'EntityMixin' || name === '_temp')\n            )\n              throw new Error(\n                'Entity classes without a name must define `static key`\\nSee: https://resthooks.io/rest/api/Entity#key',\n              );\n            return name;\n          };\n\n    Object.defineProperty(EntityMixin, 'key', {\n      get,\n      set,\n    });\n  }\n\n  return EntityMixin as any;\n}\n\nfunction indexFromParams<I extends string>(\n  params: Readonly<object>,\n  indexes?: Readonly<I[]>,\n) {\n  if (!indexes) return undefined;\n  return indexes.find(index => Object.hasOwn(params, index));\n}\n\n// part of the reason for pulling this out is that all functions that throw are deoptimized\nfunction throwValidationError(errorMessage: string | undefined) {\n  if (errorMessage) {\n    const error = new Error(errorMessage);\n    (error as any).status = 400;\n    throw error;\n  }\n}\n\nexport interface IEntityClass<TBase extends Constructor = any> {\n  toJSON(): {\n    name: string;\n    schema: {\n      [k: string]: Schema;\n    };\n    key: string;\n  };\n  /** Defines nested entities\n   *\n   * @see https://resthooks.io/rest/api/Entity#schema\n   */\n  schema: {\n    [k: string]: Schema;\n  };\n  /** Returns the globally unique identifier for the static Entity\n   *\n   * @see https://resthooks.io/docs/api/Entity#key\n   */\n  key: string;\n  /** Defines indexes to enable lookup by\n   *\n   * @see https://resthooks.io/rest/api/Entity#indexes\n   */\n  indexes?: readonly string[] | undefined;\n  /**\n   * A unique identifier for each Entity\n   *\n   * @see https://resthooks.io/docs/api/Entity#pk\n   * @param [value] POJO of the entity or subset used\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  pk<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    value: Partial<AbstractInstanceType<T>>,\n    parent?: any,\n    key?: string,\n    args?: any[],\n  ): string | undefined;\n  /** Return true to merge incoming data; false keeps existing entity\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n   */\n  useIncoming(\n    existingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    existing: any,\n    incoming: any,\n  ): boolean;\n  /** Determines the order of incoming entity vs entity already in store\\\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#shouldReorder\n   * @returns true if incoming entity should be first argument of merge()\n   */\n  shouldReorder(\n    existingMeta: { date: number; fetchedAt: number },\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ): boolean;\n  /** Creates new instance copying over defined values of arguments\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#merge\n   */\n  merge(existing: any, incoming: any): any;\n  /** Run when an existing entity is found in the store\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#mergeWithStore\n   */\n  mergeWithStore(\n    existingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    existing: any,\n    incoming: any,\n  ): any;\n  /** Run when an existing entity is found in the store\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#mergeMetaWithStore\n   */\n  mergeMetaWithStore(\n    existingMeta: {\n      expiresAt: number;\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: { expiresAt: number; date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ): {\n    expiresAt: number;\n    date: number;\n    fetchedAt: number;\n  };\n  /** Factory method to convert from Plain JS Objects.\n   *\n   * @param [props] Plain Object of properties to assign.\n   */\n  fromJS<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    props?: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T>;\n  /** Called when denormalizing an entity to create an instance when 'valid'\n   *\n   * @param [props] Plain Object of properties to assign.\n   * @see https://resthooks.io/docs/api/Entity#createIfValid\n   */\n  createIfValid<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    props: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T> | undefined;\n  /** Do any transformations when first receiving input\n   *\n   * @see https://resthooks.io/docs/api/Entity#process\n   */\n  process(input: any, parent: any, key: string | undefined): any;\n  normalize(\n    input: any,\n    parent: any,\n    key: string | undefined,\n    visit: (...args: any) => any,\n    addEntity: (...args: any) => any,\n    visitedEntities: Record<string, any>,\n  ): any;\n  /** Do any transformations when first receiving input\n   *\n   * @see https://resthooks.io/docs/api/Entity#validate\n   */\n  validate(processedEntity: any): string | undefined;\n  /** Attempts to infer results\n   *\n   * @see https://resthooks.io/docs/api/Entity#infer\n   */\n\n  infer(args: readonly any[], indexes: NormalizedIndex, recurse: any): any;\n  denormalize<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    input: any,\n    unvisit: UnvisitFunction,\n  ): [denormalized: AbstractInstanceType<T>, found: boolean, suspend: boolean];\n  denormalizeOnly<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    input: any,\n    unvisit: (input: any, schema: any) => any,\n  ): AbstractInstanceType<T>;\n  /** All instance defaults set */\n  readonly defaults: any;\n  //set(entity: any, key: string, value: any): void;\n}\nexport interface IEntityInstance {\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  pk(parent?: any, key?: string, args?: readonly any[]): string | undefined;\n}\n\nfunction inferId(schema: any, args: readonly any[], indexes: NormalizedIndex) {\n  if (['string', 'number'].includes(typeof args[0])) {\n    return `${args[0]}`;\n  }\n  const id = schema.pk(args[0], undefined, '', args);\n  // Was able to infer the entity's primary key from params\n  if (id !== undefined && id !== '') return id;\n  // now attempt lookup in indexes\n  const indexName = indexFromParams(args[0], schema.indexes);\n  if (indexName && indexes[schema.key]) {\n    // 'as Record<string, any>': indexName can only be found if params is a string key'd object\n    const id =\n      indexes[schema.key][indexName][\n        (args[0] as Record<string, any>)[indexName]\n      ];\n    return id;\n  }\n}\n"],"mappings":"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"} |
@@ -50,2 +50,31 @@ /** | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpc0ltbXV0YWJsZSIsIm9iamVjdCIsImhhc093blByb3BlcnR5IiwiT2JqZWN0IiwiY2FsbCIsIl9tYXAiLCJkZW5vcm1hbGl6ZUltbXV0YWJsZSIsInNjaGVtYSIsImlucHV0IiwidW52aXNpdCIsImZvdW5kIiwiZGVsZXRlZCIsImtleXMiLCJyZWR1Y2UiLCJrZXkiLCJzdHJpbmdLZXkiLCJpdGVtIiwiZm91bmRJdGVtIiwiZGVsZXRlZEl0ZW0iLCJnZXQiLCJoYXMiLCJzZXQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9JbW11dGFibGVVdGlscy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEhlbHBlcnMgdG8gZW5hYmxlIEltbXV0YWJsZSBjb21wYXRpYmlsaXR5ICp3aXRob3V0KiBicmluZ2luZyBpblxuICogdGhlICdpbW11dGFibGUnIHBhY2thZ2UgYXMgYSBkZXBlbmRlbmN5LlxuICovXG5cbi8qKlxuICogQ2hlY2sgaWYgYW4gb2JqZWN0IGlzIGltbXV0YWJsZSBieSBjaGVja2luZyBpZiBpdCBoYXMgYSBrZXkgc3BlY2lmaWNcbiAqIHRvIHRoZSBpbW11dGFibGUgbGlicmFyeS5cbiAqXG4gKiBAcGFyYW0gIHthbnl9IG9iamVjdFxuICogQHJldHVybiB7Ym9vbH1cbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbmV4cG9ydCBmdW5jdGlvbiBpc0ltbXV0YWJsZShvYmplY3Q6IHt9KTogb2JqZWN0IGlzIHtcbiAgZ2V0KGs6IHN0cmluZyk6IGFueTtcbiAgW2s6IHN0cmluZ106IGFueTtcbn0ge1xuICByZXR1cm4gISEoXG4gICAgdHlwZW9mIG9iamVjdC5oYXNPd25Qcm9wZXJ0eSA9PT0gJ2Z1bmN0aW9uJyAmJlxuICAgIChPYmplY3QuaGFzT3duUHJvcGVydHkuY2FsbChvYmplY3QsICdfX293bmVySUQnKSB8fCAvLyBJbW11dGFibGUuTWFwXG4gICAgICAoKG9iamVjdCBhcyBhbnkpLl9tYXAgJiZcbiAgICAgICAgT2JqZWN0Lmhhc093blByb3BlcnR5LmNhbGwoKG9iamVjdCBhcyBhbnkpLl9tYXAsICdfX293bmVySUQnKSkpXG4gICk7IC8vIEltbXV0YWJsZS5SZWNvcmRcbn1cblxuLyoqXG4gKiBEZW5vcm1hbGl6ZSBhbiBpbW11dGFibGUgZW50aXR5LlxuICpcbiAqIEBwYXJhbSAge1NjaGVtYX0gc2NoZW1hXG4gKiBAcGFyYW0gIHtJbW11dGFibGUuTWFwfEltbXV0YWJsZS5SZWNvcmR9IGlucHV0XG4gKiBAcGFyYW0gIHtmdW5jdGlvbn0gdW52aXNpdFxuICogQHBhcmFtICB7ZnVuY3Rpb259IGdldERlbm9ybWFsaXplZEVudGl0eVxuICogQHJldHVybiB7SW1tdXRhYmxlLk1hcHxJbW11dGFibGUuUmVjb3JkfVxuICovXG5leHBvcnQgZnVuY3Rpb24gZGVub3JtYWxpemVJbW11dGFibGUoXG4gIHNjaGVtYTogYW55LFxuICBpbnB1dDogYW55LFxuICB1bnZpc2l0OiBhbnksXG4pOiBbZGVub3JtYWxpemVkOiBhbnksIGZvdW5kOiBib29sZWFuLCBkZWxldGVkOiBib29sZWFuXSB7XG4gIGxldCBmb3VuZCA9IHRydWU7XG4gIGxldCBkZWxldGVkID0gZmFsc2U7XG4gIHJldHVybiBbXG4gICAgT2JqZWN0LmtleXMoc2NoZW1hKS5yZWR1Y2UoKG9iamVjdCwga2V5KSA9PiB7XG4gICAgICAvLyBJbW11dGFibGUgbWFwcyBjYXN0IGtleXMgdG8gc3RyaW5ncyBvbiB3cml0ZSBzbyB3ZSBuZWVkIHRvIGVuc3VyZVxuICAgICAgLy8gd2UncmUgYWNjZXNzaW5nIHRoZW0gdXNpbmcgc3RyaW5nIGtleXMuXG4gICAgICBjb25zdCBzdHJpbmdLZXkgPSBgJHtrZXl9YDtcblxuICAgICAgY29uc3QgW2l0ZW0sIGZvdW5kSXRlbSwgZGVsZXRlZEl0ZW1dID0gdW52aXNpdChcbiAgICAgICAgb2JqZWN0LmdldChzdHJpbmdLZXkpLFxuICAgICAgICBzY2hlbWFbc3RyaW5nS2V5XSxcbiAgICAgICk7XG4gICAgICBpZiAoIWZvdW5kSXRlbSkge1xuICAgICAgICBmb3VuZCA9IGZhbHNlO1xuICAgICAgfVxuICAgICAgaWYgKGRlbGV0ZWRJdGVtKSB7XG4gICAgICAgIGRlbGV0ZWQgPSB0cnVlO1xuICAgICAgfVxuICAgICAgaWYgKG9iamVjdC5oYXMoc3RyaW5nS2V5KSkge1xuICAgICAgICByZXR1cm4gb2JqZWN0LnNldChzdHJpbmdLZXksIGl0ZW0pO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuIG9iamVjdDtcbiAgICAgIH1cbiAgICB9LCBpbnB1dCksXG4gICAgZm91bmQsXG4gICAgZGVsZXRlZCxcbiAgXTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sU0FBU0EsV0FBV0EsQ0FBQ0MsTUFBVSxFQUdwQztFQUNBLE9BQU8sQ0FBQyxFQUNOLE9BQU9BLE1BQU0sQ0FBQ0MsY0FBYyxLQUFLLFVBQVUsS0FDMUNDLE1BQU0sQ0FBQ0QsY0FBYyxDQUFDRSxJQUFJLENBQUNILE1BQU0sRUFBRSxXQUFXLENBQUM7RUFBSTtFQUNoREEsTUFBTSxDQUFTSSxJQUFJLElBQ25CRixNQUFNLENBQUNELGNBQWMsQ0FBQ0UsSUFBSSxDQUFFSCxNQUFNLENBQVNJLElBQUksRUFBRSxXQUFXLENBQUUsQ0FBQyxDQUNwRSxDQUFDLENBQUM7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLFNBQVNDLG9CQUFvQkEsQ0FDbENDLE1BQVcsRUFDWEMsS0FBVSxFQUNWQyxPQUFZLEVBQzJDO0VBQ3ZELElBQUlDLEtBQUssR0FBRyxJQUFJO0VBQ2hCLElBQUlDLE9BQU8sR0FBRyxLQUFLO0VBQ25CLE9BQU8sQ0FDTFIsTUFBTSxDQUFDUyxJQUFJLENBQUNMLE1BQU0sQ0FBQyxDQUFDTSxNQUFNLENBQUMsQ0FBQ1osTUFBTSxFQUFFYSxHQUFHLEtBQUs7SUFDMUM7SUFDQTtJQUNBLE1BQU1DLFNBQVMsR0FBSSxHQUFFRCxHQUFJLEVBQUM7SUFFMUIsTUFBTSxDQUFDRSxJQUFJLEVBQUVDLFNBQVMsRUFBRUMsV0FBVyxDQUFDLEdBQUdULE9BQU8sQ0FDNUNSLE1BQU0sQ0FBQ2tCLEdBQUcsQ0FBQ0osU0FBUyxDQUFDLEVBQ3JCUixNQUFNLENBQUNRLFNBQVMsQ0FBQyxDQUNsQjtJQUNELElBQUksQ0FBQ0UsU0FBUyxFQUFFO01BQ2RQLEtBQUssR0FBRyxLQUFLO0lBQ2Y7SUFDQSxJQUFJUSxXQUFXLEVBQUU7TUFDZlAsT0FBTyxHQUFHLElBQUk7SUFDaEI7SUFDQSxJQUFJVixNQUFNLENBQUNtQixHQUFHLENBQUNMLFNBQVMsQ0FBQyxFQUFFO01BQ3pCLE9BQU9kLE1BQU0sQ0FBQ29CLEdBQUcsQ0FBQ04sU0FBUyxFQUFFQyxJQUFJLENBQUM7SUFDcEMsQ0FBQyxNQUFNO01BQ0wsT0FBT2YsTUFBTTtJQUNmO0VBQ0YsQ0FBQyxFQUFFTyxLQUFLLENBQUMsRUFDVEUsS0FBSyxFQUNMQyxPQUFPLENBQ1I7QUFDSCJ9 | ||
/** | ||
* Denormalize an immutable entity. | ||
* | ||
* @param {Schema} schema | ||
* @param {Immutable.Map|Immutable.Record} input | ||
* @param {function} unvisit | ||
* @param {function} getDenormalizedEntity | ||
* @return {Immutable.Map|Immutable.Record} | ||
*/ | ||
export function denormalizeOnlyImmutable(schema, input, unvisit) { | ||
var _deleted; | ||
let deleted; | ||
const value = Object.keys(schema).reduce((object, key) => { | ||
// Immutable maps cast keys to strings on write so we need to ensure | ||
// we're accessing them using string keys. | ||
const stringKey = `${key}`; | ||
const item = unvisit(object.get(stringKey), schema[stringKey]); | ||
if (typeof item === 'symbol') { | ||
deleted = item; | ||
} | ||
if (object.has(stringKey)) { | ||
return object.set(stringKey, item); | ||
} else { | ||
return object; | ||
} | ||
}, input); | ||
return (_deleted = deleted) != null ? _deleted : value; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpc0ltbXV0YWJsZSIsIm9iamVjdCIsImhhc093blByb3BlcnR5IiwiT2JqZWN0IiwiY2FsbCIsIl9tYXAiLCJkZW5vcm1hbGl6ZUltbXV0YWJsZSIsInNjaGVtYSIsImlucHV0IiwidW52aXNpdCIsImZvdW5kIiwiZGVsZXRlZCIsImtleXMiLCJyZWR1Y2UiLCJrZXkiLCJzdHJpbmdLZXkiLCJpdGVtIiwiZm91bmRJdGVtIiwiZGVsZXRlZEl0ZW0iLCJnZXQiLCJoYXMiLCJzZXQiLCJkZW5vcm1hbGl6ZU9ubHlJbW11dGFibGUiLCJfZGVsZXRlZCIsInZhbHVlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvSW1tdXRhYmxlVXRpbHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBIZWxwZXJzIHRvIGVuYWJsZSBJbW11dGFibGUgY29tcGF0aWJpbGl0eSAqd2l0aG91dCogYnJpbmdpbmcgaW5cbiAqIHRoZSAnaW1tdXRhYmxlJyBwYWNrYWdlIGFzIGEgZGVwZW5kZW5jeS5cbiAqL1xuXG4vKipcbiAqIENoZWNrIGlmIGFuIG9iamVjdCBpcyBpbW11dGFibGUgYnkgY2hlY2tpbmcgaWYgaXQgaGFzIGEga2V5IHNwZWNpZmljXG4gKiB0byB0aGUgaW1tdXRhYmxlIGxpYnJhcnkuXG4gKlxuICogQHBhcmFtICB7YW55fSBvYmplY3RcbiAqIEByZXR1cm4ge2Jvb2x9XG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG5leHBvcnQgZnVuY3Rpb24gaXNJbW11dGFibGUob2JqZWN0OiB7fSk6IG9iamVjdCBpcyB7XG4gIGdldChrOiBzdHJpbmcpOiBhbnk7XG4gIFtrOiBzdHJpbmddOiBhbnk7XG59IHtcbiAgcmV0dXJuICEhKFxuICAgIHR5cGVvZiBvYmplY3QuaGFzT3duUHJvcGVydHkgPT09ICdmdW5jdGlvbicgJiZcbiAgICAoT2JqZWN0Lmhhc093blByb3BlcnR5LmNhbGwob2JqZWN0LCAnX19vd25lcklEJykgfHwgLy8gSW1tdXRhYmxlLk1hcFxuICAgICAgKChvYmplY3QgYXMgYW55KS5fbWFwICYmXG4gICAgICAgIE9iamVjdC5oYXNPd25Qcm9wZXJ0eS5jYWxsKChvYmplY3QgYXMgYW55KS5fbWFwLCAnX19vd25lcklEJykpKVxuICApOyAvLyBJbW11dGFibGUuUmVjb3JkXG59XG5cbi8qKlxuICogRGVub3JtYWxpemUgYW4gaW1tdXRhYmxlIGVudGl0eS5cbiAqXG4gKiBAcGFyYW0gIHtTY2hlbWF9IHNjaGVtYVxuICogQHBhcmFtICB7SW1tdXRhYmxlLk1hcHxJbW11dGFibGUuUmVjb3JkfSBpbnB1dFxuICogQHBhcmFtICB7ZnVuY3Rpb259IHVudmlzaXRcbiAqIEBwYXJhbSAge2Z1bmN0aW9ufSBnZXREZW5vcm1hbGl6ZWRFbnRpdHlcbiAqIEByZXR1cm4ge0ltbXV0YWJsZS5NYXB8SW1tdXRhYmxlLlJlY29yZH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGRlbm9ybWFsaXplSW1tdXRhYmxlKFxuICBzY2hlbWE6IGFueSxcbiAgaW5wdXQ6IGFueSxcbiAgdW52aXNpdDogYW55LFxuKTogW2Rlbm9ybWFsaXplZDogYW55LCBmb3VuZDogYm9vbGVhbiwgZGVsZXRlZDogYm9vbGVhbl0ge1xuICBsZXQgZm91bmQgPSB0cnVlO1xuICBsZXQgZGVsZXRlZCA9IGZhbHNlO1xuICByZXR1cm4gW1xuICAgIE9iamVjdC5rZXlzKHNjaGVtYSkucmVkdWNlKChvYmplY3QsIGtleSkgPT4ge1xuICAgICAgLy8gSW1tdXRhYmxlIG1hcHMgY2FzdCBrZXlzIHRvIHN0cmluZ3Mgb24gd3JpdGUgc28gd2UgbmVlZCB0byBlbnN1cmVcbiAgICAgIC8vIHdlJ3JlIGFjY2Vzc2luZyB0aGVtIHVzaW5nIHN0cmluZyBrZXlzLlxuICAgICAgY29uc3Qgc3RyaW5nS2V5ID0gYCR7a2V5fWA7XG5cbiAgICAgIGNvbnN0IFtpdGVtLCBmb3VuZEl0ZW0sIGRlbGV0ZWRJdGVtXSA9IHVudmlzaXQoXG4gICAgICAgIG9iamVjdC5nZXQoc3RyaW5nS2V5KSxcbiAgICAgICAgc2NoZW1hW3N0cmluZ0tleV0sXG4gICAgICApO1xuICAgICAgaWYgKCFmb3VuZEl0ZW0pIHtcbiAgICAgICAgZm91bmQgPSBmYWxzZTtcbiAgICAgIH1cbiAgICAgIGlmIChkZWxldGVkSXRlbSkge1xuICAgICAgICBkZWxldGVkID0gdHJ1ZTtcbiAgICAgIH1cbiAgICAgIGlmIChvYmplY3QuaGFzKHN0cmluZ0tleSkpIHtcbiAgICAgICAgcmV0dXJuIG9iamVjdC5zZXQoc3RyaW5nS2V5LCBpdGVtKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBvYmplY3Q7XG4gICAgICB9XG4gICAgfSwgaW5wdXQpLFxuICAgIGZvdW5kLFxuICAgIGRlbGV0ZWQsXG4gIF07XG59XG5cbi8qKlxuICogRGVub3JtYWxpemUgYW4gaW1tdXRhYmxlIGVudGl0eS5cbiAqXG4gKiBAcGFyYW0gIHtTY2hlbWF9IHNjaGVtYVxuICogQHBhcmFtICB7SW1tdXRhYmxlLk1hcHxJbW11dGFibGUuUmVjb3JkfSBpbnB1dFxuICogQHBhcmFtICB7ZnVuY3Rpb259IHVudmlzaXRcbiAqIEBwYXJhbSAge2Z1bmN0aW9ufSBnZXREZW5vcm1hbGl6ZWRFbnRpdHlcbiAqIEByZXR1cm4ge0ltbXV0YWJsZS5NYXB8SW1tdXRhYmxlLlJlY29yZH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGRlbm9ybWFsaXplT25seUltbXV0YWJsZShcbiAgc2NoZW1hOiBhbnksXG4gIGlucHV0OiBhbnksXG4gIHVudmlzaXQ6IChpbnB1dDogYW55LCBzY2hlbWE6IGFueSkgPT4gYW55LFxuKTogYW55IHtcbiAgbGV0IGRlbGV0ZWQ7XG4gIGNvbnN0IHZhbHVlID0gT2JqZWN0LmtleXMoc2NoZW1hKS5yZWR1Y2UoKG9iamVjdCwga2V5KSA9PiB7XG4gICAgLy8gSW1tdXRhYmxlIG1hcHMgY2FzdCBrZXlzIHRvIHN0cmluZ3Mgb24gd3JpdGUgc28gd2UgbmVlZCB0byBlbnN1cmVcbiAgICAvLyB3ZSdyZSBhY2Nlc3NpbmcgdGhlbSB1c2luZyBzdHJpbmcga2V5cy5cbiAgICBjb25zdCBzdHJpbmdLZXkgPSBgJHtrZXl9YDtcblxuICAgIGNvbnN0IGl0ZW0gPSB1bnZpc2l0KG9iamVjdC5nZXQoc3RyaW5nS2V5KSwgc2NoZW1hW3N0cmluZ0tleV0pO1xuICAgIGlmICh0eXBlb2YgaXRlbSA9PT0gJ3N5bWJvbCcpIHtcbiAgICAgIGRlbGV0ZWQgPSBpdGVtO1xuICAgIH1cbiAgICBpZiAob2JqZWN0LmhhcyhzdHJpbmdLZXkpKSB7XG4gICAgICByZXR1cm4gb2JqZWN0LnNldChzdHJpbmdLZXksIGl0ZW0pO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gb2JqZWN0O1xuICAgIH1cbiAgfSwgaW5wdXQpO1xuICByZXR1cm4gZGVsZXRlZCA/PyB2YWx1ZTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sU0FBU0EsV0FBV0EsQ0FBQ0MsTUFBVSxFQUdwQztFQUNBLE9BQU8sQ0FBQyxFQUNOLE9BQU9BLE1BQU0sQ0FBQ0MsY0FBYyxLQUFLLFVBQVUsS0FDMUNDLE1BQU0sQ0FBQ0QsY0FBYyxDQUFDRSxJQUFJLENBQUNILE1BQU0sRUFBRSxXQUFXLENBQUM7RUFBSTtFQUNoREEsTUFBTSxDQUFTSSxJQUFJLElBQ25CRixNQUFNLENBQUNELGNBQWMsQ0FBQ0UsSUFBSSxDQUFFSCxNQUFNLENBQVNJLElBQUksRUFBRSxXQUFXLENBQUUsQ0FBQyxDQUNwRSxDQUFDLENBQUM7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLFNBQVNDLG9CQUFvQkEsQ0FDbENDLE1BQVcsRUFDWEMsS0FBVSxFQUNWQyxPQUFZLEVBQzJDO0VBQ3ZELElBQUlDLEtBQUssR0FBRyxJQUFJO0VBQ2hCLElBQUlDLE9BQU8sR0FBRyxLQUFLO0VBQ25CLE9BQU8sQ0FDTFIsTUFBTSxDQUFDUyxJQUFJLENBQUNMLE1BQU0sQ0FBQyxDQUFDTSxNQUFNLENBQUMsQ0FBQ1osTUFBTSxFQUFFYSxHQUFHLEtBQUs7SUFDMUM7SUFDQTtJQUNBLE1BQU1DLFNBQVMsR0FBSSxHQUFFRCxHQUFJLEVBQUM7SUFFMUIsTUFBTSxDQUFDRSxJQUFJLEVBQUVDLFNBQVMsRUFBRUMsV0FBVyxDQUFDLEdBQUdULE9BQU8sQ0FDNUNSLE1BQU0sQ0FBQ2tCLEdBQUcsQ0FBQ0osU0FBUyxDQUFDLEVBQ3JCUixNQUFNLENBQUNRLFNBQVMsQ0FBQyxDQUNsQjtJQUNELElBQUksQ0FBQ0UsU0FBUyxFQUFFO01BQ2RQLEtBQUssR0FBRyxLQUFLO0lBQ2Y7SUFDQSxJQUFJUSxXQUFXLEVBQUU7TUFDZlAsT0FBTyxHQUFHLElBQUk7SUFDaEI7SUFDQSxJQUFJVixNQUFNLENBQUNtQixHQUFHLENBQUNMLFNBQVMsQ0FBQyxFQUFFO01BQ3pCLE9BQU9kLE1BQU0sQ0FBQ29CLEdBQUcsQ0FBQ04sU0FBUyxFQUFFQyxJQUFJLENBQUM7SUFDcEMsQ0FBQyxNQUFNO01BQ0wsT0FBT2YsTUFBTTtJQUNmO0VBQ0YsQ0FBQyxFQUFFTyxLQUFLLENBQUMsRUFDVEUsS0FBSyxFQUNMQyxPQUFPLENBQ1I7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLFNBQVNXLHdCQUF3QkEsQ0FDdENmLE1BQVcsRUFDWEMsS0FBVSxFQUNWQyxPQUF5QyxFQUNwQztFQUFBLElBQUFjLFFBQUE7RUFDTCxJQUFJWixPQUFPO0VBQ1gsTUFBTWEsS0FBSyxHQUFHckIsTUFBTSxDQUFDUyxJQUFJLENBQUNMLE1BQU0sQ0FBQyxDQUFDTSxNQUFNLENBQUMsQ0FBQ1osTUFBTSxFQUFFYSxHQUFHLEtBQUs7SUFDeEQ7SUFDQTtJQUNBLE1BQU1DLFNBQVMsR0FBSSxHQUFFRCxHQUFJLEVBQUM7SUFFMUIsTUFBTUUsSUFBSSxHQUFHUCxPQUFPLENBQUNSLE1BQU0sQ0FBQ2tCLEdBQUcsQ0FBQ0osU0FBUyxDQUFDLEVBQUVSLE1BQU0sQ0FBQ1EsU0FBUyxDQUFDLENBQUM7SUFDOUQsSUFBSSxPQUFPQyxJQUFJLEtBQUssUUFBUSxFQUFFO01BQzVCTCxPQUFPLEdBQUdLLElBQUk7SUFDaEI7SUFDQSxJQUFJZixNQUFNLENBQUNtQixHQUFHLENBQUNMLFNBQVMsQ0FBQyxFQUFFO01BQ3pCLE9BQU9kLE1BQU0sQ0FBQ29CLEdBQUcsQ0FBQ04sU0FBUyxFQUFFQyxJQUFJLENBQUM7SUFDcEMsQ0FBQyxNQUFNO01BQ0wsT0FBT2YsTUFBTTtJQUNmO0VBQ0YsQ0FBQyxFQUFFTyxLQUFLLENBQUM7RUFDVCxRQUFBZSxRQUFBLEdBQU9aLE9BQU8sWUFBQVksUUFBQSxHQUFJQyxLQUFLO0FBQ3pCIn0= |
@@ -1,7 +0,7 @@ | ||
import { isImmutable, denormalizeImmutable } from './ImmutableUtils.js'; | ||
export const normalize = (schema, input, parent, key, visit, addEntity, visitedEntities) => { | ||
import { isImmutable, denormalizeImmutable, denormalizeOnlyImmutable } from './ImmutableUtils.js'; | ||
export const normalize = (schema, input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) => { | ||
const object = Object.assign({}, input); | ||
Object.keys(schema).forEach(key => { | ||
const localSchema = schema[key]; | ||
const value = visit(input[key], input, key, localSchema, addEntity, visitedEntities); | ||
const value = visit(input[key], input, key, localSchema, addEntity, visitedEntities, storeEntities, args); | ||
if (value === undefined || value === null) { | ||
@@ -36,2 +36,18 @@ delete object[key]; | ||
}; | ||
export function denormalizeOnly(schema, input, args, unvisit) { | ||
if (isImmutable(input)) { | ||
return denormalizeOnlyImmutable(schema, input, unvisit); | ||
} | ||
const object = Object.assign({}, input); | ||
for (const key of Object.keys(schema)) { | ||
const item = unvisit(object[key], schema[key]); | ||
if (object[key] !== undefined) { | ||
object[key] = item; | ||
} | ||
if (typeof item === 'symbol') { | ||
return item; | ||
} | ||
} | ||
return object; | ||
} | ||
export function infer(schema, args, indexes, recurse, entities) { | ||
@@ -44,3 +60,2 @@ const resultObject = {}; | ||
} | ||
/** | ||
@@ -71,2 +86,5 @@ * Represents objects with statically known members | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return denormalizeOnly(this.schema, input, args, unvisit); | ||
} | ||
infer(args, indexes, recurse, entities) { | ||
@@ -76,2 +94,2 @@ return infer(this.schema, args, indexes, recurse, entities); | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpc0ltbXV0YWJsZSIsImRlbm9ybWFsaXplSW1tdXRhYmxlIiwibm9ybWFsaXplIiwic2NoZW1hIiwiaW5wdXQiLCJwYXJlbnQiLCJrZXkiLCJ2aXNpdCIsImFkZEVudGl0eSIsInZpc2l0ZWRFbnRpdGllcyIsIm9iamVjdCIsIk9iamVjdCIsImFzc2lnbiIsImtleXMiLCJmb3JFYWNoIiwibG9jYWxTY2hlbWEiLCJ2YWx1ZSIsInVuZGVmaW5lZCIsImRlbm9ybWFsaXplIiwidW52aXNpdCIsImZvdW5kIiwiZGVsZXRlZCIsIml0ZW0iLCJmb3VuZEl0ZW0iLCJkZWxldGVkSXRlbSIsImluZmVyIiwiYXJncyIsImluZGV4ZXMiLCJyZWN1cnNlIiwiZW50aXRpZXMiLCJyZXN1bHRPYmplY3QiLCJrIiwiT2JqZWN0U2NoZW1hIiwiY29uc3RydWN0b3IiLCJkZWZpbml0aW9uIiwiZGVmaW5lIiwicmVkdWNlIiwiZW50aXR5U2NoZW1hIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvT2JqZWN0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzSW1tdXRhYmxlLCBkZW5vcm1hbGl6ZUltbXV0YWJsZSB9IGZyb20gJy4vSW1tdXRhYmxlVXRpbHMuanMnO1xuXG5leHBvcnQgY29uc3Qgbm9ybWFsaXplID0gKFxuICBzY2hlbWE6IGFueSxcbiAgaW5wdXQ6IGFueSxcbiAgcGFyZW50OiBhbnksXG4gIGtleTogYW55LFxuICB2aXNpdDogYW55LFxuICBhZGRFbnRpdHk6IGFueSxcbiAgdmlzaXRlZEVudGl0aWVzOiBhbnksXG4pID0+IHtcbiAgY29uc3Qgb2JqZWN0ID0geyAuLi5pbnB1dCB9O1xuICBPYmplY3Qua2V5cyhzY2hlbWEpLmZvckVhY2goa2V5ID0+IHtcbiAgICBjb25zdCBsb2NhbFNjaGVtYSA9IHNjaGVtYVtrZXldO1xuICAgIGNvbnN0IHZhbHVlID0gdmlzaXQoXG4gICAgICBpbnB1dFtrZXldLFxuICAgICAgaW5wdXQsXG4gICAgICBrZXksXG4gICAgICBsb2NhbFNjaGVtYSxcbiAgICAgIGFkZEVudGl0eSxcbiAgICAgIHZpc2l0ZWRFbnRpdGllcyxcbiAgICApO1xuICAgIGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkIHx8IHZhbHVlID09PSBudWxsKSB7XG4gICAgICBkZWxldGUgb2JqZWN0W2tleV07XG4gICAgfSBlbHNlIHtcbiAgICAgIG9iamVjdFtrZXldID0gdmFsdWU7XG4gICAgfVxuICB9KTtcbiAgcmV0dXJuIG9iamVjdDtcbn07XG5cbmV4cG9ydCBjb25zdCBkZW5vcm1hbGl6ZSA9IChcbiAgc2NoZW1hOiBhbnksXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG4gIGlucHV0OiB7fSxcbiAgdW52aXNpdDogYW55LFxuKTogW2Rlbm9ybWFsaXplZDogYW55LCBmb3VuZDogYm9vbGVhbiwgZGVsZXRlZDogYm9vbGVhbl0gPT4ge1xuICBpZiAoaXNJbW11dGFibGUoaW5wdXQpKSB7XG4gICAgcmV0dXJuIGRlbm9ybWFsaXplSW1tdXRhYmxlKHNjaGVtYSwgaW5wdXQsIHVudmlzaXQpO1xuICB9XG5cbiAgY29uc3Qgb2JqZWN0OiBSZWNvcmQ8c3RyaW5nLCBhbnk+ID0geyAuLi5pbnB1dCB9O1xuICBsZXQgZm91bmQgPSB0cnVlO1xuICBsZXQgZGVsZXRlZCA9IGZhbHNlO1xuICBPYmplY3Qua2V5cyhzY2hlbWEpLmZvckVhY2goa2V5ID0+IHtcbiAgICBjb25zdCBbaXRlbSwgZm91bmRJdGVtLCBkZWxldGVkSXRlbV0gPSB1bnZpc2l0KG9iamVjdFtrZXldLCBzY2hlbWFba2V5XSk7XG4gICAgaWYgKG9iamVjdFtrZXldICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIG9iamVjdFtrZXldID0gaXRlbTtcbiAgICB9XG4gICAgaWYgKGRlbGV0ZWRJdGVtKSB7XG4gICAgICBkZWxldGVkID0gdHJ1ZTtcbiAgICB9XG4gICAgaWYgKCFmb3VuZEl0ZW0pIHtcbiAgICAgIGZvdW5kID0gZmFsc2U7XG4gICAgfVxuICB9KTtcbiAgcmV0dXJuIFtvYmplY3QsIGZvdW5kLCBkZWxldGVkXTtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBpbmZlcihcbiAgc2NoZW1hOiBhbnksXG4gIGFyZ3M6IHJlYWRvbmx5IGFueVtdLFxuICBpbmRleGVzOiBhbnksXG4gIHJlY3Vyc2U6IGFueSxcbiAgZW50aXRpZXM6IGFueSxcbikge1xuICBjb25zdCByZXN1bHRPYmplY3Q6IGFueSA9IHt9O1xuICBPYmplY3Qua2V5cyhzY2hlbWEpLmZvckVhY2goayA9PiB7XG4gICAgcmVzdWx0T2JqZWN0W2tdID0gcmVjdXJzZShzY2hlbWFba10sIGFyZ3MsIGluZGV4ZXMsIGVudGl0aWVzKTtcbiAgfSk7XG4gIHJldHVybiByZXN1bHRPYmplY3Q7XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyBvYmplY3RzIHdpdGggc3RhdGljYWxseSBrbm93biBtZW1iZXJzXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL3Jlc3QvYXBpL09iamVjdFxuICovXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBPYmplY3RTY2hlbWEge1xuICBwcm90ZWN0ZWQgc2NoZW1hOiBhbnk7XG5cbiAgY29uc3RydWN0b3IoZGVmaW5pdGlvbjogUmVjb3JkPHN0cmluZywgYW55Pikge1xuICAgIHRoaXMuZGVmaW5lKGRlZmluaXRpb24pO1xuICB9XG5cbiAgZGVmaW5lKGRlZmluaXRpb246IFJlY29yZDxzdHJpbmcsIGFueT4pIHtcbiAgICB0aGlzLnNjaGVtYSA9IE9iamVjdC5rZXlzKGRlZmluaXRpb24pLnJlZHVjZSgoZW50aXR5U2NoZW1hLCBrZXkpID0+IHtcbiAgICAgIGNvbnN0IHNjaGVtYSA9IGRlZmluaXRpb25ba2V5XTtcbiAgICAgIHJldHVybiB7IC4uLmVudGl0eVNjaGVtYSwgW2tleV06IHNjaGVtYSB9O1xuICAgIH0sIHRoaXMuc2NoZW1hIHx8IHt9KTtcbiAgfVxuXG4gIG5vcm1hbGl6ZShcbiAgICAuLi5hcmdzOiByZWFkb25seSBbXG4gICAgICBpbnB1dDogYW55LFxuICAgICAgcGFyZW50OiBhbnksXG4gICAgICBrZXk6IGFueSxcbiAgICAgIHZpc2l0OiBhbnksXG4gICAgICBhZGRFbnRpdHk6IGFueSxcbiAgICAgIHZpc2l0ZWRFbnRpdGllczogYW55LFxuICAgIF1cbiAgKSB7XG4gICAgcmV0dXJuIG5vcm1hbGl6ZSh0aGlzLnNjaGVtYSwgLi4uYXJncyk7XG4gIH1cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuICBkZW5vcm1hbGl6ZSguLi5hcmdzOiByZWFkb25seSBbaW5wdXQ6IHt9LCB1bnZpc2l0OiBhbnldKSB7XG4gICAgcmV0dXJuIGRlbm9ybWFsaXplKHRoaXMuc2NoZW1hLCAuLi5hcmdzKTtcbiAgfVxuXG4gIGluZmVyKGFyZ3M6IGFueSwgaW5kZXhlczogYW55LCByZWN1cnNlOiBhbnksIGVudGl0aWVzOiBhbnkpIHtcbiAgICByZXR1cm4gaW5mZXIodGhpcy5zY2hlbWEsIGFyZ3MsIGluZGV4ZXMsIHJlY3Vyc2UsIGVudGl0aWVzKTtcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxXQUFXLEVBQUVDLG9CQUFvQixRQUFRLHFCQUFxQjtBQUV2RSxPQUFPLE1BQU1DLFNBQVMsR0FBR0EsQ0FDdkJDLE1BQVcsRUFDWEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEtBQ2pCO0VBQ0gsTUFBTUMsTUFBTSxHQUFBQyxNQUFBLENBQUFDLE1BQUEsS0FBUVIsS0FBSyxDQUFFO0VBQzNCTyxNQUFNLENBQUNFLElBQUksQ0FBQ1YsTUFBTSxDQUFDLENBQUNXLE9BQU8sQ0FBQ1IsR0FBRyxJQUFJO0lBQ2pDLE1BQU1TLFdBQVcsR0FBR1osTUFBTSxDQUFDRyxHQUFHLENBQUM7SUFDL0IsTUFBTVUsS0FBSyxHQUFHVCxLQUFLLENBQ2pCSCxLQUFLLENBQUNFLEdBQUcsQ0FBQyxFQUNWRixLQUFLLEVBQ0xFLEdBQUcsRUFDSFMsV0FBVyxFQUNYUCxTQUFTLEVBQ1RDLGVBQWUsQ0FDaEI7SUFDRCxJQUFJTyxLQUFLLEtBQUtDLFNBQVMsSUFBSUQsS0FBSyxLQUFLLElBQUksRUFBRTtNQUN6QyxPQUFPTixNQUFNLENBQUNKLEdBQUcsQ0FBQztJQUNwQixDQUFDLE1BQU07TUFDTEksTUFBTSxDQUFDSixHQUFHLENBQUMsR0FBR1UsS0FBSztJQUNyQjtFQUNGLENBQUMsQ0FBQztFQUNGLE9BQU9OLE1BQU07QUFDZixDQUFDO0FBRUQsT0FBTyxNQUFNUSxXQUFXLEdBQUdBLENBQ3pCZixNQUFXLEVBRVhDLEtBQVMsRUFDVGUsT0FBWSxLQUM4QztFQUMxRCxJQUFJbkIsV0FBVyxDQUFDSSxLQUFLLENBQUMsRUFBRTtJQUN0QixPQUFPSCxvQkFBb0IsQ0FBQ0UsTUFBTSxFQUFFQyxLQUFLLEVBQUVlLE9BQU8sQ0FBQztFQUNyRDtFQUVBLE1BQU1ULE1BQTJCLEdBQUFDLE1BQUEsQ0FBQUMsTUFBQSxLQUFRUixLQUFLLENBQUU7RUFDaEQsSUFBSWdCLEtBQUssR0FBRyxJQUFJO0VBQ2hCLElBQUlDLE9BQU8sR0FBRyxLQUFLO0VBQ25CVixNQUFNLENBQUNFLElBQUksQ0FBQ1YsTUFBTSxDQUFDLENBQUNXLE9BQU8sQ0FBQ1IsR0FBRyxJQUFJO0lBQ2pDLE1BQU0sQ0FBQ2dCLElBQUksRUFBRUMsU0FBUyxFQUFFQyxXQUFXLENBQUMsR0FBR0wsT0FBTyxDQUFDVCxNQUFNLENBQUNKLEdBQUcsQ0FBQyxFQUFFSCxNQUFNLENBQUNHLEdBQUcsQ0FBQyxDQUFDO0lBQ3hFLElBQUlJLE1BQU0sQ0FBQ0osR0FBRyxDQUFDLEtBQUtXLFNBQVMsRUFBRTtNQUM3QlAsTUFBTSxDQUFDSixHQUFHLENBQUMsR0FBR2dCLElBQUk7SUFDcEI7SUFDQSxJQUFJRSxXQUFXLEVBQUU7TUFDZkgsT0FBTyxHQUFHLElBQUk7SUFDaEI7SUFDQSxJQUFJLENBQUNFLFNBQVMsRUFBRTtNQUNkSCxLQUFLLEdBQUcsS0FBSztJQUNmO0VBQ0YsQ0FBQyxDQUFDO0VBQ0YsT0FBTyxDQUFDVixNQUFNLEVBQUVVLEtBQUssRUFBRUMsT0FBTyxDQUFDO0FBQ2pDLENBQUM7QUFFRCxPQUFPLFNBQVNJLEtBQUtBLENBQ25CdEIsTUFBVyxFQUNYdUIsSUFBb0IsRUFDcEJDLE9BQVksRUFDWkMsT0FBWSxFQUNaQyxRQUFhLEVBQ2I7RUFDQSxNQUFNQyxZQUFpQixHQUFHLENBQUMsQ0FBQztFQUM1Qm5CLE1BQU0sQ0FBQ0UsSUFBSSxDQUFDVixNQUFNLENBQUMsQ0FBQ1csT0FBTyxDQUFDaUIsQ0FBQyxJQUFJO0lBQy9CRCxZQUFZLENBQUNDLENBQUMsQ0FBQyxHQUFHSCxPQUFPLENBQUN6QixNQUFNLENBQUM0QixDQUFDLENBQUMsRUFBRUwsSUFBSSxFQUFFQyxPQUFPLEVBQUVFLFFBQVEsQ0FBQztFQUMvRCxDQUFDLENBQUM7RUFDRixPQUFPQyxZQUFZO0FBQ3JCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNRSxZQUFZLENBQUM7RUFHaENDLFdBQVdBLENBQUNDLFVBQStCLEVBQUU7SUFBQSxLQUZuQy9CLE1BQU07SUFHZCxJQUFJLENBQUNnQyxNQUFNLENBQUNELFVBQVUsQ0FBQztFQUN6QjtFQUVBQyxNQUFNQSxDQUFDRCxVQUErQixFQUFFO0lBQ3RDLElBQUksQ0FBQy9CLE1BQU0sR0FBR1EsTUFBTSxDQUFDRSxJQUFJLENBQUNxQixVQUFVLENBQUMsQ0FBQ0UsTUFBTSxDQUFDLENBQUNDLFlBQVksRUFBRS9CLEdBQUcsS0FBSztNQUNsRSxNQUFNSCxNQUFNLEdBQUcrQixVQUFVLENBQUM1QixHQUFHLENBQUM7TUFDOUIsT0FBQUssTUFBQSxDQUFBQyxNQUFBLEtBQVl5QixZQUFZO1FBQUUsQ0FBQy9CLEdBQUcsR0FBR0g7TUFBTTtJQUN6QyxDQUFDLEVBQUUsSUFBSSxDQUFDQSxNQUFNLElBQUksQ0FBQyxDQUFDLENBQUM7RUFDdkI7RUFFQUQsU0FBU0EsQ0FDUCxHQUFHd0IsSUFPRixFQUNEO0lBQ0EsT0FBT3hCLFNBQVMsQ0FBQyxJQUFJLENBQUNDLE1BQU0sRUFBRSxHQUFHdUIsSUFBSSxDQUFDO0VBQ3hDOztFQUVBO0VBQ0FSLFdBQVdBLENBQUMsR0FBR1EsSUFBd0MsRUFBRTtJQUN2RCxPQUFPUixXQUFXLENBQUMsSUFBSSxDQUFDZixNQUFNLEVBQUUsR0FBR3VCLElBQUksQ0FBQztFQUMxQztFQUVBRCxLQUFLQSxDQUFDQyxJQUFTLEVBQUVDLE9BQVksRUFBRUMsT0FBWSxFQUFFQyxRQUFhLEVBQUU7SUFDMUQsT0FBT0osS0FBSyxDQUFDLElBQUksQ0FBQ3RCLE1BQU0sRUFBRXVCLElBQUksRUFBRUMsT0FBTyxFQUFFQyxPQUFPLEVBQUVDLFFBQVEsQ0FBQztFQUM3RDtBQUNGIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["isImmutable","denormalizeImmutable","denormalizeOnlyImmutable","normalize","schema","input","parent","key","visit","addEntity","visitedEntities","storeEntities","args","object","Object","assign","keys","forEach","localSchema","value","undefined","denormalize","unvisit","found","deleted","item","foundItem","deletedItem","denormalizeOnly","infer","indexes","recurse","entities","resultObject","k","ObjectSchema","constructor","definition","define","reduce","entitySchema"],"sources":["../../src/schemas/Object.ts"],"sourcesContent":["import {\n  isImmutable,\n  denormalizeImmutable,\n  denormalizeOnlyImmutable,\n} from './ImmutableUtils.js';\n\nexport const normalize = (\n  schema: any,\n  input: any,\n  parent: any,\n  key: any,\n  visit: any,\n  addEntity: any,\n  visitedEntities: any,\n  storeEntities: any,\n  args: any[],\n) => {\n  const object = { ...input };\n  Object.keys(schema).forEach(key => {\n    const localSchema = schema[key];\n    const value = visit(\n      input[key],\n      input,\n      key,\n      localSchema,\n      addEntity,\n      visitedEntities,\n      storeEntities,\n      args,\n    );\n    if (value === undefined || value === null) {\n      delete object[key];\n    } else {\n      object[key] = value;\n    }\n  });\n  return object;\n};\n\nexport const denormalize = (\n  schema: any,\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  input: {},\n  unvisit: any,\n): [denormalized: any, found: boolean, deleted: boolean] => {\n  if (isImmutable(input)) {\n    return denormalizeImmutable(schema, input, unvisit);\n  }\n\n  const object: Record<string, any> = { ...input };\n  let found = true;\n  let deleted = false;\n  Object.keys(schema).forEach(key => {\n    const [item, foundItem, deletedItem] = unvisit(object[key], schema[key]);\n    if (object[key] !== undefined) {\n      object[key] = item;\n    }\n    if (deletedItem) {\n      deleted = true;\n    }\n    if (!foundItem) {\n      found = false;\n    }\n  });\n  return [object, found, deleted];\n};\n\nexport function denormalizeOnly(\n  schema: any,\n  input: {},\n  args: readonly any[],\n  unvisit: (input: any, schema: any) => any,\n): any {\n  if (isImmutable(input)) {\n    return denormalizeOnlyImmutable(schema, input, unvisit);\n  }\n\n  const object: Record<string, any> = { ...input };\n\n  for (const key of Object.keys(schema)) {\n    const item = unvisit(object[key], schema[key]);\n    if (object[key] !== undefined) {\n      object[key] = item;\n    }\n    if (typeof item === 'symbol') {\n      return item;\n    }\n  }\n  return object;\n}\n\nexport function infer(\n  schema: any,\n  args: readonly any[],\n  indexes: any,\n  recurse: any,\n  entities: any,\n) {\n  const resultObject: any = {};\n  Object.keys(schema).forEach(k => {\n    resultObject[k] = recurse(schema[k], args, indexes, entities);\n  });\n  return resultObject;\n}\n/**\n * Represents objects with statically known members\n * @see https://resthooks.io/rest/api/Object\n */\nexport default class ObjectSchema {\n  protected schema: any;\n\n  constructor(definition: Record<string, any>) {\n    this.define(definition);\n  }\n\n  define(definition: Record<string, any>) {\n    this.schema = Object.keys(definition).reduce((entitySchema, key) => {\n      const schema = definition[key];\n      return { ...entitySchema, [key]: schema };\n    }, this.schema || {});\n  }\n\n  normalize(\n    ...args: readonly [\n      input: any,\n      parent: any,\n      key: any,\n      visit: any,\n      addEntity: any,\n      visitedEntities: any,\n      storeEntities: any,\n      args: any[],\n    ]\n  ) {\n    return normalize(this.schema, ...args);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  denormalize(...args: readonly [input: {}, unvisit: any]) {\n    return denormalize(this.schema, ...args);\n  }\n\n  denormalizeOnly(\n    input: {},\n    args: readonly any[],\n    unvisit: (input: any, schema: any) => any,\n  ): any {\n    return denormalizeOnly(this.schema, input, args, unvisit);\n  }\n\n  infer(args: any, indexes: any, recurse: any, entities: any) {\n    return infer(this.schema, args, indexes, recurse, entities);\n  }\n}\n"],"mappings":"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"} |
import { isImmutable } from './ImmutableUtils.js'; | ||
import { DELETED } from '../special.js'; | ||
export default class PolymorphicSchema { | ||
@@ -14,3 +15,9 @@ constructor(definition, schemaAttribute) { | ||
define(definition) { | ||
this.schema = definition; | ||
// sending Union into another Polymorphic gets hoisted | ||
if ('_schemaAttribute' in definition && !this._schemaAttribute) { | ||
this.schema = definition.schema; | ||
this._schemaAttribute = definition._schemaAttribute; | ||
} else { | ||
this.schema = definition; | ||
} | ||
} | ||
@@ -27,3 +34,4 @@ getSchemaAttribute(input, parent, key) { | ||
} | ||
normalizeValue(value, parent, key, visit, addEntity, visitedEntities) { | ||
normalizeValue(value, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
if (!value) return value; | ||
const schema = this.inferSchema(value, parent, key); | ||
@@ -41,3 +49,3 @@ if (!schema) { | ||
} | ||
const normalizedValue = visit(value, parent, key, schema, addEntity, visitedEntities); | ||
const normalizedValue = visit(value, parent, key, schema, addEntity, visitedEntities, storeEntities, args); | ||
return this.isSingleSchema || normalizedValue === undefined || normalizedValue === null ? normalizedValue : { | ||
@@ -58,9 +66,14 @@ id: normalizedValue, | ||
} | ||
return [value, true, false]; | ||
return value; | ||
} | ||
const id = this.isSingleSchema ? undefined : isImmutable(value) ? value.get('id') : value.id; | ||
const schema = this.isSingleSchema ? this.schema : this.schema[schemaKey]; | ||
return unvisit(id || value, schema); | ||
const ret = unvisit(id || value, schema); | ||
if (Array.isArray(ret) && ret.length === 3) { | ||
if (ret[2] === true) return DELETED; | ||
return ret[0]; | ||
} | ||
return ret; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["isImmutable","PolymorphicSchema","constructor","definition","schemaAttribute","schema","_schemaAttribute","input","define","isSingleSchema","getSchemaAttribute","parent","key","inferSchema","attr","normalizeValue","value","visit","addEntity","visitedEntities","process","env","NODE_ENV","console","warn","JSON","stringify","undefined","Object","keys","map","k","join","normalizedValue","id","denormalizeValue","unvisit","schemaKey","get","name"],"sources":["../../src/schemas/Polymorphic.ts"],"sourcesContent":["import { isImmutable } from './ImmutableUtils.js';\n\nexport default class PolymorphicSchema {\n  private declare _schemaAttribute: any;\n  protected schema: any;\n\n  constructor(\n    definition: any,\n    schemaAttribute?: string | ((...args: any) => any),\n  ) {\n    if (schemaAttribute) {\n      this._schemaAttribute =\n        typeof schemaAttribute === 'string'\n          ? (input: any) => input[schemaAttribute]\n          : schemaAttribute;\n    }\n    this.define(definition);\n  }\n\n  get isSingleSchema() {\n    return !this._schemaAttribute;\n  }\n\n  define(definition: any) {\n    this.schema = definition;\n  }\n\n  getSchemaAttribute(input: any, parent: any, key: any) {\n    return !this.isSingleSchema && this._schemaAttribute(input, parent, key);\n  }\n\n  inferSchema(input: any, parent: any, key: any) {\n    if (this.isSingleSchema) {\n      return this.schema;\n    }\n\n    const attr = this.getSchemaAttribute(input, parent, key);\n    return this.schema[attr];\n  }\n\n  normalizeValue(\n    value: any,\n    parent: any,\n    key: any,\n    visit: any,\n    addEntity: any,\n    visitedEntities: any,\n  ) {\n    const schema = this.inferSchema(value, parent, key);\n    if (!schema) {\n      /* istanbul ignore else */\n      if (process.env.NODE_ENV !== 'production') {\n        const attr = this.getSchemaAttribute(value, parent, key);\n        console.warn(\n          `Schema attribute ${JSON.stringify(\n            attr,\n            undefined,\n            2,\n          )} is not expected.\nExpected one of: ${Object.keys(this.schema)\n            .map(k => `\"${k}\"`)\n            .join(', ')}\n\nValue: ${JSON.stringify(value, undefined, 2)}`,\n        );\n      }\n      return value;\n    }\n    const normalizedValue = visit(\n      value,\n      parent,\n      key,\n      schema,\n      addEntity,\n      visitedEntities,\n    );\n    return this.isSingleSchema ||\n      normalizedValue === undefined ||\n      normalizedValue === null\n      ? normalizedValue\n      : {\n          id: normalizedValue,\n          schema: this.getSchemaAttribute(value, parent, key),\n        };\n  }\n\n  // value is guaranteed by caller to not be null\n  denormalizeValue(value: any, unvisit: any) {\n    const schemaKey =\n      !this.isSingleSchema &&\n      (isImmutable(value) ? value.get('schema') : value.schema);\n    if (!this.isSingleSchema && !schemaKey) {\n      /* istanbul ignore else */\n      if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `TypeError: Unable to infer schema for ${this.constructor.name}\nValue: ${JSON.stringify(value, undefined, 2)}.`,\n        );\n      }\n      return [value, true, false];\n    }\n    const id = this.isSingleSchema\n      ? undefined\n      : isImmutable(value)\n      ? value.get('id')\n      : value.id;\n    const schema = this.isSingleSchema ? this.schema : this.schema[schemaKey];\n    return unvisit(id || value, schema);\n  }\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["isImmutable","DELETED","PolymorphicSchema","constructor","definition","schemaAttribute","schema","_schemaAttribute","input","define","isSingleSchema","getSchemaAttribute","parent","key","inferSchema","attr","normalizeValue","value","visit","addEntity","visitedEntities","storeEntities","args","process","env","NODE_ENV","console","warn","JSON","stringify","undefined","Object","keys","map","k","join","normalizedValue","id","denormalizeValue","unvisit","schemaKey","get","name","ret","Array","isArray","length"],"sources":["../../src/schemas/Polymorphic.ts"],"sourcesContent":["import { isImmutable } from './ImmutableUtils.js';\nimport { DELETED } from '../special.js';\n\nexport default class PolymorphicSchema {\n  private declare _schemaAttribute: any;\n  protected schema: any;\n\n  constructor(\n    definition: any,\n    schemaAttribute?: string | ((...args: any) => any),\n  ) {\n    if (schemaAttribute) {\n      this._schemaAttribute =\n        typeof schemaAttribute === 'string'\n          ? (input: any) => input[schemaAttribute]\n          : schemaAttribute;\n    }\n    this.define(definition);\n  }\n\n  get isSingleSchema() {\n    return !this._schemaAttribute;\n  }\n\n  define(definition: any) {\n    // sending Union into another Polymorphic gets hoisted\n    if ('_schemaAttribute' in definition && !this._schemaAttribute) {\n      this.schema = definition.schema;\n      this._schemaAttribute = definition._schemaAttribute;\n    } else {\n      this.schema = definition;\n    }\n  }\n\n  getSchemaAttribute(input: any, parent: any, key: any) {\n    return !this.isSingleSchema && this._schemaAttribute(input, parent, key);\n  }\n\n  inferSchema(input: any, parent: any, key: any) {\n    if (this.isSingleSchema) {\n      return this.schema;\n    }\n\n    const attr = this.getSchemaAttribute(input, parent, key);\n    return this.schema[attr];\n  }\n\n  normalizeValue(\n    value: any,\n    parent: any,\n    key: any,\n    visit: any,\n    addEntity: any,\n    visitedEntities: any,\n    storeEntities: any,\n    args?: any[],\n  ) {\n    if (!value) return value;\n    const schema = this.inferSchema(value, parent, key);\n    if (!schema) {\n      /* istanbul ignore else */\n      if (process.env.NODE_ENV !== 'production') {\n        const attr = this.getSchemaAttribute(value, parent, key);\n        console.warn(\n          `Schema attribute ${JSON.stringify(\n            attr,\n            undefined,\n            2,\n          )} is not expected.\nExpected one of: ${Object.keys(this.schema)\n            .map(k => `\"${k}\"`)\n            .join(', ')}\n\nValue: ${JSON.stringify(value, undefined, 2)}`,\n        );\n      }\n      return value;\n    }\n    const normalizedValue = visit(\n      value,\n      parent,\n      key,\n      schema,\n      addEntity,\n      visitedEntities,\n      storeEntities,\n      args,\n    );\n    return this.isSingleSchema ||\n      normalizedValue === undefined ||\n      normalizedValue === null\n      ? normalizedValue\n      : {\n          id: normalizedValue,\n          schema: this.getSchemaAttribute(value, parent, key),\n        };\n  }\n\n  // value is guaranteed by caller to not be null\n  denormalizeValue(value: any, unvisit: any) {\n    const schemaKey =\n      !this.isSingleSchema &&\n      (isImmutable(value) ? value.get('schema') : value.schema);\n    if (!this.isSingleSchema && !schemaKey) {\n      /* istanbul ignore else */\n      if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `TypeError: Unable to infer schema for ${this.constructor.name}\nValue: ${JSON.stringify(value, undefined, 2)}.`,\n        );\n      }\n      return value;\n    }\n    const id = this.isSingleSchema\n      ? undefined\n      : isImmutable(value)\n      ? value.get('id')\n      : value.id;\n    const schema = this.isSingleSchema ? this.schema : this.schema[schemaKey];\n    const ret = unvisit(id || value, schema);\n    if (Array.isArray(ret) && ret.length === 3) {\n      if (ret[2] === true) return DELETED;\n      return ret[0];\n    }\n    return ret;\n  }\n}\n"],"mappings":"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"} |
@@ -14,4 +14,4 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
} | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
return this.normalizeValue(input, parent, key, visit, addEntity, visitedEntities); | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
return this.normalizeValue(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args); | ||
} | ||
@@ -21,2 +21,6 @@ | ||
denormalize(input, unvisit) { | ||
const value = this.denormalizeValue(input, unvisit); | ||
return [value, value !== undefined, typeof value === 'symbol']; | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return this.denormalizeValue(input, unvisit); | ||
@@ -37,2 +41,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsIlVuaW9uU2NoZW1hIiwiY29uc3RydWN0b3IiLCJkZWZpbml0aW9uIiwic2NoZW1hQXR0cmlidXRlIiwiRXJyb3IiLCJub3JtYWxpemUiLCJpbnB1dCIsInBhcmVudCIsImtleSIsInZpc2l0IiwiYWRkRW50aXR5IiwidmlzaXRlZEVudGl0aWVzIiwibm9ybWFsaXplVmFsdWUiLCJkZW5vcm1hbGl6ZSIsInVudmlzaXQiLCJkZW5vcm1hbGl6ZVZhbHVlIiwiaW5mZXIiLCJhcmdzIiwiaW5kZXhlcyIsInJlY3Vyc2UiLCJlbnRpdGllcyIsInVuZGVmaW5lZCIsImF0dHIiLCJnZXRTY2hlbWFBdHRyaWJ1dGUiLCJkaXNjcmltaW5hdGVkU2NoZW1hIiwic2NoZW1hIiwiaWQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9Vbmlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUG9seW1vcnBoaWNTY2hlbWEgZnJvbSAnLi9Qb2x5bW9ycGhpYy5qcyc7XG5cbi8qKlxuICogUmVwcmVzZW50cyBwb2x5bW9ycGhpYyB2YWx1ZXMuXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL3Jlc3QvYXBpL1VuaW9uXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFVuaW9uU2NoZW1hIGV4dGVuZHMgUG9seW1vcnBoaWNTY2hlbWEge1xuICBjb25zdHJ1Y3RvcihkZWZpbml0aW9uOiBhbnksIHNjaGVtYUF0dHJpYnV0ZTogYW55KSB7XG4gICAgaWYgKCFzY2hlbWFBdHRyaWJ1dGUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgJ0V4cGVjdGVkIG9wdGlvbiBcInNjaGVtYUF0dHJpYnV0ZVwiIG5vdCBmb3VuZCBvbiBVbmlvblNjaGVtYS4nLFxuICAgICAgKTtcbiAgICB9XG4gICAgc3VwZXIoZGVmaW5pdGlvbiwgc2NoZW1hQXR0cmlidXRlKTtcbiAgfVxuXG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiBhbnksXG4gICAgYWRkRW50aXR5OiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBhbnksXG4gICkge1xuICAgIHJldHVybiB0aGlzLm5vcm1hbGl6ZVZhbHVlKFxuICAgICAgaW5wdXQsXG4gICAgICBwYXJlbnQsXG4gICAgICBrZXksXG4gICAgICB2aXNpdCxcbiAgICAgIGFkZEVudGl0eSxcbiAgICAgIHZpc2l0ZWRFbnRpdGllcyxcbiAgICApO1xuICB9XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbiAgZGVub3JtYWxpemUoaW5wdXQ6IHt9LCB1bnZpc2l0OiBhbnkpIHtcbiAgICByZXR1cm4gdGhpcy5kZW5vcm1hbGl6ZVZhbHVlKGlucHV0LCB1bnZpc2l0KTtcbiAgfVxuXG4gIGluZmVyKGFyZ3M6IGFueSwgaW5kZXhlczogYW55LCByZWN1cnNlOiBhbnksIGVudGl0aWVzOiBhbnkpIHtcbiAgICBpZiAoIWFyZ3NbMF0pIHJldHVybiB1bmRlZmluZWQ7XG4gICAgY29uc3QgYXR0ciA9IHRoaXMuZ2V0U2NoZW1hQXR0cmlidXRlKGFyZ3NbMF0sIHVuZGVmaW5lZCwgJycpO1xuICAgIGNvbnN0IGRpc2NyaW1pbmF0ZWRTY2hlbWEgPSB0aGlzLnNjaGVtYVthdHRyXTtcblxuICAgIC8vIFdhcyB1bmFibGUgdG8gaW5mZXIgdGhlIGVudGl0eSdzIHNjaGVtYSBmcm9tIHBhcmFtc1xuICAgIGlmIChkaXNjcmltaW5hdGVkU2NoZW1hID09PSB1bmRlZmluZWQpIHJldHVybiB1bmRlZmluZWQ7XG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiByZWN1cnNlKGRpc2NyaW1pbmF0ZWRTY2hlbWEsIGFyZ3MsIGluZGV4ZXMsIGVudGl0aWVzKSxcbiAgICAgIHNjaGVtYTogYXR0cixcbiAgICB9O1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLGlCQUFpQixNQUFNLGtCQUFrQjs7QUFFaEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLE1BQU1DLFdBQVcsU0FBU0QsaUJBQWlCLENBQUM7RUFDekRFLFdBQVdBLENBQUNDLFVBQWUsRUFBRUMsZUFBb0IsRUFBRTtJQUNqRCxJQUFJLENBQUNBLGVBQWUsRUFBRTtNQUNwQixNQUFNLElBQUlDLEtBQUssQ0FDYiw2REFBNkQsQ0FDOUQ7SUFDSDtJQUNBLEtBQUssQ0FBQ0YsVUFBVSxFQUFFQyxlQUFlLENBQUM7RUFDcEM7RUFFQUUsU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEVBQ3BCO0lBQ0EsT0FBTyxJQUFJLENBQUNDLGNBQWMsQ0FDeEJOLEtBQUssRUFDTEMsTUFBTSxFQUNOQyxHQUFHLEVBQ0hDLEtBQUssRUFDTEMsU0FBUyxFQUNUQyxlQUFlLENBQ2hCO0VBQ0g7O0VBRUE7RUFDQUUsV0FBV0EsQ0FBQ1AsS0FBUyxFQUFFUSxPQUFZLEVBQUU7SUFDbkMsT0FBTyxJQUFJLENBQUNDLGdCQUFnQixDQUFDVCxLQUFLLEVBQUVRLE9BQU8sQ0FBQztFQUM5QztFQUVBRSxLQUFLQSxDQUFDQyxJQUFTLEVBQUVDLE9BQVksRUFBRUMsT0FBWSxFQUFFQyxRQUFhLEVBQUU7SUFDMUQsSUFBSSxDQUFDSCxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsT0FBT0ksU0FBUztJQUM5QixNQUFNQyxJQUFJLEdBQUcsSUFBSSxDQUFDQyxrQkFBa0IsQ0FBQ04sSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFSSxTQUFTLEVBQUUsRUFBRSxDQUFDO0lBQzVELE1BQU1HLG1CQUFtQixHQUFHLElBQUksQ0FBQ0MsTUFBTSxDQUFDSCxJQUFJLENBQUM7O0lBRTdDO0lBQ0EsSUFBSUUsbUJBQW1CLEtBQUtILFNBQVMsRUFBRSxPQUFPQSxTQUFTO0lBQ3ZELE9BQU87TUFDTEssRUFBRSxFQUFFUCxPQUFPLENBQUNLLG1CQUFtQixFQUFFUCxJQUFJLEVBQUVDLE9BQU8sRUFBRUUsUUFBUSxDQUFDO01BQ3pESyxNQUFNLEVBQUVIO0lBQ1YsQ0FBQztFQUNIO0FBQ0YifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsIlVuaW9uU2NoZW1hIiwiY29uc3RydWN0b3IiLCJkZWZpbml0aW9uIiwic2NoZW1hQXR0cmlidXRlIiwiRXJyb3IiLCJub3JtYWxpemUiLCJpbnB1dCIsInBhcmVudCIsImtleSIsInZpc2l0IiwiYWRkRW50aXR5IiwidmlzaXRlZEVudGl0aWVzIiwic3RvcmVFbnRpdGllcyIsImFyZ3MiLCJub3JtYWxpemVWYWx1ZSIsImRlbm9ybWFsaXplIiwidW52aXNpdCIsInZhbHVlIiwiZGVub3JtYWxpemVWYWx1ZSIsInVuZGVmaW5lZCIsImRlbm9ybWFsaXplT25seSIsImluZmVyIiwiaW5kZXhlcyIsInJlY3Vyc2UiLCJlbnRpdGllcyIsImF0dHIiLCJnZXRTY2hlbWFBdHRyaWJ1dGUiLCJkaXNjcmltaW5hdGVkU2NoZW1hIiwic2NoZW1hIiwiaWQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9Vbmlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUG9seW1vcnBoaWNTY2hlbWEgZnJvbSAnLi9Qb2x5bW9ycGhpYy5qcyc7XG5cbi8qKlxuICogUmVwcmVzZW50cyBwb2x5bW9ycGhpYyB2YWx1ZXMuXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL3Jlc3QvYXBpL1VuaW9uXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFVuaW9uU2NoZW1hIGV4dGVuZHMgUG9seW1vcnBoaWNTY2hlbWEge1xuICBjb25zdHJ1Y3RvcihkZWZpbml0aW9uOiBhbnksIHNjaGVtYUF0dHJpYnV0ZTogYW55KSB7XG4gICAgaWYgKCFzY2hlbWFBdHRyaWJ1dGUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgJ0V4cGVjdGVkIG9wdGlvbiBcInNjaGVtYUF0dHJpYnV0ZVwiIG5vdCBmb3VuZCBvbiBVbmlvblNjaGVtYS4nLFxuICAgICAgKTtcbiAgICB9XG4gICAgc3VwZXIoZGVmaW5pdGlvbiwgc2NoZW1hQXR0cmlidXRlKTtcbiAgfVxuXG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiBhbnksXG4gICAgYWRkRW50aXR5OiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBhbnksXG4gICAgc3RvcmVFbnRpdGllczogYW55LFxuICAgIGFyZ3M6IGFueVtdLFxuICApIHtcbiAgICByZXR1cm4gdGhpcy5ub3JtYWxpemVWYWx1ZShcbiAgICAgIGlucHV0LFxuICAgICAgcGFyZW50LFxuICAgICAga2V5LFxuICAgICAgdmlzaXQsXG4gICAgICBhZGRFbnRpdHksXG4gICAgICB2aXNpdGVkRW50aXRpZXMsXG4gICAgICBzdG9yZUVudGl0aWVzLFxuICAgICAgYXJncyxcbiAgICApO1xuICB9XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbiAgZGVub3JtYWxpemUoaW5wdXQ6IHt9LCB1bnZpc2l0OiBhbnkpOiBhbnkge1xuICAgIGNvbnN0IHZhbHVlID0gdGhpcy5kZW5vcm1hbGl6ZVZhbHVlKGlucHV0LCB1bnZpc2l0KTtcbiAgICByZXR1cm4gW3ZhbHVlLCB2YWx1ZSAhPT0gdW5kZWZpbmVkLCB0eXBlb2YgdmFsdWUgPT09ICdzeW1ib2wnXTtcbiAgfVxuXG4gIGRlbm9ybWFsaXplT25seShcbiAgICBpbnB1dDoge30sXG4gICAgYXJnczogcmVhZG9ubHkgYW55W10sXG4gICAgdW52aXNpdDogKGlucHV0OiBhbnksIHNjaGVtYTogYW55KSA9PiBhbnksXG4gICkge1xuICAgIHJldHVybiB0aGlzLmRlbm9ybWFsaXplVmFsdWUoaW5wdXQsIHVudmlzaXQpO1xuICB9XG5cbiAgaW5mZXIoYXJnczogYW55LCBpbmRleGVzOiBhbnksIHJlY3Vyc2U6IGFueSwgZW50aXRpZXM6IGFueSkge1xuICAgIGlmICghYXJnc1swXSkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICBjb25zdCBhdHRyID0gdGhpcy5nZXRTY2hlbWFBdHRyaWJ1dGUoYXJnc1swXSwgdW5kZWZpbmVkLCAnJyk7XG4gICAgY29uc3QgZGlzY3JpbWluYXRlZFNjaGVtYSA9IHRoaXMuc2NoZW1hW2F0dHJdO1xuXG4gICAgLy8gV2FzIHVuYWJsZSB0byBpbmZlciB0aGUgZW50aXR5J3Mgc2NoZW1hIGZyb20gcGFyYW1zXG4gICAgaWYgKGRpc2NyaW1pbmF0ZWRTY2hlbWEgPT09IHVuZGVmaW5lZCkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICByZXR1cm4ge1xuICAgICAgaWQ6IHJlY3Vyc2UoZGlzY3JpbWluYXRlZFNjaGVtYSwgYXJncywgaW5kZXhlcywgZW50aXRpZXMpLFxuICAgICAgc2NoZW1hOiBhdHRyLFxuICAgIH07XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsaUJBQWlCLE1BQU0sa0JBQWtCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsTUFBTUMsV0FBVyxTQUFTRCxpQkFBaUIsQ0FBQztFQUN6REUsV0FBV0EsQ0FBQ0MsVUFBZSxFQUFFQyxlQUFvQixFQUFFO0lBQ2pELElBQUksQ0FBQ0EsZUFBZSxFQUFFO01BQ3BCLE1BQU0sSUFBSUMsS0FBSyxDQUNiLDZEQUE2RCxDQUM5RDtJQUNIO0lBQ0EsS0FBSyxDQUFDRixVQUFVLEVBQUVDLGVBQWUsQ0FBQztFQUNwQztFQUVBRSxTQUFTQSxDQUNQQyxLQUFVLEVBQ1ZDLE1BQVcsRUFDWEMsR0FBUSxFQUNSQyxLQUFVLEVBQ1ZDLFNBQWMsRUFDZEMsZUFBb0IsRUFDcEJDLGFBQWtCLEVBQ2xCQyxJQUFXLEVBQ1g7SUFDQSxPQUFPLElBQUksQ0FBQ0MsY0FBYyxDQUN4QlIsS0FBSyxFQUNMQyxNQUFNLEVBQ05DLEdBQUcsRUFDSEMsS0FBSyxFQUNMQyxTQUFTLEVBQ1RDLGVBQWUsRUFDZkMsYUFBYSxFQUNiQyxJQUFJLENBQ0w7RUFDSDs7RUFFQTtFQUNBRSxXQUFXQSxDQUFDVCxLQUFTLEVBQUVVLE9BQVksRUFBTztJQUN4QyxNQUFNQyxLQUFLLEdBQUcsSUFBSSxDQUFDQyxnQkFBZ0IsQ0FBQ1osS0FBSyxFQUFFVSxPQUFPLENBQUM7SUFDbkQsT0FBTyxDQUFDQyxLQUFLLEVBQUVBLEtBQUssS0FBS0UsU0FBUyxFQUFFLE9BQU9GLEtBQUssS0FBSyxRQUFRLENBQUM7RUFDaEU7RUFFQUcsZUFBZUEsQ0FDYmQsS0FBUyxFQUNUTyxJQUFvQixFQUNwQkcsT0FBeUMsRUFDekM7SUFDQSxPQUFPLElBQUksQ0FBQ0UsZ0JBQWdCLENBQUNaLEtBQUssRUFBRVUsT0FBTyxDQUFDO0VBQzlDO0VBRUFLLEtBQUtBLENBQUNSLElBQVMsRUFBRVMsT0FBWSxFQUFFQyxPQUFZLEVBQUVDLFFBQWEsRUFBRTtJQUMxRCxJQUFJLENBQUNYLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxPQUFPTSxTQUFTO0lBQzlCLE1BQU1NLElBQUksR0FBRyxJQUFJLENBQUNDLGtCQUFrQixDQUFDYixJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUVNLFNBQVMsRUFBRSxFQUFFLENBQUM7SUFDNUQsTUFBTVEsbUJBQW1CLEdBQUcsSUFBSSxDQUFDQyxNQUFNLENBQUNILElBQUksQ0FBQzs7SUFFN0M7SUFDQSxJQUFJRSxtQkFBbUIsS0FBS1IsU0FBUyxFQUFFLE9BQU9BLFNBQVM7SUFDdkQsT0FBTztNQUNMVSxFQUFFLEVBQUVOLE9BQU8sQ0FBQ0ksbUJBQW1CLEVBQUVkLElBQUksRUFBRVMsT0FBTyxFQUFFRSxRQUFRLENBQUM7TUFDekRJLE1BQU0sRUFBRUg7SUFDVixDQUFDO0VBQ0g7QUFDRiJ9 |
export const getValues = input => Array.isArray(input) ? input : Object.keys(input).map(key => input[key]); | ||
export const filterEmpty = ([item,, deletedItem]) => item !== undefined && !deletedItem; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJnZXRWYWx1ZXMiLCJpbnB1dCIsIkFycmF5IiwiaXNBcnJheSIsIk9iamVjdCIsImtleXMiLCJtYXAiLCJrZXkiLCJmaWx0ZXJFbXB0eSIsIml0ZW0iLCJkZWxldGVkSXRlbSIsInVuZGVmaW5lZCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWFzL3V0aWxzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBnZXRWYWx1ZXMgPSAoaW5wdXQ6IGFueSkgPT5cbiAgQXJyYXkuaXNBcnJheShpbnB1dCkgPyBpbnB1dCA6IE9iamVjdC5rZXlzKGlucHV0KS5tYXAoa2V5ID0+IGlucHV0W2tleV0pO1xuXG5leHBvcnQgY29uc3QgZmlsdGVyRW1wdHkgPSAoW2l0ZW0sICwgZGVsZXRlZEl0ZW1dOiBhbnkpID0+XG4gIGl0ZW0gIT09IHVuZGVmaW5lZCAmJiAhZGVsZXRlZEl0ZW07XG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sTUFBTUEsU0FBUyxHQUFJQyxLQUFVLElBQ2xDQyxLQUFLLENBQUNDLE9BQU8sQ0FBQ0YsS0FBSyxDQUFDLEdBQUdBLEtBQUssR0FBR0csTUFBTSxDQUFDQyxJQUFJLENBQUNKLEtBQUssQ0FBQyxDQUFDSyxHQUFHLENBQUNDLEdBQUcsSUFBSU4sS0FBSyxDQUFDTSxHQUFHLENBQUMsQ0FBQztBQUUxRSxPQUFPLE1BQU1DLFdBQVcsR0FBR0EsQ0FBQyxDQUFDQyxJQUFJLEdBQUlDLFdBQVcsQ0FBTSxLQUNwREQsSUFBSSxLQUFLRSxTQUFTLElBQUksQ0FBQ0QsV0FBVyJ9 | ||
export const filterEmpty = item => item !== undefined && typeof item !== 'symbol'; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJnZXRWYWx1ZXMiLCJpbnB1dCIsIkFycmF5IiwiaXNBcnJheSIsIk9iamVjdCIsImtleXMiLCJtYXAiLCJrZXkiLCJmaWx0ZXJFbXB0eSIsIml0ZW0iLCJ1bmRlZmluZWQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy91dGlscy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgZ2V0VmFsdWVzID0gKGlucHV0OiBhbnkpID0+XG4gIEFycmF5LmlzQXJyYXkoaW5wdXQpID8gaW5wdXQgOiBPYmplY3Qua2V5cyhpbnB1dCkubWFwKGtleSA9PiBpbnB1dFtrZXldKTtcblxuZXhwb3J0IGNvbnN0IGZpbHRlckVtcHR5ID0gKGl0ZW06IGFueSkgPT5cbiAgaXRlbSAhPT0gdW5kZWZpbmVkICYmIHR5cGVvZiBpdGVtICE9PSAnc3ltYm9sJztcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxNQUFNQSxTQUFTLEdBQUlDLEtBQVUsSUFDbENDLEtBQUssQ0FBQ0MsT0FBTyxDQUFDRixLQUFLLENBQUMsR0FBR0EsS0FBSyxHQUFHRyxNQUFNLENBQUNDLElBQUksQ0FBQ0osS0FBSyxDQUFDLENBQUNLLEdBQUcsQ0FBQ0MsR0FBRyxJQUFJTixLQUFLLENBQUNNLEdBQUcsQ0FBQyxDQUFDO0FBRTFFLE9BQU8sTUFBTUMsV0FBVyxHQUFJQyxJQUFTLElBQ25DQSxJQUFJLEtBQUtDLFNBQVMsSUFBSSxPQUFPRCxJQUFJLEtBQUssUUFBUSJ9 |
@@ -8,7 +8,7 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ValuesSchema extends PolymorphicSchema { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
return Object.keys(input).reduce((output, key, index) => { | ||
const value = input[key]; | ||
return value !== undefined && value !== null ? Object.assign({}, output, { | ||
[key]: this.normalizeValue(value, input, key, visit, addEntity, visitedEntities) | ||
[key]: this.normalizeValue(value, input, key, visit, addEntity, visitedEntities, storeEntities, args) | ||
}) : output; | ||
@@ -20,19 +20,23 @@ }, {}); | ||
denormalize(input, unvisit) { | ||
let found = true; | ||
let deleted = false; | ||
return [Object.keys(input).reduce((output, key) => { | ||
const entityOrId = input[key]; | ||
const [value, foundItem, deletedItem] = this.denormalizeValue(entityOrId, unvisit); | ||
if (!foundItem) { | ||
found = false; | ||
} | ||
if (deletedItem) { | ||
deleted = true; | ||
} | ||
if (!foundItem || deletedItem) return output; | ||
const value = this.denormalizeValue(entityOrId, unvisit); | ||
if (!value || typeof value === 'symbol') return output; | ||
return Object.assign({}, output, { | ||
[key]: value | ||
}); | ||
}, {}), found, deleted]; | ||
}, {}), true, false]; | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return Object.keys(input).reduce((output, key) => { | ||
const entityOrId = input[key]; | ||
const value = this.denormalizeValue(entityOrId, unvisit); | ||
// remove empty or deleted values | ||
if (!value || typeof value === 'symbol') return output; | ||
return Object.assign({}, output, { | ||
[key]: value | ||
}); | ||
}, {}); | ||
} | ||
infer(args, indexes, recurse) { | ||
@@ -42,2 +46,2 @@ return undefined; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsIlZhbHVlc1NjaGVtYSIsIm5vcm1hbGl6ZSIsImlucHV0IiwicGFyZW50Iiwia2V5IiwidmlzaXQiLCJhZGRFbnRpdHkiLCJ2aXNpdGVkRW50aXRpZXMiLCJPYmplY3QiLCJrZXlzIiwicmVkdWNlIiwib3V0cHV0IiwiaW5kZXgiLCJ2YWx1ZSIsInVuZGVmaW5lZCIsImFzc2lnbiIsIm5vcm1hbGl6ZVZhbHVlIiwiZGVub3JtYWxpemUiLCJ1bnZpc2l0IiwiZm91bmQiLCJkZWxldGVkIiwiZW50aXR5T3JJZCIsImZvdW5kSXRlbSIsImRlbGV0ZWRJdGVtIiwiZGVub3JtYWxpemVWYWx1ZSIsImluZmVyIiwiYXJncyIsImluZGV4ZXMiLCJyZWN1cnNlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvVmFsdWVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQb2x5bW9ycGhpY1NjaGVtYSBmcm9tICcuL1BvbHltb3JwaGljLmpzJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIHZhcmlhYmx5IHNpemVkIG9iamVjdHNcbiAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vcmVzdC9hcGkvVmFsdWVzXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFZhbHVlc1NjaGVtYSBleHRlbmRzIFBvbHltb3JwaGljU2NoZW1hIHtcbiAgbm9ybWFsaXplKFxuICAgIGlucHV0OiBhbnksXG4gICAgcGFyZW50OiBhbnksXG4gICAga2V5OiBhbnksXG4gICAgdmlzaXQ6IGFueSxcbiAgICBhZGRFbnRpdHk6IGFueSxcbiAgICB2aXNpdGVkRW50aXRpZXM6IGFueSxcbiAgKSB7XG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKGlucHV0KS5yZWR1Y2UoKG91dHB1dCwga2V5LCBpbmRleCkgPT4ge1xuICAgICAgY29uc3QgdmFsdWUgPSBpbnB1dFtrZXldO1xuICAgICAgcmV0dXJuIHZhbHVlICE9PSB1bmRlZmluZWQgJiYgdmFsdWUgIT09IG51bGxcbiAgICAgICAgPyB7XG4gICAgICAgICAgICAuLi5vdXRwdXQsXG4gICAgICAgICAgICBba2V5XTogdGhpcy5ub3JtYWxpemVWYWx1ZShcbiAgICAgICAgICAgICAgdmFsdWUsXG4gICAgICAgICAgICAgIGlucHV0LFxuICAgICAgICAgICAgICBrZXksXG4gICAgICAgICAgICAgIHZpc2l0LFxuICAgICAgICAgICAgICBhZGRFbnRpdHksXG4gICAgICAgICAgICAgIHZpc2l0ZWRFbnRpdGllcyxcbiAgICAgICAgICAgICksXG4gICAgICAgICAgfVxuICAgICAgICA6IG91dHB1dDtcbiAgICB9LCB7fSk7XG4gIH1cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuICBkZW5vcm1hbGl6ZShpbnB1dDoge30sIHVudmlzaXQ6IGFueSkge1xuICAgIGxldCBmb3VuZCA9IHRydWU7XG4gICAgbGV0IGRlbGV0ZWQgPSBmYWxzZTtcbiAgICByZXR1cm4gW1xuICAgICAgT2JqZWN0LmtleXMoaW5wdXQpLnJlZHVjZSgob3V0cHV0LCBrZXkpID0+IHtcbiAgICAgICAgY29uc3QgZW50aXR5T3JJZCA9IChpbnB1dCBhcyBhbnkpW2tleV07XG4gICAgICAgIGNvbnN0IFt2YWx1ZSwgZm91bmRJdGVtLCBkZWxldGVkSXRlbV0gPSB0aGlzLmRlbm9ybWFsaXplVmFsdWUoXG4gICAgICAgICAgZW50aXR5T3JJZCxcbiAgICAgICAgICB1bnZpc2l0LFxuICAgICAgICApO1xuICAgICAgICBpZiAoIWZvdW5kSXRlbSkge1xuICAgICAgICAgIGZvdW5kID0gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGRlbGV0ZWRJdGVtKSB7XG4gICAgICAgICAgZGVsZXRlZCA9IHRydWU7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCFmb3VuZEl0ZW0gfHwgZGVsZXRlZEl0ZW0pIHJldHVybiBvdXRwdXQ7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgLi4ub3V0cHV0LFxuICAgICAgICAgIFtrZXldOiB2YWx1ZSxcbiAgICAgICAgfTtcbiAgICAgIH0sIHt9KSxcbiAgICAgIGZvdW5kLFxuICAgICAgZGVsZXRlZCxcbiAgICBdO1xuICB9XG5cbiAgaW5mZXIoYXJnczogYW55LCBpbmRleGVzOiBhbnksIHJlY3Vyc2U6IGFueSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsaUJBQWlCLE1BQU0sa0JBQWtCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsTUFBTUMsWUFBWSxTQUFTRCxpQkFBaUIsQ0FBQztFQUMxREUsU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEVBQ3BCO0lBQ0EsT0FBT0MsTUFBTSxDQUFDQyxJQUFJLENBQUNQLEtBQUssQ0FBQyxDQUFDUSxNQUFNLENBQUMsQ0FBQ0MsTUFBTSxFQUFFUCxHQUFHLEVBQUVRLEtBQUssS0FBSztNQUN2RCxNQUFNQyxLQUFLLEdBQUdYLEtBQUssQ0FBQ0UsR0FBRyxDQUFDO01BQ3hCLE9BQU9TLEtBQUssS0FBS0MsU0FBUyxJQUFJRCxLQUFLLEtBQUssSUFBSSxHQUFBTCxNQUFBLENBQUFPLE1BQUEsS0FFbkNKLE1BQU07UUFDVCxDQUFDUCxHQUFHLEdBQUcsSUFBSSxDQUFDWSxjQUFjLENBQ3hCSCxLQUFLLEVBQ0xYLEtBQUssRUFDTEUsR0FBRyxFQUNIQyxLQUFLLEVBQ0xDLFNBQVMsRUFDVEMsZUFBZTtNQUNoQixLQUVISSxNQUFNO0lBQ1osQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0VBQ1I7O0VBRUE7RUFDQU0sV0FBV0EsQ0FBQ2YsS0FBUyxFQUFFZ0IsT0FBWSxFQUFFO0lBQ25DLElBQUlDLEtBQUssR0FBRyxJQUFJO0lBQ2hCLElBQUlDLE9BQU8sR0FBRyxLQUFLO0lBQ25CLE9BQU8sQ0FDTFosTUFBTSxDQUFDQyxJQUFJLENBQUNQLEtBQUssQ0FBQyxDQUFDUSxNQUFNLENBQUMsQ0FBQ0MsTUFBTSxFQUFFUCxHQUFHLEtBQUs7TUFDekMsTUFBTWlCLFVBQVUsR0FBSW5CLEtBQUssQ0FBU0UsR0FBRyxDQUFDO01BQ3RDLE1BQU0sQ0FBQ1MsS0FBSyxFQUFFUyxTQUFTLEVBQUVDLFdBQVcsQ0FBQyxHQUFHLElBQUksQ0FBQ0MsZ0JBQWdCLENBQzNESCxVQUFVLEVBQ1ZILE9BQU8sQ0FDUjtNQUNELElBQUksQ0FBQ0ksU0FBUyxFQUFFO1FBQ2RILEtBQUssR0FBRyxLQUFLO01BQ2Y7TUFDQSxJQUFJSSxXQUFXLEVBQUU7UUFDZkgsT0FBTyxHQUFHLElBQUk7TUFDaEI7TUFDQSxJQUFJLENBQUNFLFNBQVMsSUFBSUMsV0FBVyxFQUFFLE9BQU9aLE1BQU07TUFDNUMsT0FBQUgsTUFBQSxDQUFBTyxNQUFBLEtBQ0tKLE1BQU07UUFDVCxDQUFDUCxHQUFHLEdBQUdTO01BQUs7SUFFaEIsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQ05NLEtBQUssRUFDTEMsT0FBTyxDQUNSO0VBQ0g7RUFFQUssS0FBS0EsQ0FBQ0MsSUFBUyxFQUFFQyxPQUFZLEVBQUVDLE9BQVksRUFBRTtJQUMzQyxPQUFPZCxTQUFTO0VBQ2xCO0FBQ0YifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsIlZhbHVlc1NjaGVtYSIsIm5vcm1hbGl6ZSIsImlucHV0IiwicGFyZW50Iiwia2V5IiwidmlzaXQiLCJhZGRFbnRpdHkiLCJ2aXNpdGVkRW50aXRpZXMiLCJzdG9yZUVudGl0aWVzIiwiYXJncyIsIk9iamVjdCIsImtleXMiLCJyZWR1Y2UiLCJvdXRwdXQiLCJpbmRleCIsInZhbHVlIiwidW5kZWZpbmVkIiwiYXNzaWduIiwibm9ybWFsaXplVmFsdWUiLCJkZW5vcm1hbGl6ZSIsInVudmlzaXQiLCJlbnRpdHlPcklkIiwiZGVub3JtYWxpemVWYWx1ZSIsImRlbm9ybWFsaXplT25seSIsImluZmVyIiwiaW5kZXhlcyIsInJlY3Vyc2UiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9WYWx1ZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFBvbHltb3JwaGljU2NoZW1hIGZyb20gJy4vUG9seW1vcnBoaWMuanMnO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgdmFyaWFibHkgc2l6ZWQgb2JqZWN0c1xuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9yZXN0L2FwaS9WYWx1ZXNcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgVmFsdWVzU2NoZW1hIGV4dGVuZHMgUG9seW1vcnBoaWNTY2hlbWEge1xuICBub3JtYWxpemUoXG4gICAgaW5wdXQ6IGFueSxcbiAgICBwYXJlbnQ6IGFueSxcbiAgICBrZXk6IGFueSxcbiAgICB2aXNpdDogYW55LFxuICAgIGFkZEVudGl0eTogYW55LFxuICAgIHZpc2l0ZWRFbnRpdGllczogYW55LFxuICAgIHN0b3JlRW50aXRpZXM6IGFueSxcbiAgICBhcmdzOiBhbnlbXSxcbiAgKSB7XG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKGlucHV0KS5yZWR1Y2UoKG91dHB1dCwga2V5LCBpbmRleCkgPT4ge1xuICAgICAgY29uc3QgdmFsdWUgPSBpbnB1dFtrZXldO1xuICAgICAgcmV0dXJuIHZhbHVlICE9PSB1bmRlZmluZWQgJiYgdmFsdWUgIT09IG51bGxcbiAgICAgICAgPyB7XG4gICAgICAgICAgICAuLi5vdXRwdXQsXG4gICAgICAgICAgICBba2V5XTogdGhpcy5ub3JtYWxpemVWYWx1ZShcbiAgICAgICAgICAgICAgdmFsdWUsXG4gICAgICAgICAgICAgIGlucHV0LFxuICAgICAgICAgICAgICBrZXksXG4gICAgICAgICAgICAgIHZpc2l0LFxuICAgICAgICAgICAgICBhZGRFbnRpdHksXG4gICAgICAgICAgICAgIHZpc2l0ZWRFbnRpdGllcyxcbiAgICAgICAgICAgICAgc3RvcmVFbnRpdGllcyxcbiAgICAgICAgICAgICAgYXJncyxcbiAgICAgICAgICAgICksXG4gICAgICAgICAgfVxuICAgICAgICA6IG91dHB1dDtcbiAgICB9LCB7fSk7XG4gIH1cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuICBkZW5vcm1hbGl6ZShpbnB1dDoge30sIHVudmlzaXQ6IGFueSkge1xuICAgIHJldHVybiBbXG4gICAgICBPYmplY3Qua2V5cyhpbnB1dCkucmVkdWNlKChvdXRwdXQsIGtleSkgPT4ge1xuICAgICAgICBjb25zdCBlbnRpdHlPcklkID0gKGlucHV0IGFzIGFueSlba2V5XTtcbiAgICAgICAgY29uc3QgdmFsdWUgPSB0aGlzLmRlbm9ybWFsaXplVmFsdWUoZW50aXR5T3JJZCwgdW52aXNpdCk7XG4gICAgICAgIGlmICghdmFsdWUgfHwgdHlwZW9mIHZhbHVlID09PSAnc3ltYm9sJykgcmV0dXJuIG91dHB1dDtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAuLi5vdXRwdXQsXG4gICAgICAgICAgW2tleV06IHZhbHVlLFxuICAgICAgICB9O1xuICAgICAgfSwge30pLFxuICAgICAgdHJ1ZSxcbiAgICAgIGZhbHNlLFxuICAgIF07XG4gIH1cblxuICBkZW5vcm1hbGl6ZU9ubHkoXG4gICAgaW5wdXQ6IHt9LFxuICAgIGFyZ3M6IHJlYWRvbmx5IGFueVtdLFxuICAgIHVudmlzaXQ6IChpbnB1dDogYW55LCBzY2hlbWE6IGFueSkgPT4gYW55LFxuICApOiBhbnkge1xuICAgIHJldHVybiBPYmplY3Qua2V5cyhpbnB1dCkucmVkdWNlKChvdXRwdXQsIGtleSkgPT4ge1xuICAgICAgY29uc3QgZW50aXR5T3JJZCA9IChpbnB1dCBhcyBhbnkpW2tleV07XG4gICAgICBjb25zdCB2YWx1ZSA9IHRoaXMuZGVub3JtYWxpemVWYWx1ZShlbnRpdHlPcklkLCB1bnZpc2l0KTtcblxuICAgICAgLy8gcmVtb3ZlIGVtcHR5IG9yIGRlbGV0ZWQgdmFsdWVzXG4gICAgICBpZiAoIXZhbHVlIHx8IHR5cGVvZiB2YWx1ZSA9PT0gJ3N5bWJvbCcpIHJldHVybiBvdXRwdXQ7XG4gICAgICByZXR1cm4ge1xuICAgICAgICAuLi5vdXRwdXQsXG4gICAgICAgIFtrZXldOiB2YWx1ZSxcbiAgICAgIH07XG4gICAgfSwge30pO1xuICB9XG5cbiAgaW5mZXIoYXJnczogYW55LCBpbmRleGVzOiBhbnksIHJlY3Vyc2U6IGFueSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsaUJBQWlCLE1BQU0sa0JBQWtCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsTUFBTUMsWUFBWSxTQUFTRCxpQkFBaUIsQ0FBQztFQUMxREUsU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEVBQ3BCQyxhQUFrQixFQUNsQkMsSUFBVyxFQUNYO0lBQ0EsT0FBT0MsTUFBTSxDQUFDQyxJQUFJLENBQUNULEtBQUssQ0FBQyxDQUFDVSxNQUFNLENBQUMsQ0FBQ0MsTUFBTSxFQUFFVCxHQUFHLEVBQUVVLEtBQUssS0FBSztNQUN2RCxNQUFNQyxLQUFLLEdBQUdiLEtBQUssQ0FBQ0UsR0FBRyxDQUFDO01BQ3hCLE9BQU9XLEtBQUssS0FBS0MsU0FBUyxJQUFJRCxLQUFLLEtBQUssSUFBSSxHQUFBTCxNQUFBLENBQUFPLE1BQUEsS0FFbkNKLE1BQU07UUFDVCxDQUFDVCxHQUFHLEdBQUcsSUFBSSxDQUFDYyxjQUFjLENBQ3hCSCxLQUFLLEVBQ0xiLEtBQUssRUFDTEUsR0FBRyxFQUNIQyxLQUFLLEVBQ0xDLFNBQVMsRUFDVEMsZUFBZSxFQUNmQyxhQUFhLEVBQ2JDLElBQUk7TUFDTCxLQUVISSxNQUFNO0lBQ1osQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0VBQ1I7O0VBRUE7RUFDQU0sV0FBV0EsQ0FBQ2pCLEtBQVMsRUFBRWtCLE9BQVksRUFBRTtJQUNuQyxPQUFPLENBQ0xWLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDVCxLQUFLLENBQUMsQ0FBQ1UsTUFBTSxDQUFDLENBQUNDLE1BQU0sRUFBRVQsR0FBRyxLQUFLO01BQ3pDLE1BQU1pQixVQUFVLEdBQUluQixLQUFLLENBQVNFLEdBQUcsQ0FBQztNQUN0QyxNQUFNVyxLQUFLLEdBQUcsSUFBSSxDQUFDTyxnQkFBZ0IsQ0FBQ0QsVUFBVSxFQUFFRCxPQUFPLENBQUM7TUFDeEQsSUFBSSxDQUFDTCxLQUFLLElBQUksT0FBT0EsS0FBSyxLQUFLLFFBQVEsRUFBRSxPQUFPRixNQUFNO01BQ3RELE9BQUFILE1BQUEsQ0FBQU8sTUFBQSxLQUNLSixNQUFNO1FBQ1QsQ0FBQ1QsR0FBRyxHQUFHVztNQUFLO0lBRWhCLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUNOLElBQUksRUFDSixLQUFLLENBQ047RUFDSDtFQUVBUSxlQUFlQSxDQUNickIsS0FBUyxFQUNUTyxJQUFvQixFQUNwQlcsT0FBeUMsRUFDcEM7SUFDTCxPQUFPVixNQUFNLENBQUNDLElBQUksQ0FBQ1QsS0FBSyxDQUFDLENBQUNVLE1BQU0sQ0FBQyxDQUFDQyxNQUFNLEVBQUVULEdBQUcsS0FBSztNQUNoRCxNQUFNaUIsVUFBVSxHQUFJbkIsS0FBSyxDQUFTRSxHQUFHLENBQUM7TUFDdEMsTUFBTVcsS0FBSyxHQUFHLElBQUksQ0FBQ08sZ0JBQWdCLENBQUNELFVBQVUsRUFBRUQsT0FBTyxDQUFDOztNQUV4RDtNQUNBLElBQUksQ0FBQ0wsS0FBSyxJQUFJLE9BQU9BLEtBQUssS0FBSyxRQUFRLEVBQUUsT0FBT0YsTUFBTTtNQUN0RCxPQUFBSCxNQUFBLENBQUFPLE1BQUEsS0FDS0osTUFBTTtRQUNULENBQUNULEdBQUcsR0FBR1c7TUFBSztJQUVoQixDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7RUFDUjtFQUVBUyxLQUFLQSxDQUFDZixJQUFTLEVBQUVnQixPQUFZLEVBQUVDLE9BQVksRUFBRTtJQUMzQyxPQUFPVixTQUFTO0VBQ2xCO0FBQ0YifQ== |
export const DELETED = Symbol('ENTITY WAS DELETED'); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJERUxFVEVEIiwiU3ltYm9sIl0sInNvdXJjZXMiOlsiLi4vc3JjL3NwZWNpYWwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IERFTEVURUQgPSBTeW1ib2woJ0VOVElUWSBXQVMgREVMRVRFRCcpO1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU1BLE9BQU8sR0FBR0MsTUFBTSxDQUFDLG9CQUFvQixDQUFDIn0= | ||
export const INVALID = DELETED; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJERUxFVEVEIiwiU3ltYm9sIiwiSU5WQUxJRCJdLCJzb3VyY2VzIjpbIi4uL3NyYy9zcGVjaWFsLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBERUxFVEVEID0gU3ltYm9sKCdFTlRJVFkgV0FTIERFTEVURUQnKTtcbmV4cG9ydCBjb25zdCBJTlZBTElEID0gREVMRVRFRDtcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxNQUFNQSxPQUFPLEdBQUdDLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQztBQUNuRCxPQUFPLE1BQU1DLE9BQU8sR0FBR0YsT0FBTyJ9 |
export * from './utility.js'; | ||
export * from './ErrorTypes.js'; | ||
// This hack is only needed for @rest-hooks/rest@5 or below | ||
/** @deprecated */ | ||
/** @deprecated */ | ||
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU2NoZW1hLCBFbnRpdHlJbnRlcmZhY2UgfSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IFNjaGVtYUNsYXNzIH0gZnJvbSAnLi9zY2hlbWEuanMnO1xuaW1wb3J0IHsgU25hcHNob3RJbnRlcmZhY2UgfSBmcm9tICcuL1NuYXBzaG90SW50ZXJmYWNlLmpzJztcbmltcG9ydCB7IFJlc29sdmVUeXBlIH0gZnJvbSAnLi91dGlsaXR5LmpzJztcblxuZXhwb3J0ICogZnJvbSAnLi91dGlsaXR5LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vRXJyb3JUeXBlcy5qcyc7XG5cbmV4cG9ydCB0eXBlIEZldGNoRnVuY3Rpb248QSBleHRlbmRzIHJlYWRvbmx5IGFueVtdID0gYW55LCBSID0gYW55PiA9IChcbiAgLi4uYXJnczogQVxuKSA9PiBQcm9taXNlPFI+O1xuXG4vLyBUaGlzIGhhY2sgaXMgb25seSBuZWVkZWQgZm9yIEByZXN0LWhvb2tzL3Jlc3RANSBvciBiZWxvd1xuLyoqIEBkZXByZWNhdGVkICovXG5leHBvcnQgdHlwZSBTY2hlbWFEZXRhaWw8VD4gPVxuICB8IEVudGl0eUludGVyZmFjZTxUPlxuICB8IHsgW0s6IHN0cmluZ106IGFueSB9XG4gIHwgU2NoZW1hQ2xhc3M7XG5cbi8qKiBAZGVwcmVjYXRlZCAqL1xuZXhwb3J0IHR5cGUgU2NoZW1hTGlzdDxUPiA9XG4gIHwgRW50aXR5SW50ZXJmYWNlPFQ+W11cbiAgfCB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICB8IFNjaGVtYVtdXG4gIHwgU2NoZW1hQ2xhc3M7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW5kcG9pbnRFeHRyYU9wdGlvbnM8RiBleHRlbmRzIEZldGNoRnVuY3Rpb24gPSBGZXRjaEZ1bmN0aW9uPiB7XG4gIC8qKiBEZWZhdWx0IGRhdGEgZXhwaXJ5IGxlbmd0aCwgd2lsbCBmYWxsIGJhY2sgdG8gTmV0d29ya01hbmFnZXIgZGVmYXVsdCBpZiBub3QgZGVmaW5lZCAqL1xuICByZWFkb25seSBkYXRhRXhwaXJ5TGVuZ3RoPzogbnVtYmVyO1xuICAvKiogRGVmYXVsdCBlcnJvciBleHBpcnkgbGVuZ3RoLCB3aWxsIGZhbGwgYmFjayB0byBOZXR3b3JrTWFuYWdlciBkZWZhdWx0IGlmIG5vdCBkZWZpbmVkICovXG4gIHJlYWRvbmx5IGVycm9yRXhwaXJ5TGVuZ3RoPzogbnVtYmVyO1xuICAvKiogUG9sbCB3aXRoIGF0IGxlYXN0IHRoaXMgZnJlcXVlbmN5IGluIG1pbGlzZWNvbmRzICovXG4gIHJlYWRvbmx5IHBvbGxGcmVxdWVuY3k/OiBudW1iZXI7XG4gIC8qKiBNYXJrcyBjYWNoZWQgcmVzb3VyY2VzIGFzIGludmFsaWQgaWYgdGhleSBhcmUgc3RhbGUgKi9cbiAgcmVhZG9ubHkgaW52YWxpZElmU3RhbGU/OiBib29sZWFuO1xuICAvKiogRW5hYmxlcyBvcHRpbWlzdGljIHVwZGF0ZXMgZm9yIHRoaXMgcmVxdWVzdCAtIHVzZXMgcmV0dXJuIHZhbHVlIGFzIGFzc3VtZWQgbmV0d29yayByZXNwb25zZVxuICAgKiBAZGVwcmVjYXRlZCB1c2UgaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9hcGkvRW5kcG9pbnQjZ2V0b3B0aW1pc3RpY3Jlc3BvbnNlIGluc3RlYWRcbiAgICovXG4gIG9wdGltaXN0aWNVcGRhdGU/KC4uLmFyZ3M6IFBhcmFtZXRlcnM8Rj4pOiBSZXNvbHZlVHlwZTxGPjtcbiAgLyoqIEVuYWJsZXMgb3B0aW1pc3RpYyB1cGRhdGVzIGZvciB0aGlzIHJlcXVlc3QgLSB1c2VzIHJldHVybiB2YWx1ZSBhcyBhc3N1bWVkIG5ldHdvcmsgcmVzcG9uc2UgKi9cbiAgZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlPyhcbiAgICBzbmFwOiBTbmFwc2hvdEludGVyZmFjZSxcbiAgICAuLi5hcmdzOiBQYXJhbWV0ZXJzPEY+XG4gICk6IFJlc29sdmVUeXBlPEY+O1xuICAvKiogRGV0ZXJtaW5lcyB3aGV0aGVyIHRvIHRocm93IG9yIGZhbGxiYWNrIHRvICovXG4gIGVycm9yUG9saWN5PyhlcnJvcjogYW55KTogJ2hhcmQnIHwgJ3NvZnQnIHwgdW5kZWZpbmVkO1xuICAvKiogVXNlci1sYW5kIGV4dHJhIGRhdGEgdG8gc2VuZCAqL1xuICByZWFkb25seSBleHRyYT86IGFueTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBS0EsY0FBYyxjQUFjO0FBQzVCLGNBQWMsaUJBQWlCO0FBQUMifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU2NoZW1hLCBFbnRpdHlJbnRlcmZhY2UgfSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IFNjaGVtYUNsYXNzIH0gZnJvbSAnLi9zY2hlbWEuanMnO1xuaW1wb3J0IHsgU25hcHNob3RJbnRlcmZhY2UgfSBmcm9tICcuL1NuYXBzaG90SW50ZXJmYWNlLmpzJztcbmltcG9ydCB7IFJlc29sdmVUeXBlIH0gZnJvbSAnLi91dGlsaXR5LmpzJztcblxuZXhwb3J0ICogZnJvbSAnLi91dGlsaXR5LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vRXJyb3JUeXBlcy5qcyc7XG5cbmV4cG9ydCB0eXBlIEZldGNoRnVuY3Rpb248QSBleHRlbmRzIHJlYWRvbmx5IGFueVtdID0gYW55LCBSID0gYW55PiA9IChcbiAgLi4uYXJnczogQVxuKSA9PiBQcm9taXNlPFI+O1xuXG4vLyBUaGlzIGhhY2sgaXMgb25seSBuZWVkZWQgZm9yIEByZXN0LWhvb2tzL3Jlc3RANSBvciBiZWxvd1xuLyoqIEBkZXByZWNhdGVkICovXG5leHBvcnQgdHlwZSBTY2hlbWFEZXRhaWw8VD4gPVxuICB8IEVudGl0eUludGVyZmFjZTxUPlxuICB8IHsgW0s6IHN0cmluZ106IGFueSB9XG4gIHwgU2NoZW1hQ2xhc3M7XG5cbi8qKiBAZGVwcmVjYXRlZCAqL1xuZXhwb3J0IHR5cGUgU2NoZW1hTGlzdDxUPiA9XG4gIHwgRW50aXR5SW50ZXJmYWNlPFQ+W11cbiAgfCB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICB8IFNjaGVtYVtdXG4gIHwgU2NoZW1hQ2xhc3M7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW5kcG9pbnRFeHRyYU9wdGlvbnM8RiBleHRlbmRzIEZldGNoRnVuY3Rpb24gPSBGZXRjaEZ1bmN0aW9uPiB7XG4gIC8qKiBEZWZhdWx0IGRhdGEgZXhwaXJ5IGxlbmd0aCwgd2lsbCBmYWxsIGJhY2sgdG8gTmV0d29ya01hbmFnZXIgZGVmYXVsdCBpZiBub3QgZGVmaW5lZCAqL1xuICByZWFkb25seSBkYXRhRXhwaXJ5TGVuZ3RoPzogbnVtYmVyO1xuICAvKiogRGVmYXVsdCBlcnJvciBleHBpcnkgbGVuZ3RoLCB3aWxsIGZhbGwgYmFjayB0byBOZXR3b3JrTWFuYWdlciBkZWZhdWx0IGlmIG5vdCBkZWZpbmVkICovXG4gIHJlYWRvbmx5IGVycm9yRXhwaXJ5TGVuZ3RoPzogbnVtYmVyO1xuICAvKiogUG9sbCB3aXRoIGF0IGxlYXN0IHRoaXMgZnJlcXVlbmN5IGluIG1pbGlzZWNvbmRzICovXG4gIHJlYWRvbmx5IHBvbGxGcmVxdWVuY3k/OiBudW1iZXI7XG4gIC8qKiBNYXJrcyBjYWNoZWQgcmVzb3VyY2VzIGFzIGludmFsaWQgaWYgdGhleSBhcmUgc3RhbGUgKi9cbiAgcmVhZG9ubHkgaW52YWxpZElmU3RhbGU/OiBib29sZWFuO1xuICAvKiogRW5hYmxlcyBvcHRpbWlzdGljIHVwZGF0ZXMgZm9yIHRoaXMgcmVxdWVzdCAtIHVzZXMgcmV0dXJuIHZhbHVlIGFzIGFzc3VtZWQgbmV0d29yayByZXNwb25zZVxuICAgKiBAZGVwcmVjYXRlZCB1c2UgaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9hcGkvRW5kcG9pbnQjZ2V0b3B0aW1pc3RpY3Jlc3BvbnNlIGluc3RlYWRcbiAgICovXG4gIG9wdGltaXN0aWNVcGRhdGU/KC4uLmFyZ3M6IFBhcmFtZXRlcnM8Rj4pOiBSZXNvbHZlVHlwZTxGPjtcbiAgLyoqIEVuYWJsZXMgb3B0aW1pc3RpYyB1cGRhdGVzIGZvciB0aGlzIHJlcXVlc3QgLSB1c2VzIHJldHVybiB2YWx1ZSBhcyBhc3N1bWVkIG5ldHdvcmsgcmVzcG9uc2UgKi9cbiAgZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlPyhcbiAgICBzbmFwOiBTbmFwc2hvdEludGVyZmFjZSxcbiAgICAuLi5hcmdzOiBQYXJhbWV0ZXJzPEY+XG4gICk6IFJlc29sdmVUeXBlPEY+O1xuICAvKiogRGV0ZXJtaW5lcyB3aGV0aGVyIHRvIHRocm93IG9yIGZhbGxiYWNrIHRvICovXG4gIGVycm9yUG9saWN5PyhlcnJvcjogYW55KTogJ2hhcmQnIHwgJ3NvZnQnIHwgdW5kZWZpbmVkO1xuICAvKiogVXNlci1sYW5kIGV4dHJhIGRhdGEgdG8gc2VuZCAqL1xuICByZWFkb25seSBleHRyYT86IGFueTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBS0EsY0FBYyxjQUFjO0FBQzVCLGNBQWMsaUJBQWlCOztBQU0vQjtBQUNBO0FBTUE7QUFBQSJ9 |
@@ -5,4 +5,4 @@ export type { EndpointInterface, ReadEndpoint, MutateEndpoint, } from './interface.js'; | ||
export { default as Entity } from './schemas/Entity.js'; | ||
export { default as validateRequired } from './schemas/validatRequired.js'; | ||
export { DELETED } from './special.js'; | ||
export { default as validateRequired } from './validateRequired.js'; | ||
export { DELETED, INVALID } from './special.js'; | ||
export type { Schema, SnapshotInterface, ExpiryStatusInterface, } from './interface.js'; | ||
@@ -9,0 +9,0 @@ export type { AbstractInstanceType, Normalize, NormalizeNullable, Denormalize, DenormalizeNullable, } from './normal.js'; |
@@ -7,4 +7,4 @@ Object.hasOwn = Object.hasOwn || /* istanbul ignore next */function hasOwn(it, key) { | ||
export { default as Entity } from './schemas/Entity.js'; | ||
export { default as validateRequired } from './schemas/validatRequired.js'; | ||
export { DELETED } from './special.js'; | ||
export { default as validateRequired } from './validateRequired.js'; | ||
export { DELETED, INVALID } from './special.js'; | ||
export { default as Endpoint, ExtendableEndpoint } from './endpoint.js'; | ||
@@ -14,2 +14,2 @@ export * from './indexEndpoint.js'; | ||
export { default as AbortOptimistic } from './AbortOptimistic.js'; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPYmplY3QiLCJoYXNPd24iLCJpdCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIl9zY2hlbWEiLCJzY2hlbWEiLCJkZWZhdWx0IiwiRW50aXR5IiwidmFsaWRhdGVSZXF1aXJlZCIsIkRFTEVURUQiLCJFbmRwb2ludCIsIkV4dGVuZGFibGVFbmRwb2ludCIsIkFib3J0T3B0aW1pc3RpYyJdLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuaGFzT3duID1cbiAgT2JqZWN0Lmhhc093biB8fFxuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqLyBmdW5jdGlvbiBoYXNPd24oaXQsIGtleSkge1xuICAgIHJldHVybiBPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoaXQsIGtleSk7XG4gIH07XG5cbmV4cG9ydCB0eXBlIHtcbiAgRW5kcG9pbnRJbnRlcmZhY2UsXG4gIFJlYWRFbmRwb2ludCxcbiAgTXV0YXRlRW5kcG9pbnQsXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcbmV4cG9ydCB0eXBlIHtcbiAgRW5kcG9pbnRPcHRpb25zLFxuICBFbmRwb2ludEluc3RhbmNlLFxuICBFbmRwb2ludEluc3RhbmNlSW50ZXJmYWNlLFxuICBFbmRwb2ludEV4dGVuZE9wdGlvbnMsXG59IGZyb20gJy4vZW5kcG9pbnQuanMnO1xuZXhwb3J0ICogYXMgc2NoZW1hIGZyb20gJy4vc2NoZW1hLmpzJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRW50aXR5IH0gZnJvbSAnLi9zY2hlbWFzL0VudGl0eS5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIHZhbGlkYXRlUmVxdWlyZWQgfSBmcm9tICcuL3NjaGVtYXMvdmFsaWRhdFJlcXVpcmVkLmpzJztcbmV4cG9ydCB7IERFTEVURUQgfSBmcm9tICcuL3NwZWNpYWwuanMnO1xuZXhwb3J0IHR5cGUge1xuICBTY2hlbWEsXG4gIFNuYXBzaG90SW50ZXJmYWNlLFxuICBFeHBpcnlTdGF0dXNJbnRlcmZhY2UsXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcbmV4cG9ydCB0eXBlIHtcbiAgQWJzdHJhY3RJbnN0YW5jZVR5cGUsXG4gIE5vcm1hbGl6ZSxcbiAgTm9ybWFsaXplTnVsbGFibGUsXG4gIERlbm9ybWFsaXplLFxuICBEZW5vcm1hbGl6ZU51bGxhYmxlLFxufSBmcm9tICcuL25vcm1hbC5qcyc7XG5leHBvcnQgdHlwZSB7XG4gIEVuZHBvaW50RXh0cmFPcHRpb25zLFxuICBGZXRjaEZ1bmN0aW9uLFxuICBTY2hlbWFEZXRhaWwsXG4gIFNjaGVtYUxpc3QsXG4gIFJlc29sdmVUeXBlLFxuICBFbmRwb2ludFBhcmFtLFxuICBOZXR3b3JrRXJyb3IsXG4gIFVua25vd25FcnJvcixcbiAgRXJyb3JUeXBlcyxcbn0gZnJvbSAnLi90eXBlcy5qcyc7XG5cbmV4cG9ydCB7IGRlZmF1bHQgYXMgRW5kcG9pbnQsIEV4dGVuZGFibGVFbmRwb2ludCB9IGZyb20gJy4vZW5kcG9pbnQuanMnO1xuZXhwb3J0IHR5cGUgeyBLZXlvZkVuZHBvaW50SW5zdGFuY2UgfSBmcm9tICcuL2VuZHBvaW50LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vaW5kZXhFbmRwb2ludC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL3F1ZXJ5RW5kcG9pbnQuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBBYm9ydE9wdGltaXN0aWMgfSBmcm9tICcuL0Fib3J0T3B0aW1pc3RpYy5qcyc7XG4iXSwibWFwcGluZ3MiOiJBQUFBQSxNQUFNLENBQUNDLE1BQU0sR0FDWEQsTUFBTSxDQUFDQyxNQUFNLElBQ2IsMEJBQTJCLFNBQVNBLE1BQU1BLENBQUNDLEVBQUUsRUFBRUMsR0FBRyxFQUFFO0VBQ2xELE9BQU9ILE1BQU0sQ0FBQ0ksU0FBUyxDQUFDQyxjQUFjLENBQUNDLElBQUksQ0FBQ0osRUFBRSxFQUFFQyxHQUFHLENBQUM7QUFDdEQsQ0FBQztBQUFDLFlBQUFJLE9BQUEsTUFhb0IsYUFBYTtBQUFBLFNBQUFBLE9BQUEsSUFBekJDLE1BQU07QUFDbEIsU0FBU0MsT0FBTyxJQUFJQyxNQUFNLFFBQVEscUJBQXFCO0FBQ3ZELFNBQVNELE9BQU8sSUFBSUUsZ0JBQWdCLFFBQVEsOEJBQThCO0FBQzFFLFNBQVNDLE9BQU8sUUFBUSxjQUFjO0FBeUJ0QyxTQUFTSCxPQUFPLElBQUlJLFFBQVEsRUFBRUMsa0JBQWtCLFFBQVEsZUFBZTtBQUV2RSxjQUFjLG9CQUFvQjtBQUNsQyxjQUFjLG9CQUFvQjtBQUNsQyxTQUFTTCxPQUFPLElBQUlNLGVBQWUsUUFBUSxzQkFBc0IifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPYmplY3QiLCJoYXNPd24iLCJpdCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsIl9zY2hlbWEiLCJzY2hlbWEiLCJkZWZhdWx0IiwiRW50aXR5IiwidmFsaWRhdGVSZXF1aXJlZCIsIkRFTEVURUQiLCJJTlZBTElEIiwiRW5kcG9pbnQiLCJFeHRlbmRhYmxlRW5kcG9pbnQiLCJBYm9ydE9wdGltaXN0aWMiXSwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiT2JqZWN0Lmhhc093biA9XG4gIE9iamVjdC5oYXNPd24gfHxcbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi8gZnVuY3Rpb24gaGFzT3duKGl0LCBrZXkpIHtcbiAgICByZXR1cm4gT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKGl0LCBrZXkpO1xuICB9O1xuXG5leHBvcnQgdHlwZSB7XG4gIEVuZHBvaW50SW50ZXJmYWNlLFxuICBSZWFkRW5kcG9pbnQsXG4gIE11dGF0ZUVuZHBvaW50LFxufSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5leHBvcnQgdHlwZSB7XG4gIEVuZHBvaW50T3B0aW9ucyxcbiAgRW5kcG9pbnRJbnN0YW5jZSxcbiAgRW5kcG9pbnRJbnN0YW5jZUludGVyZmFjZSxcbiAgRW5kcG9pbnRFeHRlbmRPcHRpb25zLFxufSBmcm9tICcuL2VuZHBvaW50LmpzJztcbmV4cG9ydCAqIGFzIHNjaGVtYSBmcm9tICcuL3NjaGVtYS5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEVudGl0eSB9IGZyb20gJy4vc2NoZW1hcy9FbnRpdHkuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyB2YWxpZGF0ZVJlcXVpcmVkIH0gZnJvbSAnLi92YWxpZGF0ZVJlcXVpcmVkLmpzJztcbmV4cG9ydCB7IERFTEVURUQsIElOVkFMSUQgfSBmcm9tICcuL3NwZWNpYWwuanMnO1xuZXhwb3J0IHR5cGUge1xuICBTY2hlbWEsXG4gIFNuYXBzaG90SW50ZXJmYWNlLFxuICBFeHBpcnlTdGF0dXNJbnRlcmZhY2UsXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcbmV4cG9ydCB0eXBlIHtcbiAgQWJzdHJhY3RJbnN0YW5jZVR5cGUsXG4gIE5vcm1hbGl6ZSxcbiAgTm9ybWFsaXplTnVsbGFibGUsXG4gIERlbm9ybWFsaXplLFxuICBEZW5vcm1hbGl6ZU51bGxhYmxlLFxufSBmcm9tICcuL25vcm1hbC5qcyc7XG5leHBvcnQgdHlwZSB7XG4gIEVuZHBvaW50RXh0cmFPcHRpb25zLFxuICBGZXRjaEZ1bmN0aW9uLFxuICBTY2hlbWFEZXRhaWwsXG4gIFNjaGVtYUxpc3QsXG4gIFJlc29sdmVUeXBlLFxuICBFbmRwb2ludFBhcmFtLFxuICBOZXR3b3JrRXJyb3IsXG4gIFVua25vd25FcnJvcixcbiAgRXJyb3JUeXBlcyxcbn0gZnJvbSAnLi90eXBlcy5qcyc7XG5cbmV4cG9ydCB7IGRlZmF1bHQgYXMgRW5kcG9pbnQsIEV4dGVuZGFibGVFbmRwb2ludCB9IGZyb20gJy4vZW5kcG9pbnQuanMnO1xuZXhwb3J0IHR5cGUgeyBLZXlvZkVuZHBvaW50SW5zdGFuY2UgfSBmcm9tICcuL2VuZHBvaW50LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vaW5kZXhFbmRwb2ludC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL3F1ZXJ5RW5kcG9pbnQuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBBYm9ydE9wdGltaXN0aWMgfSBmcm9tICcuL0Fib3J0T3B0aW1pc3RpYy5qcyc7XG4iXSwibWFwcGluZ3MiOiJBQUFBQSxNQUFNLENBQUNDLE1BQU0sR0FDWEQsTUFBTSxDQUFDQyxNQUFNLElBQ2IsMEJBQTJCLFNBQVNBLE1BQU1BLENBQUNDLEVBQUUsRUFBRUMsR0FBRyxFQUFFO0VBQ2xELE9BQU9ILE1BQU0sQ0FBQ0ksU0FBUyxDQUFDQyxjQUFjLENBQUNDLElBQUksQ0FBQ0osRUFBRSxFQUFFQyxHQUFHLENBQUM7QUFDdEQsQ0FBQztBQUFDLFlBQUFJLE9BQUEsTUFhb0IsYUFBYTtBQUFBLFNBQUFBLE9BQUEsSUFBekJDLE1BQU07QUFDbEIsU0FBU0MsT0FBTyxJQUFJQyxNQUFNLFFBQVEscUJBQXFCO0FBQ3ZELFNBQVNELE9BQU8sSUFBSUUsZ0JBQWdCLFFBQVEsdUJBQXVCO0FBQ25FLFNBQVNDLE9BQU8sRUFBRUMsT0FBTyxRQUFRLGNBQWM7QUF5Qi9DLFNBQVNKLE9BQU8sSUFBSUssUUFBUSxFQUFFQyxrQkFBa0IsUUFBUSxlQUFlO0FBRXZFLGNBQWMsb0JBQW9CO0FBQ2xDLGNBQWMsb0JBQW9CO0FBQ2xDLFNBQVNOLE9BQU8sSUFBSU8sZUFBZSxRQUFRLHNCQUFzQiJ9 |
@@ -14,4 +14,5 @@ import type { EndpointExtraOptions, FetchFunction } from './types.js'; | ||
export interface SchemaSimple<T = any> { | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): any; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args: any[]): any; | ||
denormalize(input: {}, unvisit: UnvisitFunction): [denormalized: T, found: boolean, suspend: boolean]; | ||
denormalizeOnly?(input: {}, args: any, unvisit: (input: any, schema: any) => any): T; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
@@ -25,3 +26,3 @@ } | ||
createIfValid?(props: any): any; | ||
pk(params: any, parent?: any, key?: string): string | undefined; | ||
pk(params: any, parent?: any, key?: string, args?: any[]): string | undefined; | ||
readonly key: string; | ||
@@ -31,2 +32,3 @@ merge(existing: any, incoming: any): any; | ||
mergeWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
mergeMetaWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
useIncoming?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): boolean; | ||
@@ -38,3 +40,3 @@ indexes?: any; | ||
export interface UnvisitFunction { | ||
(input: any, schema: any): [any, boolean, boolean]; | ||
(input: any, schema: any): [any, boolean, boolean] | any; | ||
og?: UnvisitFunction; | ||
@@ -41,0 +43,0 @@ setLocal?: (entity: any) => void; |
export * from './SnapshotInterface.js'; | ||
/** Defines a networking endpoint */ | ||
/** To change values on the server */ | ||
/** For retrieval requests */ | ||
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2ludGVyZmFjZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdEluc3RhbmNlVHlwZSwgRGVub3JtYWxpemUsIEVudGl0eU1hcCB9IGZyb20gJy4vbm9ybWFsLmpzJztcbmltcG9ydCB0eXBlIHsgRW5kcG9pbnRFeHRyYU9wdGlvbnMsIEZldGNoRnVuY3Rpb24gfSBmcm9tICcuL3R5cGVzLmpzJztcblxuZXhwb3J0ICogZnJvbSAnLi9TbmFwc2hvdEludGVyZmFjZS5qcyc7XG5cbmV4cG9ydCB0eXBlIFNjaGVtYSA9XG4gIHwgbnVsbFxuICB8IHN0cmluZ1xuICB8IHsgW0s6IHN0cmluZ106IGFueSB9XG4gIHwgU2NoZW1hW11cbiAgfCBTY2hlbWFTaW1wbGVcbiAgfCBTZXJpYWxpemFibGU7XG5cbmV4cG9ydCB0eXBlIFNlcmlhbGl6YWJsZTxcbiAgVCBleHRlbmRzIHsgdG9KU09OKCk6IHN0cmluZyB9ID0geyB0b0pTT04oKTogc3RyaW5nIH0sXG4+ID0ge1xuICBwcm90b3R5cGU6IFQ7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYVNpbXBsZTxUID0gYW55PiB7XG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgYWRkRW50aXR5OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+LFxuICApOiBhbnk7XG4gIGRlbm9ybWFsaXplKFxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG4gICAgaW5wdXQ6IHt9LFxuICAgIHVudmlzaXQ6IFVudmlzaXRGdW5jdGlvbixcbiAgKTogW2Rlbm9ybWFsaXplZDogVCwgZm91bmQ6IGJvb2xlYW4sIHN1c3BlbmQ6IGJvb2xlYW5dO1xuICBpbmZlcihcbiAgICBhcmdzOiByZWFkb25seSBhbnlbXSxcbiAgICBpbmRleGVzOiBOb3JtYWxpemVkSW5kZXgsXG4gICAgcmVjdXJzZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIGVudGl0aWVzOiBFbnRpdHlUYWJsZSxcbiAgKTogYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYUNsYXNzPFQgPSBhbnksIE4gPSBUIHwgdW5kZWZpbmVkPlxuICBleHRlbmRzIFNjaGVtYVNpbXBsZTxUPiB7XG4gIC8vIHRoaXMgaXMgbm90IGFuIGFjdHVhbCBtZW1iZXIsIGJ1dCBpcyBuZWVkZWQgZm9yIHRoZSByZWN1cnNpdmUgTm9ybWFsaXplTnVsbGFibGU8PiB0eXBlIGFsZ29cbiAgX25vcm1hbGl6ZU51bGxhYmxlKCk6IGFueTtcbiAgLy8gdGhpcyBpcyBub3QgYW4gYWN0dWFsIG1lbWJlciwgYnV0IGlzIG5lZWRlZCBmb3IgdGhlIHJlY3Vyc2l2ZSBEZW5vcm1hbGl6ZU51bGxhYmxlPD4gdHlwZSBhbGdvXG4gIF9kZW5vcm1hbGl6ZU51bGxhYmxlKCk6IFtOLCBib29sZWFuLCBib29sZWFuXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbnRpdHlJbnRlcmZhY2U8VCA9IGFueT4gZXh0ZW5kcyBTY2hlbWFTaW1wbGUge1xuICBjcmVhdGVJZlZhbGlkPyhwcm9wczogYW55KTogYW55O1xuICBwayhwYXJhbXM6IGFueSwgcGFyZW50PzogYW55LCBrZXk/OiBzdHJpbmcpOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIHJlYWRvbmx5IGtleTogc3RyaW5nO1xuICBtZXJnZShleGlzdGluZzogYW55LCBpbmNvbWluZzogYW55KTogYW55O1xuICBleHBpcmVzQXQ/KG1ldGE6IGFueSwgaW5wdXQ6IGFueSk6IG51bWJlcjtcbiAgbWVyZ2VXaXRoU3RvcmU/KFxuICAgIGV4aXN0aW5nTWV0YTogYW55LFxuICAgIGluY29taW5nTWV0YTogYW55LFxuICAgIGV4aXN0aW5nOiBhbnksXG4gICAgaW5jb21pbmc6IGFueSxcbiAgKTogYW55O1xuICAvLyBUT0RPKGJyZWFraW5nKTogZGVwcmVjYXRlIHRoaXNcbiAgdXNlSW5jb21pbmc/KFxuICAgIGV4aXN0aW5nTWV0YTogYW55LFxuICAgIGluY29taW5nTWV0YTogYW55LFxuICAgIGV4aXN0aW5nOiBhbnksXG4gICAgaW5jb21pbmc6IGFueSxcbiAgKTogYm9vbGVhbjtcbiAgaW5kZXhlcz86IGFueTtcbiAgc2NoZW1hOiBSZWNvcmQ8c3RyaW5nLCBTY2hlbWE+O1xuICBwcm90b3R5cGU6IFQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVW52aXNpdEZ1bmN0aW9uIHtcbiAgKGlucHV0OiBhbnksIHNjaGVtYTogYW55KTogW2FueSwgYm9vbGVhbiwgYm9vbGVhbl07XG4gIG9nPzogVW52aXNpdEZ1bmN0aW9uO1xuICBzZXRMb2NhbD86IChlbnRpdHk6IGFueSkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBOb3JtYWxpemVkSW5kZXgge1xuICByZWFkb25seSBbZW50aXR5S2V5OiBzdHJpbmddOiB7XG4gICAgcmVhZG9ubHkgW2luZGV4TmFtZTogc3RyaW5nXTogeyByZWFkb25seSBbbG9va3VwOiBzdHJpbmddOiBzdHJpbmcgfTtcbiAgfTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbnRpdHlUYWJsZSB7XG4gIFtlbnRpdHlLZXk6IHN0cmluZ106XG4gICAgfCB7XG4gICAgICAgIFtwazogc3RyaW5nXTogdW5rbm93bjtcbiAgICAgIH1cbiAgICB8IHVuZGVmaW5lZDtcbn1cblxuLyoqIERlZmluZXMgYSBuZXR3b3JraW5nIGVuZHBvaW50ICovXG5leHBvcnQgaW50ZXJmYWNlIEVuZHBvaW50SW50ZXJmYWNlPFxuICBGIGV4dGVuZHMgRmV0Y2hGdW5jdGlvbiA9IEZldGNoRnVuY3Rpb24sXG4gIFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBTY2hlbWEgfCB1bmRlZmluZWQsXG4gIE0gZXh0ZW5kcyB0cnVlIHwgdW5kZWZpbmVkID0gdHJ1ZSB8IHVuZGVmaW5lZCxcbj4gZXh0ZW5kcyBFbmRwb2ludEV4dHJhT3B0aW9uczxGPiB7XG4gICguLi5hcmdzOiBQYXJhbWV0ZXJzPEY+KTogUmV0dXJuVHlwZTxGPjtcbiAga2V5KC4uLmFyZ3M6IFBhcmFtZXRlcnM8Rj4pOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHNpZGVFZmZlY3Q/OiBNO1xuICByZWFkb25seSBzY2hlbWE/OiBTO1xufVxuXG4vKiogVG8gY2hhbmdlIHZhbHVlcyBvbiB0aGUgc2VydmVyICovXG5leHBvcnQgaW50ZXJmYWNlIE11dGF0ZUVuZHBvaW50PFxuICBGIGV4dGVuZHMgRmV0Y2hGdW5jdGlvbiA9IEZldGNoRnVuY3Rpb24sXG4gIFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBTY2hlbWEgfCB1bmRlZmluZWQsXG4+IGV4dGVuZHMgRW5kcG9pbnRJbnRlcmZhY2U8RiwgUywgdHJ1ZT4ge1xuICBzaWRlRWZmZWN0OiB0cnVlO1xufVxuXG4vKiogRm9yIHJldHJpZXZhbCByZXF1ZXN0cyAqL1xuZXhwb3J0IHR5cGUgUmVhZEVuZHBvaW50PFxuICBGIGV4dGVuZHMgRmV0Y2hGdW5jdGlvbiA9IEZldGNoRnVuY3Rpb24sXG4gIFMgZXh0ZW5kcyBTY2hlbWEgfCB1bmRlZmluZWQgPSBTY2hlbWEgfCB1bmRlZmluZWQsXG4+ID0gRW5kcG9pbnRJbnRlcmZhY2U8RiwgUywgdW5kZWZpbmVkPjtcbiJdLCJtYXBwaW5ncyI6IkFBR0EsY0FBYyx3QkFBd0I7QUFBQyJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2ludGVyZmFjZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdEluc3RhbmNlVHlwZSwgRGVub3JtYWxpemUsIEVudGl0eU1hcCB9IGZyb20gJy4vbm9ybWFsLmpzJztcbmltcG9ydCB0eXBlIHsgRW5kcG9pbnRFeHRyYU9wdGlvbnMsIEZldGNoRnVuY3Rpb24gfSBmcm9tICcuL3R5cGVzLmpzJztcblxuZXhwb3J0ICogZnJvbSAnLi9TbmFwc2hvdEludGVyZmFjZS5qcyc7XG5cbmV4cG9ydCB0eXBlIFNjaGVtYSA9XG4gIHwgbnVsbFxuICB8IHN0cmluZ1xuICB8IHsgW0s6IHN0cmluZ106IGFueSB9XG4gIHwgU2NoZW1hW11cbiAgfCBTY2hlbWFTaW1wbGVcbiAgfCBTZXJpYWxpemFibGU7XG5cbmV4cG9ydCB0eXBlIFNlcmlhbGl6YWJsZTxcbiAgVCBleHRlbmRzIHsgdG9KU09OKCk6IHN0cmluZyB9ID0geyB0b0pTT04oKTogc3RyaW5nIH0sXG4+ID0ge1xuICBwcm90b3R5cGU6IFQ7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYVNpbXBsZTxUID0gYW55PiB7XG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgYWRkRW50aXR5OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+LFxuICAgIHN0b3JlRW50aXRpZXM6IGFueSxcbiAgICBhcmdzOiBhbnlbXSxcbiAgKTogYW55O1xuICBkZW5vcm1hbGl6ZShcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuICAgIGlucHV0OiB7fSxcbiAgICB1bnZpc2l0OiBVbnZpc2l0RnVuY3Rpb24sXG4gICk6IFtkZW5vcm1hbGl6ZWQ6IFQsIGZvdW5kOiBib29sZWFuLCBzdXNwZW5kOiBib29sZWFuXTtcbiAgZGVub3JtYWxpemVPbmx5PyhcbiAgICBpbnB1dDoge30sXG4gICAgYXJnczogYW55LFxuICAgIHVudmlzaXQ6IChpbnB1dDogYW55LCBzY2hlbWE6IGFueSkgPT4gYW55LFxuICApOiBUO1xuICBpbmZlcihcbiAgICBhcmdzOiByZWFkb25seSBhbnlbXSxcbiAgICBpbmRleGVzOiBOb3JtYWxpemVkSW5kZXgsXG4gICAgcmVjdXJzZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIGVudGl0aWVzOiBFbnRpdHlUYWJsZSxcbiAgKTogYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYUNsYXNzPFQgPSBhbnksIE4gPSBUIHwgdW5kZWZpbmVkPlxuICBleHRlbmRzIFNjaGVtYVNpbXBsZTxUPiB7XG4gIC8vIHRoaXMgaXMgbm90IGFuIGFjdHVhbCBtZW1iZXIsIGJ1dCBpcyBuZWVkZWQgZm9yIHRoZSByZWN1cnNpdmUgTm9ybWFsaXplTnVsbGFibGU8PiB0eXBlIGFsZ29cbiAgX25vcm1hbGl6ZU51bGxhYmxlKCk6IGFueTtcbiAgLy8gdGhpcyBpcyBub3QgYW4gYWN0dWFsIG1lbWJlciwgYnV0IGlzIG5lZWRlZCBmb3IgdGhlIHJlY3Vyc2l2ZSBEZW5vcm1hbGl6ZU51bGxhYmxlPD4gdHlwZSBhbGdvXG4gIF9kZW5vcm1hbGl6ZU51bGxhYmxlKCk6IFtOLCBib29sZWFuLCBib29sZWFuXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbnRpdHlJbnRlcmZhY2U8VCA9IGFueT4gZXh0ZW5kcyBTY2hlbWFTaW1wbGUge1xuICBjcmVhdGVJZlZhbGlkPyhwcm9wczogYW55KTogYW55O1xuICBwayhwYXJhbXM6IGFueSwgcGFyZW50PzogYW55LCBrZXk/OiBzdHJpbmcsIGFyZ3M/OiBhbnlbXSk6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgcmVhZG9ubHkga2V5OiBzdHJpbmc7XG4gIG1lcmdlKGV4aXN0aW5nOiBhbnksIGluY29taW5nOiBhbnkpOiBhbnk7XG4gIGV4cGlyZXNBdD8obWV0YTogYW55LCBpbnB1dDogYW55KTogbnVtYmVyO1xuICBtZXJnZVdpdGhTdG9yZT8oXG4gICAgZXhpc3RpbmdNZXRhOiBhbnksXG4gICAgaW5jb21pbmdNZXRhOiBhbnksXG4gICAgZXhpc3Rpbmc6IGFueSxcbiAgICBpbmNvbWluZzogYW55LFxuICApOiBhbnk7XG4gIG1lcmdlTWV0YVdpdGhTdG9yZT8oXG4gICAgZXhpc3RpbmdNZXRhOiBhbnksXG4gICAgaW5jb21pbmdNZXRhOiBhbnksXG4gICAgZXhpc3Rpbmc6IGFueSxcbiAgICBpbmNvbWluZzogYW55LFxuICApOiBhbnk7XG4gIC8vIFRPRE8oYnJlYWtpbmcpOiBkZXByZWNhdGUgdGhpc1xuICB1c2VJbmNvbWluZz8oXG4gICAgZXhpc3RpbmdNZXRhOiBhbnksXG4gICAgaW5jb21pbmdNZXRhOiBhbnksXG4gICAgZXhpc3Rpbmc6IGFueSxcbiAgICBpbmNvbWluZzogYW55LFxuICApOiBib29sZWFuO1xuICBpbmRleGVzPzogYW55O1xuICBzY2hlbWE6IFJlY29yZDxzdHJpbmcsIFNjaGVtYT47XG4gIHByb3RvdHlwZTogVDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVbnZpc2l0RnVuY3Rpb24ge1xuICAoaW5wdXQ6IGFueSwgc2NoZW1hOiBhbnkpOiBbYW55LCBib29sZWFuLCBib29sZWFuXSB8IGFueTtcbiAgb2c/OiBVbnZpc2l0RnVuY3Rpb247XG4gIHNldExvY2FsPzogKGVudGl0eTogYW55KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE5vcm1hbGl6ZWRJbmRleCB7XG4gIHJlYWRvbmx5IFtlbnRpdHlLZXk6IHN0cmluZ106IHtcbiAgICByZWFkb25seSBbaW5kZXhOYW1lOiBzdHJpbmddOiB7IHJlYWRvbmx5IFtsb29rdXA6IHN0cmluZ106IHN0cmluZyB9O1xuICB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVudGl0eVRhYmxlIHtcbiAgW2VudGl0eUtleTogc3RyaW5nXTpcbiAgICB8IHtcbiAgICAgICAgW3BrOiBzdHJpbmddOiB1bmtub3duO1xuICAgICAgfVxuICAgIHwgdW5kZWZpbmVkO1xufVxuXG4vKiogRGVmaW5lcyBhIG5ldHdvcmtpbmcgZW5kcG9pbnQgKi9cbmV4cG9ydCBpbnRlcmZhY2UgRW5kcG9pbnRJbnRlcmZhY2U8XG4gIEYgZXh0ZW5kcyBGZXRjaEZ1bmN0aW9uID0gRmV0Y2hGdW5jdGlvbixcbiAgUyBleHRlbmRzIFNjaGVtYSB8IHVuZGVmaW5lZCA9IFNjaGVtYSB8IHVuZGVmaW5lZCxcbiAgTSBleHRlbmRzIHRydWUgfCB1bmRlZmluZWQgPSB0cnVlIHwgdW5kZWZpbmVkLFxuPiBleHRlbmRzIEVuZHBvaW50RXh0cmFPcHRpb25zPEY+IHtcbiAgKC4uLmFyZ3M6IFBhcmFtZXRlcnM8Rj4pOiBSZXR1cm5UeXBlPEY+O1xuICBrZXkoLi4uYXJnczogUGFyYW1ldGVyczxGPik6IHN0cmluZztcbiAgcmVhZG9ubHkgc2lkZUVmZmVjdD86IE07XG4gIHJlYWRvbmx5IHNjaGVtYT86IFM7XG59XG5cbi8qKiBUbyBjaGFuZ2UgdmFsdWVzIG9uIHRoZSBzZXJ2ZXIgKi9cbmV4cG9ydCBpbnRlcmZhY2UgTXV0YXRlRW5kcG9pbnQ8XG4gIEYgZXh0ZW5kcyBGZXRjaEZ1bmN0aW9uID0gRmV0Y2hGdW5jdGlvbixcbiAgUyBleHRlbmRzIFNjaGVtYSB8IHVuZGVmaW5lZCA9IFNjaGVtYSB8IHVuZGVmaW5lZCxcbj4gZXh0ZW5kcyBFbmRwb2ludEludGVyZmFjZTxGLCBTLCB0cnVlPiB7XG4gIHNpZGVFZmZlY3Q6IHRydWU7XG59XG5cbi8qKiBGb3IgcmV0cmlldmFsIHJlcXVlc3RzICovXG5leHBvcnQgdHlwZSBSZWFkRW5kcG9pbnQ8XG4gIEYgZXh0ZW5kcyBGZXRjaEZ1bmN0aW9uID0gRmV0Y2hGdW5jdGlvbixcbiAgUyBleHRlbmRzIFNjaGVtYSB8IHVuZGVmaW5lZCA9IFNjaGVtYSB8IHVuZGVmaW5lZCxcbj4gPSBFbmRwb2ludEludGVyZmFjZTxGLCBTLCB1bmRlZmluZWQ+O1xuIl0sIm1hcHBpbmdzIjoiQUFHQSxjQUFjLHdCQUF3Qjs7QUF1R3RDOztBQVlBOztBQVFBO0FBQUEifQ== |
@@ -1,2 +0,2 @@ | ||
import type { Schema, Serializable, EntityInterface, NormalizedIndex, SchemaClass } from './interface.js'; | ||
import type { Schema, Serializable, EntityInterface, NormalizedIndex } from './interface.js'; | ||
export type AbstractInstanceType<T> = T extends new (...args: any) => infer U ? U : T extends { | ||
@@ -37,12 +37,22 @@ prototype: infer U; | ||
export type NormalizeReturnType<T> = T extends (...args: any) => infer R ? R : never; | ||
export type Denormalize<S> = S extends EntityInterface<infer U> ? U : S extends RecordClass ? AbstractInstanceType<S> : S extends SchemaClass ? DenormalizeReturnType<S['denormalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] : S extends { | ||
export type Denormalize<S> = S extends EntityInterface<infer U> ? U : S extends RecordClass ? AbstractInstanceType<S> : S extends { | ||
denormalizeOnly: (...args: any) => any; | ||
} ? ReturnType<S['denormalizeOnly']> : S extends { | ||
denormalize: (...args: any) => any; | ||
} ? DenormalizeReturnType<S['denormalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] : S extends { | ||
[K: string]: any; | ||
} ? DenormalizeObject<S> : S; | ||
export type DenormalizeNullable<S> = S extends EntityInterface<any> ? DenormalizeNullableNestedSchema<S> | undefined : S extends RecordClass ? DenormalizeNullableNestedSchema<S> : S extends SchemaClass ? DenormalizeReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
export type DenormalizeNullable<S> = S extends EntityInterface<any> ? DenormalizeNullableNestedSchema<S> | undefined : S extends RecordClass ? DenormalizeNullableNestedSchema<S> : S extends { | ||
_denormalizeNullable: (...args: any) => any; | ||
} ? DenormalizeReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
[K: string]: any; | ||
} ? DenormalizeNullableObject<S> : S; | ||
export type Normalize<S> = S extends EntityInterface ? string : S extends RecordClass ? NormalizeObject<S['schema']> : S extends SchemaClass ? NormalizeReturnType<S['normalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] : S extends { | ||
export type Normalize<S> = S extends EntityInterface ? string : S extends RecordClass ? NormalizeObject<S['schema']> : S extends { | ||
normalize: (...args: any) => any; | ||
} ? NormalizeReturnType<S['normalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] : S extends { | ||
[K: string]: any; | ||
} ? NormalizeObject<S> : S; | ||
export type NormalizeNullable<S> = S extends EntityInterface ? string | undefined : S extends RecordClass ? NormalizedNullableObject<S['schema']> : S extends SchemaClass ? NormalizeReturnType<S['_normalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] | undefined : S extends { | ||
export type NormalizeNullable<S> = S extends EntityInterface ? string | undefined : S extends RecordClass ? NormalizedNullableObject<S['schema']> : S extends { | ||
_normalizeNullable: (...args: any) => any; | ||
} ? NormalizeReturnType<S['_normalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] | undefined : S extends { | ||
[K: string]: any; | ||
@@ -49,0 +59,0 @@ } ? NormalizedNullableObject<S> : S; |
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL25vcm1hbC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIFNjaGVtYSxcbiAgU2VyaWFsaXphYmxlLFxuICBFbnRpdHlJbnRlcmZhY2UsXG4gIE5vcm1hbGl6ZWRJbmRleCxcbiAgU2NoZW1hQ2xhc3MsXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcblxuLy8gVHlwZVNjcmlwdCA8NC4yIEluc3RhbmNlVHlwZTw+IGRvZXMgbm90IHdvcmsgb24gYWJzdHJhY3QgY2xhc3Nlc1xuZXhwb3J0IHR5cGUgQWJzdHJhY3RJbnN0YW5jZVR5cGU8VD4gPSBUIGV4dGVuZHMgbmV3ICguLi5hcmdzOiBhbnkpID0+IGluZmVyIFVcbiAgPyBVXG4gIDogVCBleHRlbmRzIHsgcHJvdG90eXBlOiBpbmZlciBVIH1cbiAgPyBVXG4gIDogbmV2ZXI7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRFbnRpdHk8VD4gPSBUIGV4dGVuZHMge1xuICBwcm90b3R5cGU6IGluZmVyIFU7XG4gIHNjaGVtYTogaW5mZXIgUztcbn1cbiAgPyB7IFtLIGluIEV4Y2x1ZGU8a2V5b2YgVSwga2V5b2YgUz5dOiBVW0tdIH0gJiB7IFtLIGluIGtleW9mIFNdOiBzdHJpbmcgfVxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemU8U1tLXT4gOiBTW0tdO1xufTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVOdWxsYWJsZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemVOdWxsYWJsZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZU51bGxhYmxlPFNbS10+IDogU1tLXTtcbn07XG5cbmludGVyZmFjZSBOZXN0ZWRTY2hlbWFDbGFzczxUID0gYW55PiB7XG4gIHNjaGVtYTogUmVjb3JkPHN0cmluZywgU2NoZW1hPjtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlY29yZENsYXNzPFQgPSBhbnk+IGV4dGVuZHMgTmVzdGVkU2NoZW1hQ2xhc3M8VD4ge1xuICBmcm9tSlM6ICguLi5hcmdzOiBhbnkpID0+IEFic3RyYWN0SW5zdGFuY2VUeXBlPFQ+O1xufVxuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU51bGxhYmxlTmVzdGVkU2NoZW1hPFMgZXh0ZW5kcyBOZXN0ZWRTY2hlbWFDbGFzcz4gPVxuICBrZXlvZiBTWydzY2hlbWEnXSBleHRlbmRzIG5ldmVyXG4gICAgPyBTWydwcm90b3R5cGUnXSAvLyB0aGlzIGlzIHRoZSBjYXNlIG9mIGEgbm9uLXNldCBzY2hlbWEsIHdoaWNoIG1lYW5zIGl0IGFjdHVhbGx5IGhhcyBubyBtZW1iZXJzXG4gICAgOiBzdHJpbmcgZXh0ZW5kcyBrZXlvZiBTWydzY2hlbWEnXVxuICAgID8gU1sncHJvdG90eXBlJ11cbiAgICA6IFNbJ3Byb3RvdHlwZSddICYge1xuICAgICAgICBbSyBpbiBrZXlvZiBTWydzY2hlbWEnXV06IERlbm9ybWFsaXplTnVsbGFibGU8U1snc2NoZW1hJ11bS10+O1xuICAgICAgfTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVSZXR1cm5UeXBlPFQ+ID0gVCBleHRlbmRzIChcbiAgaW5wdXQ6IGFueSxcbiAgdW52aXNpdDogYW55LFxuKSA9PiBbaW5mZXIgUiwgYW55LCBhbnldXG4gID8gUlxuICA6IG5ldmVyO1xuZXhwb3J0IHR5cGUgTm9ybWFsaXplUmV0dXJuVHlwZTxUPiA9IFQgZXh0ZW5kcyAoLi4uYXJnczogYW55KSA9PiBpbmZlciBSXG4gID8gUlxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2U8aW5mZXIgVT5cbiAgPyBVXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gQWJzdHJhY3RJbnN0YW5jZVR5cGU8Uz5cbiAgOiBTIGV4dGVuZHMgU2NoZW1hQ2xhc3NcbiAgPyBEZW5vcm1hbGl6ZVJldHVyblR5cGU8U1snZGVub3JtYWxpemUnXT5cbiAgOiBTIGV4dGVuZHMgU2VyaWFsaXphYmxlPGluZmVyIFQ+XG4gID8gVFxuICA6IFMgZXh0ZW5kcyBBcnJheTxpbmZlciBGPlxuICA/IERlbm9ybWFsaXplPEY+W11cbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBEZW5vcm1hbGl6ZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIERlbm9ybWFsaXplTnVsbGFibGU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlPGFueT5cbiAgPyBEZW5vcm1hbGl6ZU51bGxhYmxlTmVzdGVkU2NoZW1hPFM+IHwgdW5kZWZpbmVkXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gRGVub3JtYWxpemVOdWxsYWJsZU5lc3RlZFNjaGVtYTxTPlxuICA6IFMgZXh0ZW5kcyBTY2hlbWFDbGFzc1xuICA/IERlbm9ybWFsaXplUmV0dXJuVHlwZTxTWydfZGVub3JtYWxpemVOdWxsYWJsZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gRGVub3JtYWxpemU8Rj5bXSB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IERlbm9ybWFsaXplTnVsbGFibGVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlXG4gID8gc3RyaW5nXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gTm9ybWFsaXplT2JqZWN0PFNbJ3NjaGVtYSddPlxuICA6IFMgZXh0ZW5kcyBTY2hlbWFDbGFzc1xuICA/IE5vcm1hbGl6ZVJldHVyblR5cGU8U1snbm9ybWFsaXplJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBOb3JtYWxpemU8Rj5bXVxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IE5vcm1hbGl6ZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZU51bGxhYmxlPFM+ID0gUyBleHRlbmRzIEVudGl0eUludGVyZmFjZVxuICA/IHN0cmluZyB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyBSZWNvcmRDbGFzc1xuICA/IE5vcm1hbGl6ZWROdWxsYWJsZU9iamVjdDxTWydzY2hlbWEnXT5cbiAgOiBTIGV4dGVuZHMgU2NoZW1hQ2xhc3NcbiAgPyBOb3JtYWxpemVSZXR1cm5UeXBlPFNbJ19ub3JtYWxpemVOdWxsYWJsZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gTm9ybWFsaXplPEY+W10gfCB1bmRlZmluZWRcbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVkU2NoZW1hPEUsIFI+ID0ge1xuICBlbnRpdGllczogRTtcbiAgcmVzdWx0OiBSO1xuICBpbmRleGVzOiBOb3JtYWxpemVkSW5kZXg7XG4gIGVudGl0eU1ldGE6IHtcbiAgICByZWFkb25seSBbZW50aXR5S2V5OiBzdHJpbmddOiB7XG4gICAgICByZWFkb25seSBbcGs6IHN0cmluZ106IHtcbiAgICAgICAgcmVhZG9ubHkgZGF0ZTogbnVtYmVyO1xuICAgICAgICByZWFkb25seSBleHBpcmVzQXQ6IG51bWJlcjtcbiAgICAgICAgcmVhZG9ubHkgZmV0Y2hlZEF0OiBudW1iZXI7XG4gICAgICB9O1xuICAgIH07XG4gIH07XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIEVudGl0eU1hcDxUID0gYW55PiB7XG4gIHJlYWRvbmx5IFtrOiBzdHJpbmddOiBFbnRpdHlJbnRlcmZhY2U8VD47XG59XG4iXSwibWFwcGluZ3MiOiIifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL25vcm1hbC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIFNjaGVtYSxcbiAgU2VyaWFsaXphYmxlLFxuICBFbnRpdHlJbnRlcmZhY2UsXG4gIE5vcm1hbGl6ZWRJbmRleCxcbiAgU2NoZW1hQ2xhc3MsXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcblxuLy8gVHlwZVNjcmlwdCA8NC4yIEluc3RhbmNlVHlwZTw+IGRvZXMgbm90IHdvcmsgb24gYWJzdHJhY3QgY2xhc3Nlc1xuZXhwb3J0IHR5cGUgQWJzdHJhY3RJbnN0YW5jZVR5cGU8VD4gPSBUIGV4dGVuZHMgbmV3ICguLi5hcmdzOiBhbnkpID0+IGluZmVyIFVcbiAgPyBVXG4gIDogVCBleHRlbmRzIHsgcHJvdG90eXBlOiBpbmZlciBVIH1cbiAgPyBVXG4gIDogbmV2ZXI7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRFbnRpdHk8VD4gPSBUIGV4dGVuZHMge1xuICBwcm90b3R5cGU6IGluZmVyIFU7XG4gIHNjaGVtYTogaW5mZXIgUztcbn1cbiAgPyB7IFtLIGluIEV4Y2x1ZGU8a2V5b2YgVSwga2V5b2YgUz5dOiBVW0tdIH0gJiB7IFtLIGluIGtleW9mIFNdOiBzdHJpbmcgfVxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemU8U1tLXT4gOiBTW0tdO1xufTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVOdWxsYWJsZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemVOdWxsYWJsZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZU51bGxhYmxlPFNbS10+IDogU1tLXTtcbn07XG5cbmludGVyZmFjZSBOZXN0ZWRTY2hlbWFDbGFzczxUID0gYW55PiB7XG4gIHNjaGVtYTogUmVjb3JkPHN0cmluZywgU2NoZW1hPjtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlY29yZENsYXNzPFQgPSBhbnk+IGV4dGVuZHMgTmVzdGVkU2NoZW1hQ2xhc3M8VD4ge1xuICBmcm9tSlM6ICguLi5hcmdzOiBhbnkpID0+IEFic3RyYWN0SW5zdGFuY2VUeXBlPFQ+O1xufVxuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU51bGxhYmxlTmVzdGVkU2NoZW1hPFMgZXh0ZW5kcyBOZXN0ZWRTY2hlbWFDbGFzcz4gPVxuICBrZXlvZiBTWydzY2hlbWEnXSBleHRlbmRzIG5ldmVyXG4gICAgPyBTWydwcm90b3R5cGUnXSAvLyB0aGlzIGlzIHRoZSBjYXNlIG9mIGEgbm9uLXNldCBzY2hlbWEsIHdoaWNoIG1lYW5zIGl0IGFjdHVhbGx5IGhhcyBubyBtZW1iZXJzXG4gICAgOiBzdHJpbmcgZXh0ZW5kcyBrZXlvZiBTWydzY2hlbWEnXVxuICAgID8gU1sncHJvdG90eXBlJ11cbiAgICA6IFNbJ3Byb3RvdHlwZSddICYge1xuICAgICAgICBbSyBpbiBrZXlvZiBTWydzY2hlbWEnXV06IERlbm9ybWFsaXplTnVsbGFibGU8U1snc2NoZW1hJ11bS10+O1xuICAgICAgfTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVSZXR1cm5UeXBlPFQ+ID0gVCBleHRlbmRzIChcbiAgaW5wdXQ6IGFueSxcbiAgdW52aXNpdDogYW55LFxuKSA9PiBbaW5mZXIgUiwgYW55LCBhbnldXG4gID8gUlxuICA6IG5ldmVyO1xuZXhwb3J0IHR5cGUgTm9ybWFsaXplUmV0dXJuVHlwZTxUPiA9IFQgZXh0ZW5kcyAoLi4uYXJnczogYW55KSA9PiBpbmZlciBSXG4gID8gUlxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2U8aW5mZXIgVT5cbiAgPyBVXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gQWJzdHJhY3RJbnN0YW5jZVR5cGU8Uz5cbiAgOiBTIGV4dGVuZHMgeyBkZW5vcm1hbGl6ZU9ubHk6ICguLi5hcmdzOiBhbnkpID0+IGFueSB9XG4gID8gUmV0dXJuVHlwZTxTWydkZW5vcm1hbGl6ZU9ubHknXT5cbiAgOiBTIGV4dGVuZHMgeyBkZW5vcm1hbGl6ZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBEZW5vcm1hbGl6ZVJldHVyblR5cGU8U1snZGVub3JtYWxpemUnXT5cbiAgOiBTIGV4dGVuZHMgU2VyaWFsaXphYmxlPGluZmVyIFQ+XG4gID8gVFxuICA6IFMgZXh0ZW5kcyBBcnJheTxpbmZlciBGPlxuICA/IERlbm9ybWFsaXplPEY+W11cbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBEZW5vcm1hbGl6ZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIERlbm9ybWFsaXplTnVsbGFibGU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlPGFueT5cbiAgPyBEZW5vcm1hbGl6ZU51bGxhYmxlTmVzdGVkU2NoZW1hPFM+IHwgdW5kZWZpbmVkXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gRGVub3JtYWxpemVOdWxsYWJsZU5lc3RlZFNjaGVtYTxTPlxuICA6IFMgZXh0ZW5kcyB7IF9kZW5vcm1hbGl6ZU51bGxhYmxlOiAoLi4uYXJnczogYW55KSA9PiBhbnkgfVxuICA/IERlbm9ybWFsaXplUmV0dXJuVHlwZTxTWydfZGVub3JtYWxpemVOdWxsYWJsZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gRGVub3JtYWxpemU8Rj5bXSB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IERlbm9ybWFsaXplTnVsbGFibGVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlXG4gID8gc3RyaW5nXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gTm9ybWFsaXplT2JqZWN0PFNbJ3NjaGVtYSddPlxuICA6IFMgZXh0ZW5kcyB7IG5vcm1hbGl6ZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBOb3JtYWxpemVSZXR1cm5UeXBlPFNbJ25vcm1hbGl6ZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gTm9ybWFsaXplPEY+W11cbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBOb3JtYWxpemVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVOdWxsYWJsZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2VcbiAgPyBzdHJpbmcgfCB1bmRlZmluZWRcbiAgOiBTIGV4dGVuZHMgUmVjb3JkQ2xhc3NcbiAgPyBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8U1snc2NoZW1hJ10+XG4gIDogUyBleHRlbmRzIHsgX25vcm1hbGl6ZU51bGxhYmxlOiAoLi4uYXJnczogYW55KSA9PiBhbnkgfVxuICA/IE5vcm1hbGl6ZVJldHVyblR5cGU8U1snX25vcm1hbGl6ZU51bGxhYmxlJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBOb3JtYWxpemU8Rj5bXSB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IE5vcm1hbGl6ZWROdWxsYWJsZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRTY2hlbWE8RSwgUj4gPSB7XG4gIGVudGl0aWVzOiBFO1xuICByZXN1bHQ6IFI7XG4gIGluZGV4ZXM6IE5vcm1hbGl6ZWRJbmRleDtcbiAgZW50aXR5TWV0YToge1xuICAgIHJlYWRvbmx5IFtlbnRpdHlLZXk6IHN0cmluZ106IHtcbiAgICAgIHJlYWRvbmx5IFtwazogc3RyaW5nXToge1xuICAgICAgICByZWFkb25seSBkYXRlOiBudW1iZXI7XG4gICAgICAgIHJlYWRvbmx5IGV4cGlyZXNBdDogbnVtYmVyO1xuICAgICAgICByZWFkb25seSBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgICAgIH07XG4gICAgfTtcbiAgfTtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW50aXR5TWFwPFQgPSBhbnk+IHtcbiAgcmVhZG9ubHkgW2s6IHN0cmluZ106IEVudGl0eUludGVyZmFjZTxUPjtcbn1cbiJdLCJtYXBwaW5ncyI6IiJ9 |
@@ -18,4 +18,5 @@ import type { SchemaSimple, UnvisitFunction } from './interface.js'; | ||
_denormalizeNullable(input: {}, unvisit: UnvisitFunction): [denormalized: R | undefined, found: boolean, suspend: boolean]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): R; | ||
}; | ||
export {}; | ||
//# sourceMappingURL=queryEndpoint.d.ts.map |
@@ -24,6 +24,14 @@ /** | ||
}, unvisit) => { | ||
if (input === undefined) return [undefined, false, true]; | ||
if (input === undefined) return [undefined, false, false]; | ||
const [value, found, deleted] = schema.denormalize(input, unvisit); | ||
return [found ? this.process(value, ...args) : undefined, found, deleted]; | ||
}; | ||
if (schema.denormalizeOnly) query.denormalizeOnly = ({ | ||
args, | ||
input | ||
}, _, unvisit) => { | ||
if (input === undefined) return undefined; | ||
const value = schema.denormalizeOnly(input, args, unvisit); | ||
return typeof value === 'symbol' ? undefined : this.process(value, ...args); | ||
}; | ||
query.infer = (args, indexes, recurse, entities) => { | ||
@@ -38,2 +46,2 @@ return { | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJRdWVyeSIsImNvbnN0cnVjdG9yIiwic2NoZW1hIiwicHJvY2VzcyIsInNpZGVFZmZlY3QiLCJ1bmRlZmluZWQiLCJjcmVhdGVRdWVyeVNjaGVtYSIsImVudHJpZXMiLCJrZXkiLCJhcmdzIiwiSlNPTiIsInN0cmluZ2lmeSIsInF1ZXJ5IiwiT2JqZWN0IiwiY3JlYXRlIiwiZGVub3JtYWxpemUiLCJpbnB1dCIsInVudmlzaXQiLCJ2YWx1ZSIsImZvdW5kIiwiZGVsZXRlZCIsImluZmVyIiwiaW5kZXhlcyIsInJlY3Vyc2UiLCJlbnRpdGllcyJdLCJzb3VyY2VzIjpbIi4uL3NyYy9xdWVyeUVuZHBvaW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtcbiAgRW50aXR5VGFibGUsXG4gIE5vcm1hbGl6ZWRJbmRleCxcbiAgU2NoZW1hU2ltcGxlLFxuICBVbnZpc2l0RnVuY3Rpb24sXG59IGZyb20gJy4vaW50ZXJmYWNlLmpzJztcbmltcG9ydCB0eXBlIHsgRGVub3JtYWxpemUgfSBmcm9tICcuL25vcm1hbC5qcyc7XG5cbi8qKlxuICogUHJvZ3JhbW1hdGljIGNhY2hlIHJlYWRpbmdcbiAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vcmVzdC9hcGkvUXVlcnlcbiAqL1xuZXhwb3J0IGNsYXNzIFF1ZXJ5PFxuICBTIGV4dGVuZHMgU2NoZW1hU2ltcGxlLFxuICBQIGV4dGVuZHMgYW55W10gPSBbXSxcbiAgUiA9IERlbm9ybWFsaXplPFM+LFxuPiB7XG4gIGRlY2xhcmUgc2NoZW1hOiBRdWVyeVNjaGVtYTxTLCBSPjtcbiAgLy8gVE9ETzogYWxsb3cgYXJiaXRyYXJ5IHJldHVybiB0eXBlcyB0aGVuIGluZmVycmluZyBpdCBmcm9tXG4gIGRlY2xhcmUgcHJvY2VzczogKGVudHJpZXM6IERlbm9ybWFsaXplPFM+LCAuLi5hcmdzOiBQKSA9PiBSO1xuXG4gIHJlYWRvbmx5IHNpZGVFZmZlY3QgPSB1bmRlZmluZWQ7XG5cbiAgY29uc3RydWN0b3Ioc2NoZW1hOiBTLCBwcm9jZXNzPzogKGVudHJpZXM6IERlbm9ybWFsaXplPFM+LCAuLi5hcmdzOiBQKSA9PiBSKSB7XG4gICAgdGhpcy5zY2hlbWEgPSB0aGlzLmNyZWF0ZVF1ZXJ5U2NoZW1hKHNjaGVtYSk7XG4gICAgaWYgKHByb2Nlc3MpIHRoaXMucHJvY2VzcyA9IHByb2Nlc3M7XG4gICAgLy8gYWxsb3dzIGZvciBpbmhlcml0YW5jZSBvdmVycmlkZXNcbiAgICBlbHNlIGlmICghdGhpcy5wcm9jZXNzKVxuICAgICAgdGhpcy5wcm9jZXNzID0gKChlbnRyaWVzOiBEZW5vcm1hbGl6ZTxTPikgPT4gZW50cmllcykgYXMgYW55O1xuICB9XG5cbiAga2V5KC4uLmFyZ3M6IFApIHtcbiAgICByZXR1cm4gYFFVRVJZICR7SlNPTi5zdHJpbmdpZnkoYXJncyl9YDtcbiAgfVxuXG4gIHByb3RlY3RlZCBjcmVhdGVRdWVyeVNjaGVtYShzY2hlbWE6IFNjaGVtYVNpbXBsZSkge1xuICAgIGNvbnN0IHF1ZXJ5ID0gT2JqZWN0LmNyZWF0ZShzY2hlbWEpO1xuICAgIHF1ZXJ5LmRlbm9ybWFsaXplID0gKFxuICAgICAgeyBhcmdzLCBpbnB1dCB9OiB7IGFyZ3M6IFA7IGlucHV0OiBhbnkgfSxcbiAgICAgIHVudmlzaXQ6IGFueSxcbiAgICApID0+IHtcbiAgICAgIGlmIChpbnB1dCA9PT0gdW5kZWZpbmVkKSByZXR1cm4gW3VuZGVmaW5lZCwgZmFsc2UsIHRydWVdO1xuICAgICAgY29uc3QgW3ZhbHVlLCBmb3VuZCwgZGVsZXRlZF0gPSBzY2hlbWEuZGVub3JtYWxpemUoaW5wdXQsIHVudmlzaXQpO1xuICAgICAgcmV0dXJuIFtmb3VuZCA/IHRoaXMucHJvY2Vzcyh2YWx1ZSwgLi4uYXJncykgOiB1bmRlZmluZWQsIGZvdW5kLCBkZWxldGVkXTtcbiAgICB9O1xuICAgIHF1ZXJ5LmluZmVyID0gKFxuICAgICAgYXJnczogYW55LFxuICAgICAgaW5kZXhlczogYW55LFxuICAgICAgcmVjdXJzZTogKFxuICAgICAgICBzY2hlbWE6IFNjaGVtYVNpbXBsZSxcbiAgICAgICAgYXJnczogYW55W10sXG4gICAgICAgIGluZGV4ZXM6IE5vcm1hbGl6ZWRJbmRleCxcbiAgICAgICAgZW50aXRpZXM6IEVudGl0eVRhYmxlLFxuICAgICAgKSA9PiBhbnksXG4gICAgICBlbnRpdGllczogRW50aXR5VGFibGUsXG4gICAgKSA9PiB7XG4gICAgICByZXR1cm4geyBhcmdzLCBpbnB1dDogcmVjdXJzZShzY2hlbWEsIGFyZ3MsIGluZGV4ZXMsIGVudGl0aWVzKSB9O1xuICAgIH07XG4gICAgcmV0dXJuIHF1ZXJ5O1xuICB9XG59XG5cbnR5cGUgUXVlcnlTY2hlbWE8U2NoZW1hLCBSPiA9IEV4Y2x1ZGU8XG4gIFNjaGVtYSxcbiAgJ2Rlbm9ybWFsaXplJyB8ICdfZGVub3JtYWxpemVOdWxsYWJsZSdcbj4gJiB7XG4gIGRlbm9ybWFsaXplKFxuICAgIGlucHV0OiB7fSxcbiAgICB1bnZpc2l0OiBVbnZpc2l0RnVuY3Rpb24sXG4gICk6IFtkZW5vcm1hbGl6ZWQ6IFIsIGZvdW5kOiBib29sZWFuLCBzdXNwZW5kOiBib29sZWFuXTtcbiAgX2Rlbm9ybWFsaXplTnVsbGFibGUoXG4gICAgaW5wdXQ6IHt9LFxuICAgIHVudmlzaXQ6IFVudmlzaXRGdW5jdGlvbixcbiAgKTogW2Rlbm9ybWFsaXplZDogUiB8IHVuZGVmaW5lZCwgZm91bmQ6IGJvb2xlYW4sIHN1c3BlbmQ6IGJvb2xlYW5dO1xufTtcbiJdLCJtYXBwaW5ncyI6IkFBUUE7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLE1BQU1BLEtBQUssQ0FJaEI7RUFFQTs7RUFLQUMsV0FBV0EsQ0FBQ0MsTUFBUyxFQUFFQyxPQUFvRCxFQUFFO0lBQUEsS0FGcEVDLFVBQVUsR0FBR0MsU0FBUztJQUc3QixJQUFJLENBQUNILE1BQU0sR0FBRyxJQUFJLENBQUNJLGlCQUFpQixDQUFDSixNQUFNLENBQUM7SUFDNUMsSUFBSUMsT0FBTyxFQUFFLElBQUksQ0FBQ0EsT0FBTyxHQUFHQSxPQUFPO0lBQ25DO0lBQUEsS0FDSyxJQUFJLENBQUMsSUFBSSxDQUFDQSxPQUFPLEVBQ3BCLElBQUksQ0FBQ0EsT0FBTyxHQUFLSSxPQUF1QixJQUFLQSxPQUFlO0VBQ2hFO0VBRUFDLEdBQUdBLENBQUMsR0FBR0MsSUFBTyxFQUFFO0lBQ2QsT0FBUSxTQUFRQyxJQUFJLENBQUNDLFNBQVMsQ0FBQ0YsSUFBSSxDQUFFLEVBQUM7RUFDeEM7RUFFVUgsaUJBQWlCQSxDQUFDSixNQUFvQixFQUFFO0lBQ2hELE1BQU1VLEtBQUssR0FBR0MsTUFBTSxDQUFDQyxNQUFNLENBQUNaLE1BQU0sQ0FBQztJQUNuQ1UsS0FBSyxDQUFDRyxXQUFXLEdBQUcsQ0FDbEI7TUFBRU4sSUFBSTtNQUFFTztJQUErQixDQUFDLEVBQ3hDQyxPQUFZLEtBQ1Q7TUFDSCxJQUFJRCxLQUFLLEtBQUtYLFNBQVMsRUFBRSxPQUFPLENBQUNBLFNBQVMsRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDO01BQ3hELE1BQU0sQ0FBQ2EsS0FBSyxFQUFFQyxLQUFLLEVBQUVDLE9BQU8sQ0FBQyxHQUFHbEIsTUFBTSxDQUFDYSxXQUFXLENBQUNDLEtBQUssRUFBRUMsT0FBTyxDQUFDO01BQ2xFLE9BQU8sQ0FBQ0UsS0FBSyxHQUFHLElBQUksQ0FBQ2hCLE9BQU8sQ0FBQ2UsS0FBSyxFQUFFLEdBQUdULElBQUksQ0FBQyxHQUFHSixTQUFTLEVBQUVjLEtBQUssRUFBRUMsT0FBTyxDQUFDO0lBQzNFLENBQUM7SUFDRFIsS0FBSyxDQUFDUyxLQUFLLEdBQUcsQ0FDWlosSUFBUyxFQUNUYSxPQUFZLEVBQ1pDLE9BS1EsRUFDUkMsUUFBcUIsS0FDbEI7TUFDSCxPQUFPO1FBQUVmLElBQUk7UUFBRU8sS0FBSyxFQUFFTyxPQUFPLENBQUNyQixNQUFNLEVBQUVPLElBQUksRUFBRWEsT0FBTyxFQUFFRSxRQUFRO01BQUUsQ0FBQztJQUNsRSxDQUFDO0lBQ0QsT0FBT1osS0FBSztFQUNkO0FBQ0YifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJRdWVyeSIsImNvbnN0cnVjdG9yIiwic2NoZW1hIiwicHJvY2VzcyIsInNpZGVFZmZlY3QiLCJ1bmRlZmluZWQiLCJjcmVhdGVRdWVyeVNjaGVtYSIsImVudHJpZXMiLCJrZXkiLCJhcmdzIiwiSlNPTiIsInN0cmluZ2lmeSIsInF1ZXJ5IiwiT2JqZWN0IiwiY3JlYXRlIiwiZGVub3JtYWxpemUiLCJpbnB1dCIsInVudmlzaXQiLCJ2YWx1ZSIsImZvdW5kIiwiZGVsZXRlZCIsImRlbm9ybWFsaXplT25seSIsIl8iLCJpbmZlciIsImluZGV4ZXMiLCJyZWN1cnNlIiwiZW50aXRpZXMiXSwic291cmNlcyI6WyIuLi9zcmMvcXVlcnlFbmRwb2ludC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIEVudGl0eVRhYmxlLFxuICBOb3JtYWxpemVkSW5kZXgsXG4gIFNjaGVtYVNpbXBsZSxcbiAgVW52aXNpdEZ1bmN0aW9uLFxufSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IERlbm9ybWFsaXplIH0gZnJvbSAnLi9ub3JtYWwuanMnO1xuXG4vKipcbiAqIFByb2dyYW1tYXRpYyBjYWNoZSByZWFkaW5nXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL3Jlc3QvYXBpL1F1ZXJ5XG4gKi9cbmV4cG9ydCBjbGFzcyBRdWVyeTxcbiAgUyBleHRlbmRzIFNjaGVtYVNpbXBsZSxcbiAgUCBleHRlbmRzIGFueVtdID0gW10sXG4gIFIgPSBEZW5vcm1hbGl6ZTxTPixcbj4ge1xuICBkZWNsYXJlIHNjaGVtYTogUXVlcnlTY2hlbWE8UywgUj47XG4gIC8vIFRPRE86IGFsbG93IGFyYml0cmFyeSByZXR1cm4gdHlwZXMgdGhlbiBpbmZlcnJpbmcgaXQgZnJvbVxuICBkZWNsYXJlIHByb2Nlc3M6IChlbnRyaWVzOiBEZW5vcm1hbGl6ZTxTPiwgLi4uYXJnczogUCkgPT4gUjtcblxuICByZWFkb25seSBzaWRlRWZmZWN0ID0gdW5kZWZpbmVkO1xuXG4gIGNvbnN0cnVjdG9yKHNjaGVtYTogUywgcHJvY2Vzcz86IChlbnRyaWVzOiBEZW5vcm1hbGl6ZTxTPiwgLi4uYXJnczogUCkgPT4gUikge1xuICAgIHRoaXMuc2NoZW1hID0gdGhpcy5jcmVhdGVRdWVyeVNjaGVtYShzY2hlbWEpO1xuICAgIGlmIChwcm9jZXNzKSB0aGlzLnByb2Nlc3MgPSBwcm9jZXNzO1xuICAgIC8vIGFsbG93cyBmb3IgaW5oZXJpdGFuY2Ugb3ZlcnJpZGVzXG4gICAgZWxzZSBpZiAoIXRoaXMucHJvY2VzcylcbiAgICAgIHRoaXMucHJvY2VzcyA9ICgoZW50cmllczogRGVub3JtYWxpemU8Uz4pID0+IGVudHJpZXMpIGFzIGFueTtcbiAgfVxuXG4gIGtleSguLi5hcmdzOiBQKSB7XG4gICAgcmV0dXJuIGBRVUVSWSAke0pTT04uc3RyaW5naWZ5KGFyZ3MpfWA7XG4gIH1cblxuICBwcm90ZWN0ZWQgY3JlYXRlUXVlcnlTY2hlbWEoc2NoZW1hOiBTY2hlbWFTaW1wbGUpIHtcbiAgICBjb25zdCBxdWVyeSA9IE9iamVjdC5jcmVhdGUoc2NoZW1hKTtcbiAgICBxdWVyeS5kZW5vcm1hbGl6ZSA9IChcbiAgICAgIHsgYXJncywgaW5wdXQgfTogeyBhcmdzOiBQOyBpbnB1dDogYW55IH0sXG4gICAgICB1bnZpc2l0OiBhbnksXG4gICAgKSA9PiB7XG4gICAgICBpZiAoaW5wdXQgPT09IHVuZGVmaW5lZCkgcmV0dXJuIFt1bmRlZmluZWQsIGZhbHNlLCBmYWxzZV07XG4gICAgICBjb25zdCBbdmFsdWUsIGZvdW5kLCBkZWxldGVkXSA9IHNjaGVtYS5kZW5vcm1hbGl6ZShpbnB1dCwgdW52aXNpdCk7XG4gICAgICByZXR1cm4gW2ZvdW5kID8gdGhpcy5wcm9jZXNzKHZhbHVlLCAuLi5hcmdzKSA6IHVuZGVmaW5lZCwgZm91bmQsIGRlbGV0ZWRdO1xuICAgIH07XG4gICAgaWYgKHNjaGVtYS5kZW5vcm1hbGl6ZU9ubHkpXG4gICAgICBxdWVyeS5kZW5vcm1hbGl6ZU9ubHkgPSAoXG4gICAgICAgIHsgYXJncywgaW5wdXQgfTogeyBhcmdzOiBQOyBpbnB1dDogYW55IH0sXG4gICAgICAgIF86IFAsXG4gICAgICAgIHVudmlzaXQ6IGFueSxcbiAgICAgICkgPT4ge1xuICAgICAgICBpZiAoaW5wdXQgPT09IHVuZGVmaW5lZCkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICAgICAgY29uc3QgdmFsdWUgPSAoc2NoZW1hIGFzIGFueSkuZGVub3JtYWxpemVPbmx5KGlucHV0LCBhcmdzLCB1bnZpc2l0KTtcbiAgICAgICAgcmV0dXJuIHR5cGVvZiB2YWx1ZSA9PT0gJ3N5bWJvbCdcbiAgICAgICAgICA/IHVuZGVmaW5lZFxuICAgICAgICAgIDogdGhpcy5wcm9jZXNzKHZhbHVlLCAuLi5hcmdzKTtcbiAgICAgIH07XG4gICAgcXVlcnkuaW5mZXIgPSAoXG4gICAgICBhcmdzOiBhbnksXG4gICAgICBpbmRleGVzOiBhbnksXG4gICAgICByZWN1cnNlOiAoXG4gICAgICAgIHNjaGVtYTogU2NoZW1hU2ltcGxlLFxuICAgICAgICBhcmdzOiBhbnlbXSxcbiAgICAgICAgaW5kZXhlczogTm9ybWFsaXplZEluZGV4LFxuICAgICAgICBlbnRpdGllczogRW50aXR5VGFibGUsXG4gICAgICApID0+IGFueSxcbiAgICAgIGVudGl0aWVzOiBFbnRpdHlUYWJsZSxcbiAgICApID0+IHtcbiAgICAgIHJldHVybiB7IGFyZ3MsIGlucHV0OiByZWN1cnNlKHNjaGVtYSwgYXJncywgaW5kZXhlcywgZW50aXRpZXMpIH07XG4gICAgfTtcbiAgICByZXR1cm4gcXVlcnk7XG4gIH1cbn1cblxudHlwZSBRdWVyeVNjaGVtYTxTY2hlbWEsIFI+ID0gRXhjbHVkZTxcbiAgU2NoZW1hLFxuICAnZGVub3JtYWxpemUnIHwgJ19kZW5vcm1hbGl6ZU51bGxhYmxlJ1xuPiAmIHtcbiAgZGVub3JtYWxpemUoXG4gICAgaW5wdXQ6IHt9LFxuICAgIHVudmlzaXQ6IFVudmlzaXRGdW5jdGlvbixcbiAgKTogW2Rlbm9ybWFsaXplZDogUiwgZm91bmQ6IGJvb2xlYW4sIHN1c3BlbmQ6IGJvb2xlYW5dO1xuICBfZGVub3JtYWxpemVOdWxsYWJsZShcbiAgICBpbnB1dDoge30sXG4gICAgdW52aXNpdDogVW52aXNpdEZ1bmN0aW9uLFxuICApOiBbZGVub3JtYWxpemVkOiBSIHwgdW5kZWZpbmVkLCBmb3VuZDogYm9vbGVhbiwgc3VzcGVuZDogYm9vbGVhbl07XG4gIGRlbm9ybWFsaXplT25seShcbiAgICBpbnB1dDoge30sXG4gICAgYXJnczogcmVhZG9ubHkgYW55W10sXG4gICAgdW52aXNpdDogKGlucHV0OiBhbnksIHNjaGVtYTogYW55KSA9PiBhbnksXG4gICk6IFI7XG59O1xuIl0sIm1hcHBpbmdzIjoiQUFRQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sTUFBTUEsS0FBSyxDQUloQjtFQUVBOztFQUtBQyxXQUFXQSxDQUFDQyxNQUFTLEVBQUVDLE9BQW9ELEVBQUU7SUFBQSxLQUZwRUMsVUFBVSxHQUFHQyxTQUFTO0lBRzdCLElBQUksQ0FBQ0gsTUFBTSxHQUFHLElBQUksQ0FBQ0ksaUJBQWlCLENBQUNKLE1BQU0sQ0FBQztJQUM1QyxJQUFJQyxPQUFPLEVBQUUsSUFBSSxDQUFDQSxPQUFPLEdBQUdBLE9BQU87SUFDbkM7SUFBQSxLQUNLLElBQUksQ0FBQyxJQUFJLENBQUNBLE9BQU8sRUFDcEIsSUFBSSxDQUFDQSxPQUFPLEdBQUtJLE9BQXVCLElBQUtBLE9BQWU7RUFDaEU7RUFFQUMsR0FBR0EsQ0FBQyxHQUFHQyxJQUFPLEVBQUU7SUFDZCxPQUFRLFNBQVFDLElBQUksQ0FBQ0MsU0FBUyxDQUFDRixJQUFJLENBQUUsRUFBQztFQUN4QztFQUVVSCxpQkFBaUJBLENBQUNKLE1BQW9CLEVBQUU7SUFDaEQsTUFBTVUsS0FBSyxHQUFHQyxNQUFNLENBQUNDLE1BQU0sQ0FBQ1osTUFBTSxDQUFDO0lBQ25DVSxLQUFLLENBQUNHLFdBQVcsR0FBRyxDQUNsQjtNQUFFTixJQUFJO01BQUVPO0lBQStCLENBQUMsRUFDeENDLE9BQVksS0FDVDtNQUNILElBQUlELEtBQUssS0FBS1gsU0FBUyxFQUFFLE9BQU8sQ0FBQ0EsU0FBUyxFQUFFLEtBQUssRUFBRSxLQUFLLENBQUM7TUFDekQsTUFBTSxDQUFDYSxLQUFLLEVBQUVDLEtBQUssRUFBRUMsT0FBTyxDQUFDLEdBQUdsQixNQUFNLENBQUNhLFdBQVcsQ0FBQ0MsS0FBSyxFQUFFQyxPQUFPLENBQUM7TUFDbEUsT0FBTyxDQUFDRSxLQUFLLEdBQUcsSUFBSSxDQUFDaEIsT0FBTyxDQUFDZSxLQUFLLEVBQUUsR0FBR1QsSUFBSSxDQUFDLEdBQUdKLFNBQVMsRUFBRWMsS0FBSyxFQUFFQyxPQUFPLENBQUM7SUFDM0UsQ0FBQztJQUNELElBQUlsQixNQUFNLENBQUNtQixlQUFlLEVBQ3hCVCxLQUFLLENBQUNTLGVBQWUsR0FBRyxDQUN0QjtNQUFFWixJQUFJO01BQUVPO0lBQStCLENBQUMsRUFDeENNLENBQUksRUFDSkwsT0FBWSxLQUNUO01BQ0gsSUFBSUQsS0FBSyxLQUFLWCxTQUFTLEVBQUUsT0FBT0EsU0FBUztNQUN6QyxNQUFNYSxLQUFLLEdBQUloQixNQUFNLENBQVNtQixlQUFlLENBQUNMLEtBQUssRUFBRVAsSUFBSSxFQUFFUSxPQUFPLENBQUM7TUFDbkUsT0FBTyxPQUFPQyxLQUFLLEtBQUssUUFBUSxHQUM1QmIsU0FBUyxHQUNULElBQUksQ0FBQ0YsT0FBTyxDQUFDZSxLQUFLLEVBQUUsR0FBR1QsSUFBSSxDQUFDO0lBQ2xDLENBQUM7SUFDSEcsS0FBSyxDQUFDVyxLQUFLLEdBQUcsQ0FDWmQsSUFBUyxFQUNUZSxPQUFZLEVBQ1pDLE9BS1EsRUFDUkMsUUFBcUIsS0FDbEI7TUFDSCxPQUFPO1FBQUVqQixJQUFJO1FBQUVPLEtBQUssRUFBRVMsT0FBTyxDQUFDdkIsTUFBTSxFQUFFTyxJQUFJLEVBQUVlLE9BQU8sRUFBRUUsUUFBUTtNQUFFLENBQUM7SUFDbEUsQ0FBQztJQUNELE9BQU9kLEtBQUs7RUFDZDtBQUNGIn0= |
@@ -21,2 +21,3 @@ import type { | ||
} from './normal.js'; | ||
import { CollectionOptions } from './schemas/Collection.js'; | ||
import { default as Delete } from './schemas/Delete.js'; | ||
@@ -32,4 +33,5 @@ import { | ||
} from './schemas/EntitySchema.js'; | ||
import { default as Invalidate } from './schemas/Invalidate.js'; | ||
export { Delete, EntityMap }; | ||
export { Delete, EntityMap, Invalidate }; | ||
@@ -60,2 +62,4 @@ export { EntityInterface } from './interface.js'; | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
@@ -83,2 +87,8 @@ | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): (S extends EntityMap<infer T> ? T : Denormalize<S>)[]; | ||
infer( | ||
@@ -117,2 +127,4 @@ args: readonly any[], | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
@@ -140,2 +152,8 @@ | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): (S extends EntityMap<infer T> ? T : Denormalize<S>)[]; | ||
infer( | ||
@@ -166,2 +184,4 @@ args: readonly any[], | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): NormalizeObject<O>; | ||
@@ -179,2 +199,8 @@ | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): DenormalizeObject<O>; | ||
infer( | ||
@@ -210,2 +236,4 @@ args: readonly any[], | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): UnionResult<Choices>; | ||
@@ -231,2 +259,8 @@ | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): AbstractInstanceType<Choices[keyof Choices]>; | ||
infer( | ||
@@ -269,2 +303,4 @@ args: readonly any[], | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): Record< | ||
@@ -308,2 +344,11 @@ string, | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): Record< | ||
string, | ||
Choices extends EntityMap<infer T> ? T : Denormalize<Choices> | ||
>; | ||
infer( | ||
@@ -316,2 +361,134 @@ args: readonly any[], | ||
/** | ||
* Entities but for Arrays instead of classes | ||
* @see https://resthooks.io/rest/api/Collection | ||
*/ | ||
export class CollectionSchema< | ||
S extends Array<any> | Values<any> = any, | ||
Parent extends any[] = any, | ||
> { | ||
addWith<P extends any[] = Parent>( | ||
merge: (existing: any, incoming: any) => any, | ||
createCollectionFilter?: ( | ||
...args: P | ||
) => (collectionKey: Record<string, any>) => boolean, | ||
): CollectionSchema<S, P>; | ||
readonly schema: S; | ||
key: string; | ||
pk(value: any, parent: any, key: string, args: any[]): string; | ||
normalize( | ||
input: any, | ||
parent: Parent, | ||
key: string, | ||
visit: (...args: any) => any, | ||
addEntity: (...args: any) => any, | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args: any[], | ||
): string; | ||
merge(existing: any, incoming: any): any; | ||
shouldReorder( | ||
existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
existing: any, | ||
incoming: any, | ||
): boolean; | ||
mergeWithStore( | ||
existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
existing: any, | ||
incoming: any, | ||
): any; | ||
mergeMetaWithStore( | ||
existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
incomingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
existing: any, | ||
incoming: any, | ||
): { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}; | ||
infer( | ||
args: unknown, | ||
indexes: unknown, | ||
recurse: unknown, | ||
entities: unknown, | ||
): any; | ||
createIfValid: (value: any) => any | undefined; | ||
denormalizeOnly( | ||
input: any, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): ReturnType<S['denormalizeOnly']>; | ||
_denormalizeNullable(): ReturnType<S['_denormalizeNullable']>; | ||
_normalizeNullable(): ReturnType<S['_normalizeNullable']>; | ||
} | ||
export type CollectionType< | ||
S extends any[] | Array<any> | Values<any> = any, | ||
Parent extends any[] = [ | ||
urlParams: Record<string, any>, | ||
body?: Record<string, any>, | ||
], | ||
> = CollectionSchema<S extends any[] ? Array<S[number]> : S> & | ||
(S extends any[] | ||
? { | ||
push: CollectionSchema<Array<S[number]>, Parent>; | ||
unshift: CollectionSchema<Array<S[number]>, Parent>; | ||
} | ||
: S extends Values<any> | ||
? { assign: CollectionSchema<S, Parent> } | ||
: S extends Array<any> | ||
? { | ||
push: CollectionSchema<S, Parent>; | ||
unshift: CollectionSchema<S, Parent>; | ||
} | ||
: never); | ||
export interface CollectionConstructor { | ||
new < | ||
S extends SchemaSimple[] | Array<any> | Values<any> = any, | ||
Parent extends any[] = [ | ||
urlParams: Record<string, any>, | ||
body?: Record<string, any>, | ||
], | ||
>( | ||
schema: S, | ||
options: CollectionOptions, | ||
): CollectionType<S, Parent>; | ||
readonly prototype: CollectionSchema; | ||
} | ||
/** | ||
* Entities but for Arrays instead of classes | ||
* @see https://resthooks.io/rest/api/Collection | ||
*/ | ||
export declare let Collection: CollectionConstructor; | ||
export type StrategyFunction<T> = (value: any, parent: any, key: string) => T; | ||
@@ -342,2 +519,26 @@ export type SchemaFunction<K = string> = ( | ||
export interface SchemaSimpleNew<T = any> { | ||
normalize( | ||
input: any, | ||
parent: any, | ||
key: any, | ||
visit: (...args: any) => any, | ||
addEntity: (...args: any) => any, | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): any; | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): T; | ||
infer( | ||
args: readonly any[], | ||
indexes: NormalizedIndex, | ||
recurse: (...args: any) => any, | ||
entities: EntityTable, | ||
): any; | ||
} | ||
// id is in Instance, so we default to that as pk | ||
@@ -344,0 +545,0 @@ /** |
@@ -8,3 +8,5 @@ /* istanbul ignore file */ | ||
export { default as Delete } from './schemas/Delete.js'; | ||
export { default as Invalidate } from './schemas/Invalidate.js'; | ||
export { default as Collection } from './schemas/Collection.js'; | ||
export { default as Entity } from './schemas/EntitySchema.js'; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkZWZhdWx0IiwiVW5pb24iLCJWYWx1ZXMiLCJBcnJheSIsIkFsbCIsIk9iamVjdCIsIkRlbGV0ZSIsIkVudGl0eSJdLCJzb3VyY2VzIjpbIi4uL3NyYy9zY2hlbWEuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogaXN0YW5idWwgaWdub3JlIGZpbGUgKi9cbmV4cG9ydCB7IGRlZmF1bHQgYXMgVW5pb24gfSBmcm9tICcuL3NjaGVtYXMvVW5pb24uanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBWYWx1ZXMgfSBmcm9tICcuL3NjaGVtYXMvVmFsdWVzLmpzJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgQXJyYXkgfSBmcm9tICcuL3NjaGVtYXMvQXJyYXkuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBBbGwgfSBmcm9tICcuL3NjaGVtYXMvQWxsLmpzJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgT2JqZWN0IH0gZnJvbSAnLi9zY2hlbWFzL09iamVjdC5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIERlbGV0ZSB9IGZyb20gJy4vc2NoZW1hcy9EZWxldGUuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBFbnRpdHkgfSBmcm9tICcuL3NjaGVtYXMvRW50aXR5U2NoZW1hLmpzJztcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQSxTQUFTQSxPQUFPLElBQUlDLEtBQUssUUFBUSxvQkFBb0I7QUFDckQsU0FBU0QsT0FBTyxJQUFJRSxNQUFNLFFBQVEscUJBQXFCO0FBQ3ZELFNBQVNGLE9BQU8sSUFBSUcsS0FBSyxRQUFRLG9CQUFvQjtBQUNyRCxTQUFTSCxPQUFPLElBQUlJLEdBQUcsUUFBUSxrQkFBa0I7QUFDakQsU0FBU0osT0FBTyxJQUFJSyxNQUFNLFFBQVEscUJBQXFCO0FBQ3ZELFNBQVNMLE9BQU8sSUFBSU0sTUFBTSxRQUFRLHFCQUFxQjtBQUN2RCxTQUFTTixPQUFPLElBQUlPLE1BQU0sUUFBUSwyQkFBMkIifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJkZWZhdWx0IiwiVW5pb24iLCJWYWx1ZXMiLCJBcnJheSIsIkFsbCIsIk9iamVjdCIsIkRlbGV0ZSIsIkludmFsaWRhdGUiLCJDb2xsZWN0aW9uIiwiRW50aXR5Il0sInNvdXJjZXMiOlsiLi4vc3JjL3NjaGVtYS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBpc3RhbmJ1bCBpZ25vcmUgZmlsZSAqL1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBVbmlvbiB9IGZyb20gJy4vc2NoZW1hcy9Vbmlvbi5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIFZhbHVlcyB9IGZyb20gJy4vc2NoZW1hcy9WYWx1ZXMuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBBcnJheSB9IGZyb20gJy4vc2NoZW1hcy9BcnJheS5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEFsbCB9IGZyb20gJy4vc2NoZW1hcy9BbGwuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBPYmplY3QgfSBmcm9tICcuL3NjaGVtYXMvT2JqZWN0LmpzJztcbmV4cG9ydCB7IGRlZmF1bHQgYXMgRGVsZXRlIH0gZnJvbSAnLi9zY2hlbWFzL0RlbGV0ZS5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEludmFsaWRhdGUgfSBmcm9tICcuL3NjaGVtYXMvSW52YWxpZGF0ZS5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIENvbGxlY3Rpb24gfSBmcm9tICcuL3NjaGVtYXMvQ29sbGVjdGlvbi5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIEVudGl0eSB9IGZyb20gJy4vc2NoZW1hcy9FbnRpdHlTY2hlbWEuanMnO1xuIl0sIm1hcHBpbmdzIjoiQUFBQTtBQUNBLFNBQVNBLE9BQU8sSUFBSUMsS0FBSyxRQUFRLG9CQUFvQjtBQUNyRCxTQUFTRCxPQUFPLElBQUlFLE1BQU0sUUFBUSxxQkFBcUI7QUFDdkQsU0FBU0YsT0FBTyxJQUFJRyxLQUFLLFFBQVEsb0JBQW9CO0FBQ3JELFNBQVNILE9BQU8sSUFBSUksR0FBRyxRQUFRLGtCQUFrQjtBQUNqRCxTQUFTSixPQUFPLElBQUlLLE1BQU0sUUFBUSxxQkFBcUI7QUFDdkQsU0FBU0wsT0FBTyxJQUFJTSxNQUFNLFFBQVEscUJBQXFCO0FBQ3ZELFNBQVNOLE9BQU8sSUFBSU8sVUFBVSxRQUFRLHlCQUF5QjtBQUMvRCxTQUFTUCxPQUFPLElBQUlRLFVBQVUsUUFBUSx5QkFBeUI7QUFDL0QsU0FBU1IsT0FBTyxJQUFJUyxNQUFNLFFBQVEsMkJBQTJCIn0= |
@@ -11,5 +11,5 @@ import ArraySchema from './Array.js'; | ||
constructor(definition: S, schemaAttribute?: S extends EntityMap<infer T> ? keyof T | SchemaFunction<keyof S> : undefined); | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
infer(args: any, indexes: any, recurse: any, entities: EntityTable): any; | ||
} | ||
//# sourceMappingURL=All.d.ts.map |
@@ -11,5 +11,5 @@ import ArraySchema from './Array.js'; | ||
} | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
// we return undefined | ||
super.normalize(input, parent, key, visit, addEntity, visitedEntities); | ||
super.normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args); | ||
} | ||
@@ -36,2 +36,2 @@ infer(args, indexes, recurse, entities) { | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJBcnJheVNjaGVtYSIsIkFsbFNjaGVtYSIsImNvbnN0cnVjdG9yIiwiZGVmaW5pdGlvbiIsInNjaGVtYUF0dHJpYnV0ZSIsIm5vcm1hbGl6ZSIsImlucHV0IiwicGFyZW50Iiwia2V5IiwidmlzaXQiLCJhZGRFbnRpdHkiLCJ2aXNpdGVkRW50aXRpZXMiLCJpbmZlciIsImFyZ3MiLCJpbmRleGVzIiwicmVjdXJzZSIsImVudGl0aWVzIiwiaXNTaW5nbGVTY2hlbWEiLCJlbnRpdGllc0VudHJ5Iiwic2NoZW1hIiwidW5kZWZpbmVkIiwiT2JqZWN0IiwidmFsdWVzIiwibWFwIiwiZW50aXR5IiwicGsiLCJmb3VuZCIsImxpc3QiLCJmbGF0TWFwIiwiaWQiLCJnZXRTY2hlbWFBdHRyaWJ1dGUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9BbGwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEFycmF5U2NoZW1hIGZyb20gJy4vQXJyYXkuanMnO1xuaW1wb3J0IHsgRW50aXR5VGFibGUgfSBmcm9tICcuLi9pbnRlcmZhY2UuanMnO1xuaW1wb3J0IHsgRW50aXR5SW50ZXJmYWNlLCBFbnRpdHlNYXAsIFNjaGVtYUZ1bmN0aW9uIH0gZnJvbSAnLi4vc2NoZW1hLmpzJztcblxuLyoqXG4gKiBSZXRyaWV2ZXMgYWxsIGVudGl0aWVzIGluIGNhY2hlXG4gKlxuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9yZXN0L2FwaS9BbGxcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgQWxsU2NoZW1hPFxuICBTIGV4dGVuZHMgRW50aXR5TWFwIHwgRW50aXR5SW50ZXJmYWNlID0gRW50aXR5TWFwIHwgRW50aXR5SW50ZXJmYWNlLFxuPiBleHRlbmRzIEFycmF5U2NoZW1hIHtcbiAgY29uc3RydWN0b3IoXG4gICAgZGVmaW5pdGlvbjogUyxcbiAgICBzY2hlbWFBdHRyaWJ1dGU/OiBTIGV4dGVuZHMgRW50aXR5TWFwPGluZmVyIFQ+XG4gICAgICA/IGtleW9mIFQgfCBTY2hlbWFGdW5jdGlvbjxrZXlvZiBTPlxuICAgICAgOiB1bmRlZmluZWQsXG4gICkge1xuICAgIHN1cGVyKGRlZmluaXRpb24sIHNjaGVtYUF0dHJpYnV0ZSBhcyBhbnkpO1xuICB9XG5cbiAgbm9ybWFsaXplKFxuICAgIGlucHV0OiBhbnksXG4gICAgcGFyZW50OiBhbnksXG4gICAga2V5OiBhbnksXG4gICAgdmlzaXQ6IGFueSxcbiAgICBhZGRFbnRpdHk6IGFueSxcbiAgICB2aXNpdGVkRW50aXRpZXM6IGFueSxcbiAgKTogYW55IHtcbiAgICAvLyB3ZSByZXR1cm4gdW5kZWZpbmVkXG4gICAgc3VwZXIubm9ybWFsaXplKGlucHV0LCBwYXJlbnQsIGtleSwgdmlzaXQsIGFkZEVudGl0eSwgdmlzaXRlZEVudGl0aWVzKTtcbiAgfVxuXG4gIGluZmVyKGFyZ3M6IGFueSwgaW5kZXhlczogYW55LCByZWN1cnNlOiBhbnksIGVudGl0aWVzOiBFbnRpdHlUYWJsZSk6IGFueSB7XG4gICAgaWYgKHRoaXMuaXNTaW5nbGVTY2hlbWEpIHtcbiAgICAgIGNvbnN0IGVudGl0aWVzRW50cnkgPSBlbnRpdGllc1t0aGlzLnNjaGVtYS5rZXldO1xuICAgICAgaWYgKGVudGl0aWVzRW50cnkgPT09IHVuZGVmaW5lZCkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKGVudGl0aWVzRW50cnkpLm1hcChcbiAgICAgICAgZW50aXR5ID0+IGVudGl0eSAmJiB0aGlzLnNjaGVtYS5wayhlbnRpdHkpLFxuICAgICAgKTtcbiAgICB9XG4gICAgbGV0IGZvdW5kID0gZmFsc2U7XG4gICAgY29uc3QgbGlzdCA9IE9iamVjdC52YWx1ZXModGhpcy5zY2hlbWEgYXMgUmVjb3JkPHN0cmluZywgYW55PikuZmxhdE1hcChcbiAgICAgIChzY2hlbWE6IEVudGl0eUludGVyZmFjZSkgPT4ge1xuICAgICAgICBpZiAoIWVudGl0aWVzW3NjaGVtYS5rZXldKSByZXR1cm4gW107XG4gICAgICAgIGZvdW5kID0gdHJ1ZTtcbiAgICAgICAgcmV0dXJuIE9iamVjdC52YWx1ZXMoZW50aXRpZXNbc2NoZW1hLmtleV0gYXMgUmVjb3JkPHN0cmluZywgYW55PikubWFwKFxuICAgICAgICAgIGVudGl0eSA9PiAoe1xuICAgICAgICAgICAgaWQ6IGVudGl0eSAmJiBzY2hlbWEucGsoZW50aXR5KSxcbiAgICAgICAgICAgIHNjaGVtYTogdGhpcy5nZXRTY2hlbWFBdHRyaWJ1dGUoZW50aXR5LCB1bmRlZmluZWQsIHVuZGVmaW5lZCksXG4gICAgICAgICAgfSksXG4gICAgICAgICk7XG4gICAgICB9LFxuICAgICk7XG4gICAgLy8gaWYgbm8gdGFibGUgZW50cmllcyBleGlzdCB3ZSBzaG91bGRuJ3QgZ3JhYiBhbnl0aGluZ1xuICAgIGlmICghZm91bmQpIHJldHVybjtcbiAgICByZXR1cm4gbGlzdDtcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxXQUFXLE1BQU0sWUFBWTtBQUlwQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNQyxTQUFTLFNBRXBCRCxXQUFXLENBQUM7RUFDcEJFLFdBQVdBLENBQ1RDLFVBQWEsRUFDYkMsZUFFYSxFQUNiO0lBQ0EsS0FBSyxDQUFDRCxVQUFVLEVBQUVDLGVBQWUsQ0FBUTtFQUMzQztFQUVBQyxTQUFTQSxDQUNQQyxLQUFVLEVBQ1ZDLE1BQVcsRUFDWEMsR0FBUSxFQUNSQyxLQUFVLEVBQ1ZDLFNBQWMsRUFDZEMsZUFBb0IsRUFDZjtJQUNMO0lBQ0EsS0FBSyxDQUFDTixTQUFTLENBQUNDLEtBQUssRUFBRUMsTUFBTSxFQUFFQyxHQUFHLEVBQUVDLEtBQUssRUFBRUMsU0FBUyxFQUFFQyxlQUFlLENBQUM7RUFDeEU7RUFFQUMsS0FBS0EsQ0FBQ0MsSUFBUyxFQUFFQyxPQUFZLEVBQUVDLE9BQVksRUFBRUMsUUFBcUIsRUFBTztJQUN2RSxJQUFJLElBQUksQ0FBQ0MsY0FBYyxFQUFFO01BQ3ZCLE1BQU1DLGFBQWEsR0FBR0YsUUFBUSxDQUFDLElBQUksQ0FBQ0csTUFBTSxDQUFDWCxHQUFHLENBQUM7TUFDL0MsSUFBSVUsYUFBYSxLQUFLRSxTQUFTLEVBQUUsT0FBT0EsU0FBUztNQUNqRCxPQUFPQyxNQUFNLENBQUNDLE1BQU0sQ0FBQ0osYUFBYSxDQUFDLENBQUNLLEdBQUcsQ0FDckNDLE1BQU0sSUFBSUEsTUFBTSxJQUFJLElBQUksQ0FBQ0wsTUFBTSxDQUFDTSxFQUFFLENBQUNELE1BQU0sQ0FBQyxDQUMzQztJQUNIO0lBQ0EsSUFBSUUsS0FBSyxHQUFHLEtBQUs7SUFDakIsTUFBTUMsSUFBSSxHQUFHTixNQUFNLENBQUNDLE1BQU0sQ0FBQyxJQUFJLENBQUNILE1BQU0sQ0FBd0IsQ0FBQ1MsT0FBTyxDQUNuRVQsTUFBdUIsSUFBSztNQUMzQixJQUFJLENBQUNILFFBQVEsQ0FBQ0csTUFBTSxDQUFDWCxHQUFHLENBQUMsRUFBRSxPQUFPLEVBQUU7TUFDcENrQixLQUFLLEdBQUcsSUFBSTtNQUNaLE9BQU9MLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDTixRQUFRLENBQUNHLE1BQU0sQ0FBQ1gsR0FBRyxDQUFDLENBQXdCLENBQUNlLEdBQUcsQ0FDbkVDLE1BQU0sS0FBSztRQUNUSyxFQUFFLEVBQUVMLE1BQU0sSUFBSUwsTUFBTSxDQUFDTSxFQUFFLENBQUNELE1BQU0sQ0FBQztRQUMvQkwsTUFBTSxFQUFFLElBQUksQ0FBQ1csa0JBQWtCLENBQUNOLE1BQU0sRUFBRUosU0FBUyxFQUFFQSxTQUFTO01BQzlELENBQUMsQ0FBQyxDQUNIO0lBQ0gsQ0FBQyxDQUNGO0lBQ0Q7SUFDQSxJQUFJLENBQUNNLEtBQUssRUFBRTtJQUNaLE9BQU9DLElBQUk7RUFDYjtBQUNGIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJBcnJheVNjaGVtYSIsIkFsbFNjaGVtYSIsImNvbnN0cnVjdG9yIiwiZGVmaW5pdGlvbiIsInNjaGVtYUF0dHJpYnV0ZSIsIm5vcm1hbGl6ZSIsImlucHV0IiwicGFyZW50Iiwia2V5IiwidmlzaXQiLCJhZGRFbnRpdHkiLCJ2aXNpdGVkRW50aXRpZXMiLCJzdG9yZUVudGl0aWVzIiwiYXJncyIsImluZmVyIiwiaW5kZXhlcyIsInJlY3Vyc2UiLCJlbnRpdGllcyIsImlzU2luZ2xlU2NoZW1hIiwiZW50aXRpZXNFbnRyeSIsInNjaGVtYSIsInVuZGVmaW5lZCIsIk9iamVjdCIsInZhbHVlcyIsIm1hcCIsImVudGl0eSIsInBrIiwiZm91bmQiLCJsaXN0IiwiZmxhdE1hcCIsImlkIiwiZ2V0U2NoZW1hQXR0cmlidXRlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvQWxsLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBBcnJheVNjaGVtYSBmcm9tICcuL0FycmF5LmpzJztcbmltcG9ydCB7IEVudGl0eVRhYmxlIH0gZnJvbSAnLi4vaW50ZXJmYWNlLmpzJztcbmltcG9ydCB7IEVudGl0eUludGVyZmFjZSwgRW50aXR5TWFwLCBTY2hlbWFGdW5jdGlvbiB9IGZyb20gJy4uL3NjaGVtYS5qcyc7XG5cbi8qKlxuICogUmV0cmlldmVzIGFsbCBlbnRpdGllcyBpbiBjYWNoZVxuICpcbiAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vcmVzdC9hcGkvQWxsXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEFsbFNjaGVtYTxcbiAgUyBleHRlbmRzIEVudGl0eU1hcCB8IEVudGl0eUludGVyZmFjZSA9IEVudGl0eU1hcCB8IEVudGl0eUludGVyZmFjZSxcbj4gZXh0ZW5kcyBBcnJheVNjaGVtYSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIGRlZmluaXRpb246IFMsXG4gICAgc2NoZW1hQXR0cmlidXRlPzogUyBleHRlbmRzIEVudGl0eU1hcDxpbmZlciBUPlxuICAgICAgPyBrZXlvZiBUIHwgU2NoZW1hRnVuY3Rpb248a2V5b2YgUz5cbiAgICAgIDogdW5kZWZpbmVkLFxuICApIHtcbiAgICBzdXBlcihkZWZpbml0aW9uLCBzY2hlbWFBdHRyaWJ1dGUgYXMgYW55KTtcbiAgfVxuXG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiBhbnksXG4gICAgYWRkRW50aXR5OiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBhbnksXG4gICAgc3RvcmVFbnRpdGllczogYW55LFxuICAgIGFyZ3M/OiBhbnlbXSxcbiAgKTogYW55IHtcbiAgICAvLyB3ZSByZXR1cm4gdW5kZWZpbmVkXG4gICAgc3VwZXIubm9ybWFsaXplKFxuICAgICAgaW5wdXQsXG4gICAgICBwYXJlbnQsXG4gICAgICBrZXksXG4gICAgICB2aXNpdCxcbiAgICAgIGFkZEVudGl0eSxcbiAgICAgIHZpc2l0ZWRFbnRpdGllcyxcbiAgICAgIHN0b3JlRW50aXRpZXMsXG4gICAgICBhcmdzLFxuICAgICk7XG4gIH1cblxuICBpbmZlcihhcmdzOiBhbnksIGluZGV4ZXM6IGFueSwgcmVjdXJzZTogYW55LCBlbnRpdGllczogRW50aXR5VGFibGUpOiBhbnkge1xuICAgIGlmICh0aGlzLmlzU2luZ2xlU2NoZW1hKSB7XG4gICAgICBjb25zdCBlbnRpdGllc0VudHJ5ID0gZW50aXRpZXNbdGhpcy5zY2hlbWEua2V5XTtcbiAgICAgIGlmIChlbnRpdGllc0VudHJ5ID09PSB1bmRlZmluZWQpIHJldHVybiB1bmRlZmluZWQ7XG4gICAgICByZXR1cm4gT2JqZWN0LnZhbHVlcyhlbnRpdGllc0VudHJ5KS5tYXAoXG4gICAgICAgIGVudGl0eSA9PiBlbnRpdHkgJiYgdGhpcy5zY2hlbWEucGsoZW50aXR5KSxcbiAgICAgICk7XG4gICAgfVxuICAgIGxldCBmb3VuZCA9IGZhbHNlO1xuICAgIGNvbnN0IGxpc3QgPSBPYmplY3QudmFsdWVzKHRoaXMuc2NoZW1hIGFzIFJlY29yZDxzdHJpbmcsIGFueT4pLmZsYXRNYXAoXG4gICAgICAoc2NoZW1hOiBFbnRpdHlJbnRlcmZhY2UpID0+IHtcbiAgICAgICAgaWYgKCFlbnRpdGllc1tzY2hlbWEua2V5XSkgcmV0dXJuIFtdO1xuICAgICAgICBmb3VuZCA9IHRydWU7XG4gICAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKGVudGl0aWVzW3NjaGVtYS5rZXldIGFzIFJlY29yZDxzdHJpbmcsIGFueT4pLm1hcChcbiAgICAgICAgICBlbnRpdHkgPT4gKHtcbiAgICAgICAgICAgIGlkOiBlbnRpdHkgJiYgc2NoZW1hLnBrKGVudGl0eSksXG4gICAgICAgICAgICBzY2hlbWE6IHRoaXMuZ2V0U2NoZW1hQXR0cmlidXRlKGVudGl0eSwgdW5kZWZpbmVkLCB1bmRlZmluZWQpLFxuICAgICAgICAgIH0pLFxuICAgICAgICApO1xuICAgICAgfSxcbiAgICApO1xuICAgIC8vIGlmIG5vIHRhYmxlIGVudHJpZXMgZXhpc3Qgd2Ugc2hvdWxkbid0IGdyYWIgYW55dGhpbmdcbiAgICBpZiAoIWZvdW5kKSByZXR1cm47XG4gICAgcmV0dXJuIGxpc3Q7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsV0FBVyxNQUFNLFlBQVk7QUFJcEM7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsTUFBTUMsU0FBUyxTQUVwQkQsV0FBVyxDQUFDO0VBQ3BCRSxXQUFXQSxDQUNUQyxVQUFhLEVBQ2JDLGVBRWEsRUFDYjtJQUNBLEtBQUssQ0FBQ0QsVUFBVSxFQUFFQyxlQUFlLENBQVE7RUFDM0M7RUFFQUMsU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEVBQ3BCQyxhQUFrQixFQUNsQkMsSUFBWSxFQUNQO0lBQ0w7SUFDQSxLQUFLLENBQUNSLFNBQVMsQ0FDYkMsS0FBSyxFQUNMQyxNQUFNLEVBQ05DLEdBQUcsRUFDSEMsS0FBSyxFQUNMQyxTQUFTLEVBQ1RDLGVBQWUsRUFDZkMsYUFBYSxFQUNiQyxJQUFJLENBQ0w7RUFDSDtFQUVBQyxLQUFLQSxDQUFDRCxJQUFTLEVBQUVFLE9BQVksRUFBRUMsT0FBWSxFQUFFQyxRQUFxQixFQUFPO0lBQ3ZFLElBQUksSUFBSSxDQUFDQyxjQUFjLEVBQUU7TUFDdkIsTUFBTUMsYUFBYSxHQUFHRixRQUFRLENBQUMsSUFBSSxDQUFDRyxNQUFNLENBQUNaLEdBQUcsQ0FBQztNQUMvQyxJQUFJVyxhQUFhLEtBQUtFLFNBQVMsRUFBRSxPQUFPQSxTQUFTO01BQ2pELE9BQU9DLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDSixhQUFhLENBQUMsQ0FBQ0ssR0FBRyxDQUNyQ0MsTUFBTSxJQUFJQSxNQUFNLElBQUksSUFBSSxDQUFDTCxNQUFNLENBQUNNLEVBQUUsQ0FBQ0QsTUFBTSxDQUFDLENBQzNDO0lBQ0g7SUFDQSxJQUFJRSxLQUFLLEdBQUcsS0FBSztJQUNqQixNQUFNQyxJQUFJLEdBQUdOLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDLElBQUksQ0FBQ0gsTUFBTSxDQUF3QixDQUFDUyxPQUFPLENBQ25FVCxNQUF1QixJQUFLO01BQzNCLElBQUksQ0FBQ0gsUUFBUSxDQUFDRyxNQUFNLENBQUNaLEdBQUcsQ0FBQyxFQUFFLE9BQU8sRUFBRTtNQUNwQ21CLEtBQUssR0FBRyxJQUFJO01BQ1osT0FBT0wsTUFBTSxDQUFDQyxNQUFNLENBQUNOLFFBQVEsQ0FBQ0csTUFBTSxDQUFDWixHQUFHLENBQUMsQ0FBd0IsQ0FBQ2dCLEdBQUcsQ0FDbkVDLE1BQU0sS0FBSztRQUNUSyxFQUFFLEVBQUVMLE1BQU0sSUFBSUwsTUFBTSxDQUFDTSxFQUFFLENBQUNELE1BQU0sQ0FBQztRQUMvQkwsTUFBTSxFQUFFLElBQUksQ0FBQ1csa0JBQWtCLENBQUNOLE1BQU0sRUFBRUosU0FBUyxFQUFFQSxTQUFTO01BQzlELENBQUMsQ0FBQyxDQUNIO0lBQ0gsQ0FBQyxDQUNGO0lBQ0Q7SUFDQSxJQUFJLENBQUNNLEtBQUssRUFBRTtJQUNaLE9BQU9DLElBQUk7RUFDYjtBQUNGIn0= |
@@ -7,4 +7,5 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ArraySchema extends PolymorphicSchema { | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
denormalize(input: any, unvisit: any): [denormalized: any, found: boolean, deleted: boolean]; | ||
denormalizeOnly(input: any, args: any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: unknown, indexes: unknown, recurse: unknown, entities: unknown): any; | ||
@@ -11,0 +12,0 @@ toJSON(): any[]; |
@@ -9,9 +9,12 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ArraySchema extends PolymorphicSchema { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
const values = getValues(input); | ||
return values.map((value, index) => this.normalizeValue(value, parent, key, visit, addEntity, visitedEntities)).filter(value => value !== undefined && value !== null); | ||
return values.map((value, index) => this.normalizeValue(value, parent, key, visit, addEntity, visitedEntities, storeEntities, args)).filter(value => value !== undefined && value !== null); | ||
} | ||
denormalize(input, unvisit) { | ||
return [input.map ? input.map(entityOrId => this.denormalizeValue(entityOrId, unvisit)).filter(filterEmpty).map(([value]) => value) : input, true, false]; | ||
return [this.denormalizeOnly(input, [], unvisit), true, false]; | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return input.map ? input.map(entityOrId => this.denormalizeValue(entityOrId, unvisit)).filter(filterEmpty) : input; | ||
} | ||
infer(args, indexes, recurse, entities) { | ||
@@ -24,2 +27,2 @@ return undefined; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsImZpbHRlckVtcHR5IiwiZ2V0VmFsdWVzIiwiQXJyYXlTY2hlbWEiLCJub3JtYWxpemUiLCJpbnB1dCIsInBhcmVudCIsImtleSIsInZpc2l0IiwiYWRkRW50aXR5IiwidmlzaXRlZEVudGl0aWVzIiwidmFsdWVzIiwibWFwIiwidmFsdWUiLCJpbmRleCIsIm5vcm1hbGl6ZVZhbHVlIiwiZmlsdGVyIiwidW5kZWZpbmVkIiwiZGVub3JtYWxpemUiLCJ1bnZpc2l0IiwiZW50aXR5T3JJZCIsImRlbm9ybWFsaXplVmFsdWUiLCJpbmZlciIsImFyZ3MiLCJpbmRleGVzIiwicmVjdXJzZSIsImVudGl0aWVzIiwidG9KU09OIiwic2NoZW1hIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvQXJyYXkudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFBvbHltb3JwaGljU2NoZW1hIGZyb20gJy4vUG9seW1vcnBoaWMuanMnO1xuaW1wb3J0IHsgZmlsdGVyRW1wdHksIGdldFZhbHVlcyB9IGZyb20gJy4vdXRpbHMuanMnO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYXJyYXlzXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL3Jlc3QvYXBpL0FycmF5XG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEFycmF5U2NoZW1hIGV4dGVuZHMgUG9seW1vcnBoaWNTY2hlbWEge1xuICBub3JtYWxpemUoXG4gICAgaW5wdXQ6IGFueSxcbiAgICBwYXJlbnQ6IGFueSxcbiAgICBrZXk6IGFueSxcbiAgICB2aXNpdDogYW55LFxuICAgIGFkZEVudGl0eTogYW55LFxuICAgIHZpc2l0ZWRFbnRpdGllczogYW55LFxuICApOiBhbnkge1xuICAgIGNvbnN0IHZhbHVlcyA9IGdldFZhbHVlcyhpbnB1dCk7XG5cbiAgICByZXR1cm4gdmFsdWVzXG4gICAgICAubWFwKCh2YWx1ZSwgaW5kZXgpID0+XG4gICAgICAgIHRoaXMubm9ybWFsaXplVmFsdWUoXG4gICAgICAgICAgdmFsdWUsXG4gICAgICAgICAgcGFyZW50LFxuICAgICAgICAgIGtleSxcbiAgICAgICAgICB2aXNpdCxcbiAgICAgICAgICBhZGRFbnRpdHksXG4gICAgICAgICAgdmlzaXRlZEVudGl0aWVzLFxuICAgICAgICApLFxuICAgICAgKVxuICAgICAgLmZpbHRlcih2YWx1ZSA9PiB2YWx1ZSAhPT0gdW5kZWZpbmVkICYmIHZhbHVlICE9PSBudWxsKTtcbiAgfVxuXG4gIGRlbm9ybWFsaXplKFxuICAgIGlucHV0OiBhbnksXG4gICAgdW52aXNpdDogYW55LFxuICApOiBbZGVub3JtYWxpemVkOiBhbnksIGZvdW5kOiBib29sZWFuLCBkZWxldGVkOiBib29sZWFuXSB7XG4gICAgcmV0dXJuIFtcbiAgICAgIGlucHV0Lm1hcFxuICAgICAgICA/IGlucHV0XG4gICAgICAgICAgICAubWFwKChlbnRpdHlPcklkOiBhbnkpID0+XG4gICAgICAgICAgICAgIHRoaXMuZGVub3JtYWxpemVWYWx1ZShlbnRpdHlPcklkLCB1bnZpc2l0KSxcbiAgICAgICAgICAgIClcbiAgICAgICAgICAgIC5maWx0ZXIoZmlsdGVyRW1wdHkpXG4gICAgICAgICAgICAubWFwKChbdmFsdWVdOiBhbnkpID0+IHZhbHVlKVxuICAgICAgICA6IGlucHV0LFxuICAgICAgdHJ1ZSxcbiAgICAgIGZhbHNlLFxuICAgIF07XG4gIH1cblxuICBpbmZlcihcbiAgICBhcmdzOiB1bmtub3duLFxuICAgIGluZGV4ZXM6IHVua25vd24sXG4gICAgcmVjdXJzZTogdW5rbm93bixcbiAgICBlbnRpdGllczogdW5rbm93bixcbiAgKTogYW55IHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgdG9KU09OKCkge1xuICAgIHJldHVybiBbdGhpcy5zY2hlbWFdO1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLGlCQUFpQixNQUFNLGtCQUFrQjtBQUNoRCxTQUFTQyxXQUFXLEVBQUVDLFNBQVMsUUFBUSxZQUFZOztBQUVuRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsTUFBTUMsV0FBVyxTQUFTSCxpQkFBaUIsQ0FBQztFQUN6REksU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEVBQ2Y7SUFDTCxNQUFNQyxNQUFNLEdBQUdULFNBQVMsQ0FBQ0csS0FBSyxDQUFDO0lBRS9CLE9BQU9NLE1BQU0sQ0FDVkMsR0FBRyxDQUFDLENBQUNDLEtBQUssRUFBRUMsS0FBSyxLQUNoQixJQUFJLENBQUNDLGNBQWMsQ0FDakJGLEtBQUssRUFDTFAsTUFBTSxFQUNOQyxHQUFHLEVBQ0hDLEtBQUssRUFDTEMsU0FBUyxFQUNUQyxlQUFlLENBQ2hCLENBQ0YsQ0FDQU0sTUFBTSxDQUFDSCxLQUFLLElBQUlBLEtBQUssS0FBS0ksU0FBUyxJQUFJSixLQUFLLEtBQUssSUFBSSxDQUFDO0VBQzNEO0VBRUFLLFdBQVdBLENBQ1RiLEtBQVUsRUFDVmMsT0FBWSxFQUMyQztJQUN2RCxPQUFPLENBQ0xkLEtBQUssQ0FBQ08sR0FBRyxHQUNMUCxLQUFLLENBQ0ZPLEdBQUcsQ0FBRVEsVUFBZSxJQUNuQixJQUFJLENBQUNDLGdCQUFnQixDQUFDRCxVQUFVLEVBQUVELE9BQU8sQ0FBQyxDQUMzQyxDQUNBSCxNQUFNLENBQUNmLFdBQVcsQ0FBQyxDQUNuQlcsR0FBRyxDQUFDLENBQUMsQ0FBQ0MsS0FBSyxDQUFNLEtBQUtBLEtBQUssQ0FBQyxHQUMvQlIsS0FBSyxFQUNULElBQUksRUFDSixLQUFLLENBQ047RUFDSDtFQUVBaUIsS0FBS0EsQ0FDSEMsSUFBYSxFQUNiQyxPQUFnQixFQUNoQkMsT0FBZ0IsRUFDaEJDLFFBQWlCLEVBQ1o7SUFDTCxPQUFPVCxTQUFTO0VBQ2xCO0VBRUFVLE1BQU1BLENBQUEsRUFBRztJQUNQLE9BQU8sQ0FBQyxJQUFJLENBQUNDLE1BQU0sQ0FBQztFQUN0QjtBQUNGIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsImZpbHRlckVtcHR5IiwiZ2V0VmFsdWVzIiwiQXJyYXlTY2hlbWEiLCJub3JtYWxpemUiLCJpbnB1dCIsInBhcmVudCIsImtleSIsInZpc2l0IiwiYWRkRW50aXR5IiwidmlzaXRlZEVudGl0aWVzIiwic3RvcmVFbnRpdGllcyIsImFyZ3MiLCJ2YWx1ZXMiLCJtYXAiLCJ2YWx1ZSIsImluZGV4Iiwibm9ybWFsaXplVmFsdWUiLCJmaWx0ZXIiLCJ1bmRlZmluZWQiLCJkZW5vcm1hbGl6ZSIsInVudmlzaXQiLCJkZW5vcm1hbGl6ZU9ubHkiLCJlbnRpdHlPcklkIiwiZGVub3JtYWxpemVWYWx1ZSIsImluZmVyIiwiaW5kZXhlcyIsInJlY3Vyc2UiLCJlbnRpdGllcyIsInRvSlNPTiIsInNjaGVtYSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWFzL0FycmF5LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQb2x5bW9ycGhpY1NjaGVtYSBmcm9tICcuL1BvbHltb3JwaGljLmpzJztcbmltcG9ydCB7IGZpbHRlckVtcHR5LCBnZXRWYWx1ZXMgfSBmcm9tICcuL3V0aWxzLmpzJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIGFycmF5c1xuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9yZXN0L2FwaS9BcnJheVxuICovXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBBcnJheVNjaGVtYSBleHRlbmRzIFBvbHltb3JwaGljU2NoZW1hIHtcbiAgbm9ybWFsaXplKFxuICAgIGlucHV0OiBhbnksXG4gICAgcGFyZW50OiBhbnksXG4gICAga2V5OiBhbnksXG4gICAgdmlzaXQ6IGFueSxcbiAgICBhZGRFbnRpdHk6IGFueSxcbiAgICB2aXNpdGVkRW50aXRpZXM6IGFueSxcbiAgICBzdG9yZUVudGl0aWVzOiBhbnksXG4gICAgYXJncz86IGFueVtdLFxuICApOiBhbnkge1xuICAgIGNvbnN0IHZhbHVlcyA9IGdldFZhbHVlcyhpbnB1dCk7XG5cbiAgICByZXR1cm4gdmFsdWVzXG4gICAgICAubWFwKCh2YWx1ZSwgaW5kZXgpID0+XG4gICAgICAgIHRoaXMubm9ybWFsaXplVmFsdWUoXG4gICAgICAgICAgdmFsdWUsXG4gICAgICAgICAgcGFyZW50LFxuICAgICAgICAgIGtleSxcbiAgICAgICAgICB2aXNpdCxcbiAgICAgICAgICBhZGRFbnRpdHksXG4gICAgICAgICAgdmlzaXRlZEVudGl0aWVzLFxuICAgICAgICAgIHN0b3JlRW50aXRpZXMsXG4gICAgICAgICAgYXJncyxcbiAgICAgICAgKSxcbiAgICAgIClcbiAgICAgIC5maWx0ZXIodmFsdWUgPT4gdmFsdWUgIT09IHVuZGVmaW5lZCAmJiB2YWx1ZSAhPT0gbnVsbCk7XG4gIH1cblxuICBkZW5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHVudmlzaXQ6IGFueSxcbiAgKTogW2Rlbm9ybWFsaXplZDogYW55LCBmb3VuZDogYm9vbGVhbiwgZGVsZXRlZDogYm9vbGVhbl0ge1xuICAgIHJldHVybiBbdGhpcy5kZW5vcm1hbGl6ZU9ubHkoaW5wdXQsIFtdLCB1bnZpc2l0KSwgdHJ1ZSwgZmFsc2VdO1xuICB9XG5cbiAgZGVub3JtYWxpemVPbmx5KFxuICAgIGlucHV0OiBhbnksXG4gICAgYXJnczogYW55W10sXG4gICAgdW52aXNpdDogKGlucHV0OiBhbnksIHNjaGVtYTogYW55KSA9PiBhbnksXG4gICkge1xuICAgIHJldHVybiBpbnB1dC5tYXBcbiAgICAgID8gaW5wdXRcbiAgICAgICAgICAubWFwKChlbnRpdHlPcklkOiBhbnkpID0+IHRoaXMuZGVub3JtYWxpemVWYWx1ZShlbnRpdHlPcklkLCB1bnZpc2l0KSlcbiAgICAgICAgICAuZmlsdGVyKGZpbHRlckVtcHR5KVxuICAgICAgOiBpbnB1dDtcbiAgfVxuXG4gIGluZmVyKFxuICAgIGFyZ3M6IHVua25vd24sXG4gICAgaW5kZXhlczogdW5rbm93bixcbiAgICByZWN1cnNlOiB1bmtub3duLFxuICAgIGVudGl0aWVzOiB1bmtub3duLFxuICApOiBhbnkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICB0b0pTT04oKSB7XG4gICAgcmV0dXJuIFt0aGlzLnNjaGVtYV07XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsaUJBQWlCLE1BQU0sa0JBQWtCO0FBQ2hELFNBQVNDLFdBQVcsRUFBRUMsU0FBUyxRQUFRLFlBQVk7O0FBRW5EO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNQyxXQUFXLFNBQVNILGlCQUFpQixDQUFDO0VBQ3pESSxTQUFTQSxDQUNQQyxLQUFVLEVBQ1ZDLE1BQVcsRUFDWEMsR0FBUSxFQUNSQyxLQUFVLEVBQ1ZDLFNBQWMsRUFDZEMsZUFBb0IsRUFDcEJDLGFBQWtCLEVBQ2xCQyxJQUFZLEVBQ1A7SUFDTCxNQUFNQyxNQUFNLEdBQUdYLFNBQVMsQ0FBQ0csS0FBSyxDQUFDO0lBRS9CLE9BQU9RLE1BQU0sQ0FDVkMsR0FBRyxDQUFDLENBQUNDLEtBQUssRUFBRUMsS0FBSyxLQUNoQixJQUFJLENBQUNDLGNBQWMsQ0FDakJGLEtBQUssRUFDTFQsTUFBTSxFQUNOQyxHQUFHLEVBQ0hDLEtBQUssRUFDTEMsU0FBUyxFQUNUQyxlQUFlLEVBQ2ZDLGFBQWEsRUFDYkMsSUFBSSxDQUNMLENBQ0YsQ0FDQU0sTUFBTSxDQUFDSCxLQUFLLElBQUlBLEtBQUssS0FBS0ksU0FBUyxJQUFJSixLQUFLLEtBQUssSUFBSSxDQUFDO0VBQzNEO0VBRUFLLFdBQVdBLENBQ1RmLEtBQVUsRUFDVmdCLE9BQVksRUFDMkM7SUFDdkQsT0FBTyxDQUFDLElBQUksQ0FBQ0MsZUFBZSxDQUFDakIsS0FBSyxFQUFFLEVBQUUsRUFBRWdCLE9BQU8sQ0FBQyxFQUFFLElBQUksRUFBRSxLQUFLLENBQUM7RUFDaEU7RUFFQUMsZUFBZUEsQ0FDYmpCLEtBQVUsRUFDVk8sSUFBVyxFQUNYUyxPQUF5QyxFQUN6QztJQUNBLE9BQU9oQixLQUFLLENBQUNTLEdBQUcsR0FDWlQsS0FBSyxDQUNGUyxHQUFHLENBQUVTLFVBQWUsSUFBSyxJQUFJLENBQUNDLGdCQUFnQixDQUFDRCxVQUFVLEVBQUVGLE9BQU8sQ0FBQyxDQUFDLENBQ3BFSCxNQUFNLENBQUNqQixXQUFXLENBQUMsR0FDdEJJLEtBQUs7RUFDWDtFQUVBb0IsS0FBS0EsQ0FDSGIsSUFBYSxFQUNiYyxPQUFnQixFQUNoQkMsT0FBZ0IsRUFDaEJDLFFBQWlCLEVBQ1o7SUFDTCxPQUFPVCxTQUFTO0VBQ2xCO0VBRUFVLE1BQU1BLENBQUEsRUFBRztJQUNQLE9BQU8sQ0FBQyxJQUFJLENBQUNDLE1BQU0sQ0FBQztFQUN0QjtBQUNGIn0= |
@@ -0,1 +1,2 @@ | ||
import Invalidate from './Invalidate.js'; | ||
import type { EntityInterface } from '../interface.js'; | ||
@@ -10,24 +11,5 @@ import type { AbstractInstanceType } from '../normal.js'; | ||
process: any; | ||
}> implements SchemaClass { | ||
private _entity; | ||
constructor(entity: E); | ||
get key(): string; | ||
normalize(input: any, parent: any, key: string | undefined, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): string | undefined; | ||
infer(args: any, indexes: any, recurse: any): any; | ||
}> extends Invalidate<E> implements SchemaClass { | ||
denormalize(id: string, unvisit: UnvisitFunction): [denormalized: AbstractInstanceType<E>, found: boolean, suspend: boolean]; | ||
_denormalizeNullable(): [ | ||
AbstractInstanceType<E> | undefined, | ||
boolean, | ||
false | ||
]; | ||
_normalizeNullable(): string | undefined; | ||
merge(existing: any, incoming: any): any; | ||
useIncoming(existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): boolean; | ||
} | ||
//# sourceMappingURL=Delete.d.ts.map |
/* eslint-disable @typescript-eslint/explicit-module-boundary-types */ | ||
import { DELETED } from '../special.js'; | ||
import Invalidate from './Invalidate.js'; | ||
// TODO(breaking): mark deprecated | ||
/** | ||
@@ -9,59 +8,7 @@ * Marks entity as deleted. | ||
*/ | ||
export default class Delete { | ||
constructor(entity) { | ||
if (process.env.NODE_ENV !== 'production' && !entity) { | ||
throw new Error('Expected option "entity" not found on DeleteSchema.'); | ||
} | ||
this._entity = entity; | ||
} | ||
get key() { | ||
return this._entity.key; | ||
} | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
// TODO: what's store needs to be a differing type from fromJS | ||
const processedEntity = this._entity.process(input, parent, key); | ||
const id = this._entity.pk(processedEntity, parent, key); | ||
if (process.env.NODE_ENV !== 'production' && (id === undefined || id === '')) { | ||
var _name; | ||
const error = new Error(`Missing usable primary key when normalizing response. | ||
This is likely due to a malformed response. | ||
Try inspecting the network response or fetch() return value. | ||
Or use debugging tools: https://resthooks.io/docs/guides/debugging | ||
Learn more about schemas: https://resthooks.io/docs/api/schema | ||
Delete(Entity): Delete(${(_name = this._entity.name) != null ? _name : this._entity}) | ||
Value: ${input && JSON.stringify(input, null, 2)} | ||
`); | ||
error.status = 400; | ||
throw error; | ||
} | ||
addEntity(this, DELETED, id); | ||
return id; | ||
} | ||
infer(args, indexes, recurse) { | ||
return undefined; | ||
} | ||
export default class Delete extends Invalidate { | ||
denormalize(id, unvisit) { | ||
return unvisit(id, this._entity); | ||
} | ||
/* istanbul ignore next */ | ||
_denormalizeNullable() { | ||
return []; | ||
} | ||
/* istanbul ignore next */ | ||
_normalizeNullable() { | ||
return []; | ||
} | ||
/* istanbul ignore next */ | ||
merge(existing, incoming) { | ||
return incoming; | ||
} | ||
useIncoming(existingMeta, incomingMeta, existing, incoming) { | ||
return existingMeta.date <= incomingMeta.date; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJERUxFVEVEIiwiRGVsZXRlIiwiY29uc3RydWN0b3IiLCJlbnRpdHkiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJFcnJvciIsIl9lbnRpdHkiLCJrZXkiLCJub3JtYWxpemUiLCJpbnB1dCIsInBhcmVudCIsInZpc2l0IiwiYWRkRW50aXR5IiwidmlzaXRlZEVudGl0aWVzIiwicHJvY2Vzc2VkRW50aXR5IiwiaWQiLCJwayIsInVuZGVmaW5lZCIsIl9uYW1lIiwiZXJyb3IiLCJuYW1lIiwiSlNPTiIsInN0cmluZ2lmeSIsInN0YXR1cyIsImluZmVyIiwiYXJncyIsImluZGV4ZXMiLCJyZWN1cnNlIiwiZGVub3JtYWxpemUiLCJ1bnZpc2l0IiwiX2Rlbm9ybWFsaXplTnVsbGFibGUiLCJfbm9ybWFsaXplTnVsbGFibGUiLCJtZXJnZSIsImV4aXN0aW5nIiwiaW5jb21pbmciLCJ1c2VJbmNvbWluZyIsImV4aXN0aW5nTWV0YSIsImluY29taW5nTWV0YSIsImRhdGUiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9EZWxldGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L2V4cGxpY2l0LW1vZHVsZS1ib3VuZGFyeS10eXBlcyAqL1xuaW1wb3J0IHR5cGUgeyBFbnRpdHlJbnRlcmZhY2UgfSBmcm9tICcuLi9pbnRlcmZhY2UuanMnO1xuaW1wb3J0IHR5cGUgeyBBYnN0cmFjdEluc3RhbmNlVHlwZSB9IGZyb20gJy4uL25vcm1hbC5qcyc7XG5pbXBvcnQgeyBTY2hlbWFDbGFzcywgVW52aXNpdEZ1bmN0aW9uIH0gZnJvbSAnLi4vc2NoZW1hLmpzJztcbmltcG9ydCB7IERFTEVURUQgfSBmcm9tICcuLi9zcGVjaWFsLmpzJztcblxuLyoqXG4gKiBNYXJrcyBlbnRpdHkgYXMgZGVsZXRlZC5cbiAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vcmVzdC9hcGkvRGVsZXRlXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIERlbGV0ZTxFIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlICYgeyBwcm9jZXNzOiBhbnkgfT5cbiAgaW1wbGVtZW50cyBTY2hlbWFDbGFzc1xue1xuICBwcml2YXRlIGRlY2xhcmUgX2VudGl0eTogRTtcblxuICBjb25zdHJ1Y3RvcihlbnRpdHk6IEUpIHtcbiAgICBpZiAocHJvY2Vzcy5lbnYuTk9ERV9FTlYgIT09ICdwcm9kdWN0aW9uJyAmJiAhZW50aXR5KSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0V4cGVjdGVkIG9wdGlvbiBcImVudGl0eVwiIG5vdCBmb3VuZCBvbiBEZWxldGVTY2hlbWEuJyk7XG4gICAgfVxuICAgIHRoaXMuX2VudGl0eSA9IGVudGl0eTtcbiAgfVxuXG4gIGdldCBrZXkoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2VudGl0eS5rZXk7XG4gIH1cblxuICBub3JtYWxpemUoXG4gICAgaW5wdXQ6IGFueSxcbiAgICBwYXJlbnQ6IGFueSxcbiAgICBrZXk6IHN0cmluZyB8IHVuZGVmaW5lZCxcbiAgICB2aXNpdDogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIGFkZEVudGl0eTogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIHZpc2l0ZWRFbnRpdGllczogUmVjb3JkPHN0cmluZywgYW55PixcbiAgKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICAvLyBUT0RPOiB3aGF0J3Mgc3RvcmUgbmVlZHMgdG8gYmUgYSBkaWZmZXJpbmcgdHlwZSBmcm9tIGZyb21KU1xuICAgIGNvbnN0IHByb2Nlc3NlZEVudGl0eSA9IHRoaXMuX2VudGl0eS5wcm9jZXNzKGlucHV0LCBwYXJlbnQsIGtleSk7XG4gICAgY29uc3QgaWQgPSB0aGlzLl9lbnRpdHkucGsocHJvY2Vzc2VkRW50aXR5LCBwYXJlbnQsIGtleSk7XG5cbiAgICBpZiAoXG4gICAgICBwcm9jZXNzLmVudi5OT0RFX0VOViAhPT0gJ3Byb2R1Y3Rpb24nICYmXG4gICAgICAoaWQgPT09IHVuZGVmaW5lZCB8fCBpZCA9PT0gJycpXG4gICAgKSB7XG4gICAgICBjb25zdCBlcnJvciA9IG5ldyBFcnJvcihcbiAgICAgICAgYE1pc3NpbmcgdXNhYmxlIHByaW1hcnkga2V5IHdoZW4gbm9ybWFsaXppbmcgcmVzcG9uc2UuXG5cbiAgVGhpcyBpcyBsaWtlbHkgZHVlIHRvIGEgbWFsZm9ybWVkIHJlc3BvbnNlLlxuICBUcnkgaW5zcGVjdGluZyB0aGUgbmV0d29yayByZXNwb25zZSBvciBmZXRjaCgpIHJldHVybiB2YWx1ZS5cbiAgT3IgdXNlIGRlYnVnZ2luZyB0b29sczogaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9ndWlkZXMvZGVidWdnaW5nXG4gIExlYXJuIG1vcmUgYWJvdXQgc2NoZW1hczogaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9hcGkvc2NoZW1hXG5cbiAgRGVsZXRlKEVudGl0eSk6IERlbGV0ZSgkeyh0aGlzLl9lbnRpdHkgYXMgYW55KS5uYW1lID8/IHRoaXMuX2VudGl0eX0pXG4gIFZhbHVlOiAke2lucHV0ICYmIEpTT04uc3RyaW5naWZ5KGlucHV0LCBudWxsLCAyKX1cbiAgYCxcbiAgICAgICk7XG4gICAgICAoZXJyb3IgYXMgYW55KS5zdGF0dXMgPSA0MDA7XG4gICAgICB0aHJvdyBlcnJvcjtcbiAgICB9XG4gICAgYWRkRW50aXR5KHRoaXMsIERFTEVURUQsIGlkKTtcbiAgICByZXR1cm4gaWQ7XG4gIH1cblxuICBpbmZlcihhcmdzOiBhbnksIGluZGV4ZXM6IGFueSwgcmVjdXJzZTogYW55KTogYW55IHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgZGVub3JtYWxpemUoXG4gICAgaWQ6IHN0cmluZyxcbiAgICB1bnZpc2l0OiBVbnZpc2l0RnVuY3Rpb24sXG4gICk6IFtkZW5vcm1hbGl6ZWQ6IEFic3RyYWN0SW5zdGFuY2VUeXBlPEU+LCBmb3VuZDogYm9vbGVhbiwgc3VzcGVuZDogYm9vbGVhbl0ge1xuICAgIHJldHVybiB1bnZpc2l0KGlkLCB0aGlzLl9lbnRpdHkpIGFzIGFueTtcbiAgfVxuXG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIF9kZW5vcm1hbGl6ZU51bGxhYmxlKCk6IFtcbiAgICBBYnN0cmFjdEluc3RhbmNlVHlwZTxFPiB8IHVuZGVmaW5lZCxcbiAgICBib29sZWFuLFxuICAgIGZhbHNlLFxuICBdIHtcbiAgICByZXR1cm4gW10gYXMgYW55O1xuICB9XG5cbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgX25vcm1hbGl6ZU51bGxhYmxlKCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIFtdIGFzIGFueTtcbiAgfVxuXG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIG1lcmdlKGV4aXN0aW5nOiBhbnksIGluY29taW5nOiBhbnkpIHtcbiAgICByZXR1cm4gaW5jb21pbmc7XG4gIH1cblxuICB1c2VJbmNvbWluZyhcbiAgICBleGlzdGluZ01ldGE6IHsgZGF0ZTogbnVtYmVyOyBmZXRjaGVkQXQ6IG51bWJlciB9LFxuICAgIGluY29taW5nTWV0YTogeyBkYXRlOiBudW1iZXI7IGZldGNoZWRBdDogbnVtYmVyIH0sXG4gICAgZXhpc3Rpbmc6IGFueSxcbiAgICBpbmNvbWluZzogYW55LFxuICApIHtcbiAgICByZXR1cm4gZXhpc3RpbmdNZXRhLmRhdGUgPD0gaW5jb21pbmdNZXRhLmRhdGU7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBSUEsU0FBU0EsT0FBTyxRQUFRLGVBQWU7O0FBRXZDO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNQyxNQUFNLENBRTNCO0VBR0VDLFdBQVdBLENBQUNDLE1BQVMsRUFBRTtJQUNyQixJQUFJQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLFlBQVksSUFBSSxDQUFDSCxNQUFNLEVBQUU7TUFDcEQsTUFBTSxJQUFJSSxLQUFLLENBQUMscURBQXFELENBQUM7SUFDeEU7SUFDQSxJQUFJLENBQUNDLE9BQU8sR0FBR0wsTUFBTTtFQUN2QjtFQUVBLElBQUlNLEdBQUdBLENBQUEsRUFBRztJQUNSLE9BQU8sSUFBSSxDQUFDRCxPQUFPLENBQUNDLEdBQUc7RUFDekI7RUFFQUMsU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hILEdBQXVCLEVBQ3ZCSSxLQUE0QixFQUM1QkMsU0FBZ0MsRUFDaENDLGVBQW9DLEVBQ2hCO0lBQ3BCO0lBQ0EsTUFBTUMsZUFBZSxHQUFHLElBQUksQ0FBQ1IsT0FBTyxDQUFDSixPQUFPLENBQUNPLEtBQUssRUFBRUMsTUFBTSxFQUFFSCxHQUFHLENBQUM7SUFDaEUsTUFBTVEsRUFBRSxHQUFHLElBQUksQ0FBQ1QsT0FBTyxDQUFDVSxFQUFFLENBQUNGLGVBQWUsRUFBRUosTUFBTSxFQUFFSCxHQUFHLENBQUM7SUFFeEQsSUFDRUwsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFFBQVEsS0FBSyxZQUFZLEtBQ3BDVyxFQUFFLEtBQUtFLFNBQVMsSUFBSUYsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUMvQjtNQUFBLElBQUFHLEtBQUE7TUFDQSxNQUFNQyxLQUFLLEdBQUcsSUFBSWQsS0FBSyxDQUNwQjtBQUNUO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJCQUF5QixDQUFBYSxLQUFBLEdBQUcsSUFBSSxDQUFDWixPQUFPLENBQVNjLElBQUksWUFBQUYsS0FBQSxHQUFJLElBQUksQ0FBQ1osT0FBUTtBQUN0RSxXQUFXRyxLQUFLLElBQUlZLElBQUksQ0FBQ0MsU0FBUyxDQUFDYixLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBRTtBQUNuRCxHQUFHLENBQ0k7TUFDQVUsS0FBSyxDQUFTSSxNQUFNLEdBQUcsR0FBRztNQUMzQixNQUFNSixLQUFLO0lBQ2I7SUFDQVAsU0FBUyxDQUFDLElBQUksRUFBRWQsT0FBTyxFQUFFaUIsRUFBRSxDQUFDO0lBQzVCLE9BQU9BLEVBQUU7RUFDWDtFQUVBUyxLQUFLQSxDQUFDQyxJQUFTLEVBQUVDLE9BQVksRUFBRUMsT0FBWSxFQUFPO0lBQ2hELE9BQU9WLFNBQVM7RUFDbEI7RUFFQVcsV0FBV0EsQ0FDVGIsRUFBVSxFQUNWYyxPQUF3QixFQUNtRDtJQUMzRSxPQUFPQSxPQUFPLENBQUNkLEVBQUUsRUFBRSxJQUFJLENBQUNULE9BQU8sQ0FBQztFQUNsQzs7RUFFQTtFQUNBd0Isb0JBQW9CQSxDQUFBLEVBSWxCO0lBQ0EsT0FBTyxFQUFFO0VBQ1g7O0VBRUE7RUFDQUMsa0JBQWtCQSxDQUFBLEVBQXVCO0lBQ3ZDLE9BQU8sRUFBRTtFQUNYOztFQUVBO0VBQ0FDLEtBQUtBLENBQUNDLFFBQWEsRUFBRUMsUUFBYSxFQUFFO0lBQ2xDLE9BQU9BLFFBQVE7RUFDakI7RUFFQUMsV0FBV0EsQ0FDVEMsWUFBaUQsRUFDakRDLFlBQWlELEVBQ2pESixRQUFhLEVBQ2JDLFFBQWEsRUFDYjtJQUNBLE9BQU9FLFlBQVksQ0FBQ0UsSUFBSSxJQUFJRCxZQUFZLENBQUNDLElBQUk7RUFDL0M7QUFDRiJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJJbnZhbGlkYXRlIiwiRGVsZXRlIiwiZGVub3JtYWxpemUiLCJpZCIsInVudmlzaXQiLCJfZW50aXR5Il0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvRGVsZXRlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC9leHBsaWNpdC1tb2R1bGUtYm91bmRhcnktdHlwZXMgKi9cbmltcG9ydCBJbnZhbGlkYXRlIGZyb20gJy4vSW52YWxpZGF0ZS5qcyc7XG5pbXBvcnQgdHlwZSB7IEVudGl0eUludGVyZmFjZSB9IGZyb20gJy4uL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IEFic3RyYWN0SW5zdGFuY2VUeXBlIH0gZnJvbSAnLi4vbm9ybWFsLmpzJztcbmltcG9ydCB7IFNjaGVtYUNsYXNzLCBVbnZpc2l0RnVuY3Rpb24gfSBmcm9tICcuLi9zY2hlbWEuanMnO1xuXG4vLyBUT0RPKGJyZWFraW5nKTogbWFyayBkZXByZWNhdGVkXG4vKipcbiAqIE1hcmtzIGVudGl0eSBhcyBkZWxldGVkLlxuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9yZXN0L2FwaS9EZWxldGVcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgRGVsZXRlPFxuICAgIEUgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2UgJiB7XG4gICAgICBwcm9jZXNzOiBhbnk7XG4gICAgfSxcbiAgPlxuICBleHRlbmRzIEludmFsaWRhdGU8RT5cbiAgaW1wbGVtZW50cyBTY2hlbWFDbGFzc1xue1xuICBkZW5vcm1hbGl6ZShcbiAgICBpZDogc3RyaW5nLFxuICAgIHVudmlzaXQ6IFVudmlzaXRGdW5jdGlvbixcbiAgKTogW2Rlbm9ybWFsaXplZDogQWJzdHJhY3RJbnN0YW5jZVR5cGU8RT4sIGZvdW5kOiBib29sZWFuLCBzdXNwZW5kOiBib29sZWFuXSB7XG4gICAgcmV0dXJuIHVudmlzaXQoaWQsIHRoaXMuX2VudGl0eSkgYXMgYW55O1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0EsT0FBT0EsVUFBVSxNQUFNLGlCQUFpQjtBQUt4QztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNQyxNQUFNLFNBS2pCRCxVQUFVLENBRXBCO0VBQ0VFLFdBQVdBLENBQ1RDLEVBQVUsRUFDVkMsT0FBd0IsRUFDbUQ7SUFDM0UsT0FBT0EsT0FBTyxDQUFDRCxFQUFFLEVBQUUsSUFBSSxDQUFDRSxPQUFPLENBQUM7RUFDbEM7QUFDRiJ9 |
import type { UnvisitFunction } from '../interface.js'; | ||
import { AbstractInstanceType } from '../normal.js'; | ||
declare const Entity_base: import("./EntitySchema.js").IEntityClass<abstract new (...args: any[]) => { | ||
pk(parent?: any, key?: string | undefined): string | undefined; | ||
pk(parent?: any, key?: string | undefined, args?: readonly any[] | undefined): string | undefined; | ||
}> & (abstract new (...args: any[]) => { | ||
pk(parent?: any, key?: string | undefined): string | undefined; | ||
pk(parent?: any, key?: string | undefined, args?: readonly any[] | undefined): string | undefined; | ||
}); | ||
@@ -19,3 +19,3 @@ /** | ||
*/ | ||
abstract pk(parent?: any, key?: string): string | undefined; | ||
abstract pk(parent?: any, key?: string, args?: readonly any[]): string | undefined; | ||
/** Control how automatic schema validation is handled | ||
@@ -49,2 +49,15 @@ * | ||
}, existing: any, incoming: any): any; | ||
static mergeMetaWithStore(existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}; | ||
/** Factory method to convert from Plain JS Objects. | ||
@@ -62,3 +75,3 @@ * | ||
*/ | ||
static pk: <T extends typeof Entity>(this: T, value: Partial<AbstractInstanceType<T>>, parent?: any, key?: string) => string | undefined; | ||
static pk: <T extends typeof Entity>(this: T, value: Partial<AbstractInstanceType<T>>, parent?: any, key?: string, args?: any[]) => string | undefined; | ||
/** Do any transformations when first receiving input */ | ||
@@ -65,0 +78,0 @@ static process(input: any, parent: any, key: string | undefined): any; |
@@ -19,2 +19,11 @@ /* eslint-disable @typescript-eslint/explicit-module-boundary-types */ | ||
/** Control how automatic schema validation is handled | ||
* | ||
* `undefined`: Defaults - throw error in worst offense | ||
* 'warn': only ever warn | ||
* 'silent': Don't bother with processing at all | ||
* | ||
* Note: this only applies to non-nested members. | ||
*/ | ||
/** Return true to merge incoming data; false keeps existing entity | ||
@@ -44,2 +53,9 @@ * | ||
} | ||
static mergeMetaWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
return { | ||
expiresAt: Math.max(this.expiresAt(incomingMeta, incoming), existingMeta.expiresAt), | ||
date: Math.max(incomingMeta.date, existingMeta.date), | ||
fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt) | ||
}; | ||
} | ||
@@ -51,2 +67,10 @@ /** Factory method to convert from Plain JS Objects. | ||
/** | ||
* A unique identifier for each Entity | ||
* | ||
* @param [value] POJO of the entity or subset used | ||
* @param [parent] When normalizing, the object which included the entity | ||
* @param [key] When normalizing, the key where this entity was found | ||
*/ | ||
/** Do any transformations when first receiving input */ | ||
@@ -201,2 +225,7 @@ static process(input, parent, key) { | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["isImmutable","denormalizeImmutable","Entity","EntitySchema","EmptyBase","useIncoming","existingMeta","incomingMeta","existing","incoming","fetchedAt","mergeWithStore","merge","process","input","parent","key","env","NODE_ENV","automaticValidation","Array","isArray","errorMessage","name","JSON","stringify","slice","error","Error","status","console","warn","validate","processedEntity","keysOfRecord","Set","Object","keys","defaults","keysOfProps","found","missing","unexpected","keyOfProps","has","push","keyOfRecord","includes","size","tooManyUnexpected","Math","max","length","foundNothing","min","extra","reason","denormalize","unvisit","undefined","toJS","setLocal","denormEntity","deleted","schema","fromJS","toObject","entityCopy","forEach","nextInput","value","deletedItem","set","entity","superFrom","props","prototype","pk","call"],"sources":["../../src/schemas/Entity.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n\nimport { isImmutable, denormalizeImmutable } from './ImmutableUtils.js';\nimport type { UnvisitFunction } from '../interface.js';\nimport { AbstractInstanceType } from '../normal.js';\nimport { Entity as EntitySchema } from '../schema.js';\n\nconst EmptyBase = class {} as any as abstract new (...args: any[]) => {\n  pk(parent?: any, key?: string): string | undefined;\n};\n\n/**\n * Represents data that should be deduped by specifying a primary key.\n * @see https://resthooks.io/docs/api/Entity\n */\nexport default abstract class Entity extends EntitySchema(EmptyBase) {\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  abstract pk(parent?: any, key?: string): string | undefined;\n\n  /** Control how automatic schema validation is handled\n   *\n   * `undefined`: Defaults - throw error in worst offense\n   * 'warn': only ever warn\n   * 'silent': Don't bother with processing at all\n   *\n   * Note: this only applies to non-nested members.\n   */\n  protected declare static automaticValidation?: 'warn' | 'silent';\n\n  /** Return true to merge incoming data; false keeps existing entity\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n   */\n  static useIncoming(\n    existingMeta: { date: number; fetchedAt: number },\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ) {\n    return existingMeta.fetchedAt <= incomingMeta.fetchedAt;\n  }\n\n  /** Run when an existing entity is found in the store */\n  static mergeWithStore(\n    existingMeta:\n      | {\n          date: number;\n          fetchedAt: number;\n        }\n      | undefined,\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ) {\n    const useIncoming =\n      // we may have in store but not in meta; so this existance check is still important\n      !existingMeta ||\n      this.useIncoming(existingMeta, incomingMeta, existing, incoming);\n\n    if (useIncoming) {\n      // distinct types are not mergeable, so just replace\n      if (typeof incoming !== typeof existing) {\n        return incoming;\n      } else {\n        return this.merge(existing, incoming);\n      }\n    } else {\n      return existing;\n    }\n  }\n\n  /** Factory method to convert from Plain JS Objects.\n   *\n   * @param [props] Plain Object of properties to assign.\n   */\n  declare static fromJS: <T extends typeof Entity>(\n    this: T,\n    // TODO: this should only accept members that are not functions\n    props?: Partial<AbstractInstanceType<T>>,\n  ) => AbstractInstanceType<T>;\n\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [value] POJO of the entity or subset used\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  declare static pk: <T extends typeof Entity>(\n    this: T,\n    value: Partial<AbstractInstanceType<T>>,\n    parent?: any,\n    key?: string,\n  ) => string | undefined;\n\n  /** Do any transformations when first receiving input */\n  static process(input: any, parent: any, key: string | undefined): any {\n    /* istanbul ignore else */\n    if (\n      process.env.NODE_ENV !== 'production' &&\n      this.automaticValidation !== 'silent'\n    ) {\n      if (Array.isArray(input)) {\n        const errorMessage = `Attempted to initialize ${\n          this.name\n        } with an array, but named members were expected\n\nThis is likely due to a malformed response.\nTry inspecting the network response or fetch() return value.\nOr use debugging tools: https://resthooks.io/docs/guides/debugging\nLearn more about schemas: https://resthooks.io/docs/api/schema\nIf this is a mistake, you can disable this check by setting static automaticValidation = 'silent'\n\nFirst three members: ${JSON.stringify(input.slice(0, 3), null, 2)}`;\n        if (this.automaticValidation !== 'warn') {\n          const error = new Error(errorMessage);\n          (error as any).status = 400;\n          throw error;\n        }\n        console.warn(errorMessage);\n      }\n    }\n\n    return super.process(input, parent, key);\n  }\n\n  static validate(processedEntity: any): string | undefined {\n    /* istanbul ignore else */\n    if (\n      process.env.NODE_ENV !== 'production' &&\n      this.automaticValidation !== 'silent'\n    ) {\n      const keysOfRecord = new Set(Object.keys(this.defaults));\n      const keysOfProps = Object.keys(processedEntity);\n      const [found, missing, unexpected] = [[], [], []] as [\n        string[],\n        string[],\n        string[],\n      ];\n      for (const keyOfProps of keysOfProps) {\n        if (keysOfRecord.has(keyOfProps)) {\n          found.push(keyOfProps);\n        } else {\n          unexpected.push(keyOfProps);\n        }\n      }\n      for (const keyOfRecord of keysOfRecord) {\n        if (!found.includes(keyOfRecord)) {\n          missing.push(keyOfRecord);\n        }\n      }\n\n      // only bother with this if they used *any* defaults\n      if (keysOfRecord.size) {\n        const tooManyUnexpected =\n          // unexpected compared to members in response\n          Math.max(keysOfProps.length / 2, 1) <= unexpected.length &&\n          // unexpected compared to what we specified\n          keysOfRecord.size > Math.max(unexpected.length, 2) &&\n          // as we find more and more be more easily assured it is correct\n          found.length ** 1.5 / 2 <= unexpected.length;\n        const foundNothing = found.length < Math.min(1, keysOfRecord.size / 2);\n        // if we find nothing (we expect at least one member for a pk)\n        // or we find too many unexpected members\n        if (tooManyUnexpected || foundNothing) {\n          let extra = '';\n          let reason = 'substantially different than expected keys';\n          if (foundNothing) {\n            extra += `\\n    Missing: ${missing}`;\n            reason = 'no matching keys found';\n          }\n          if (tooManyUnexpected) {\n            extra += `\\n    Unexpected keys: ${unexpected}`;\n            reason = 'a large number of unexpected keys found';\n          }\n          const errorMessage = `Attempted to initialize ${\n            this.name\n          } with ${reason}\n\n  This is likely due to a malformed response.\n  Try inspecting the network response or fetch() return value.\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about schemas: https://resthooks.io/docs/api/schema\n  If this is a mistake, you can disable this check by setting static automaticValidation = 'silent'\n\n  Expected keys:\n    Found: ${found}${extra}\n  Value (processed): ${JSON.stringify(processedEntity, null, 2)}`;\n          if (\n            (found.length >= 4 && tooManyUnexpected) ||\n            this.automaticValidation === 'warn'\n          ) {\n            console.warn(errorMessage);\n          } else {\n            return errorMessage;\n          }\n        }\n      }\n    }\n    return super.validate(processedEntity);\n  }\n\n  static denormalize<T extends typeof Entity>(\n    this: T,\n    input: any,\n    unvisit: UnvisitFunction,\n  ): [denormalized: AbstractInstanceType<T>, found: boolean, suspend: boolean] {\n    // TODO: remove codecov ignore once denormalize is modified to expect this\n    /* istanbul ignore if */\n    if (typeof input === 'symbol') {\n      return [undefined, true, true] as any;\n    }\n    // TODO(breaking): Remove fromJS and setLocal call once old versions are no longer supported\n    if (isImmutable(input)) {\n      if (this.validate((input as any).toJS()))\n        return [undefined as any, false, true];\n      // Need to set this first so that if it is referenced further within the\n      // denormalization the reference will already exist.\n      unvisit.setLocal?.(input);\n      const [denormEntity, found, deleted] = denormalizeImmutable(\n        this.schema,\n        input,\n        unvisit,\n      );\n      return [this.fromJS(denormEntity.toObject()) as any, true, deleted];\n    }\n    let entityCopy: any;\n    // new path\n    if (input instanceof this) {\n      entityCopy = input;\n      // TODO(breaking): Remove fromJS and setLocal call once old versions are no longer supported\n    } else {\n      if (this.validate(input)) {\n        return [undefined as any, false, true];\n      }\n      entityCopy = this.fromJS(input);\n      // Need to set this first so that if it is referenced further within the\n      // denormalization the reference will already exist.\n      unvisit.setLocal?.(entityCopy);\n    }\n\n    let deleted = false;\n\n    // note: iteration order must be stable\n    Object.keys(this.schema).forEach(key => {\n      const schema = this.schema[key];\n      const nextInput = (input as any)[key];\n      const [value, , deletedItem] = unvisit(nextInput, schema);\n\n      if (deletedItem && !!this.defaults[key]) {\n        deleted = true;\n      }\n      if ((input as any)[key] !== value) {\n        // we're cheating because we know it is implemented\n        (this as any).set(entityCopy, key, value);\n      }\n    });\n\n    return [entityCopy, true, deleted];\n  }\n\n  /** Used by denormalize to set nested members */\n  protected static set?(entity: any, key: string, value: any) {\n    entity[key] = value;\n  }\n}\n\nif (process.env.NODE_ENV !== 'production') {\n  /* istanbul ignore else */\n  const superFrom = Entity.fromJS;\n  // for those not using TypeScript this is a good catch to ensure they are defining\n  // the abstract members\n  Entity.fromJS = function fromJS<T extends typeof Entity>(\n    this: T,\n    props?: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T> {\n    if ((this as any).prototype.pk === Entity.prototype.pk)\n      throw new Error('cannot construct on abstract types');\n    return superFrom.call(this, props) as any;\n  };\n}\n"],"mappings":"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"} | ||
// we're avoiding this on the type | ||
Entity.expiresAt = function (meta, input) { | ||
return meta.expiresAt; | ||
}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["isImmutable","denormalizeImmutable","Entity","EntitySchema","EmptyBase","useIncoming","existingMeta","incomingMeta","existing","incoming","fetchedAt","mergeWithStore","merge","mergeMetaWithStore","expiresAt","Math","max","date","process","input","parent","key","env","NODE_ENV","automaticValidation","Array","isArray","errorMessage","name","JSON","stringify","slice","error","Error","status","console","warn","validate","processedEntity","keysOfRecord","Set","Object","keys","defaults","keysOfProps","found","missing","unexpected","keyOfProps","has","push","keyOfRecord","includes","size","tooManyUnexpected","length","foundNothing","min","extra","reason","denormalize","unvisit","undefined","toJS","setLocal","denormEntity","deleted","schema","fromJS","toObject","entityCopy","forEach","nextInput","value","deletedItem","set","entity","superFrom","props","prototype","pk","call","meta"],"sources":["../../src/schemas/Entity.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\n\nimport { isImmutable, denormalizeImmutable } from './ImmutableUtils.js';\nimport type { UnvisitFunction } from '../interface.js';\nimport { AbstractInstanceType } from '../normal.js';\nimport { Entity as EntitySchema } from '../schema.js';\n\nconst EmptyBase = class {} as any as abstract new (...args: any[]) => {\n  pk(parent?: any, key?: string, args?: readonly any[]): string | undefined;\n};\n\n/**\n * Represents data that should be deduped by specifying a primary key.\n * @see https://resthooks.io/docs/api/Entity\n */\nexport default abstract class Entity extends EntitySchema(EmptyBase) {\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  abstract pk(\n    parent?: any,\n    key?: string,\n    args?: readonly any[],\n  ): string | undefined;\n\n  /** Control how automatic schema validation is handled\n   *\n   * `undefined`: Defaults - throw error in worst offense\n   * 'warn': only ever warn\n   * 'silent': Don't bother with processing at all\n   *\n   * Note: this only applies to non-nested members.\n   */\n  protected declare static automaticValidation?: 'warn' | 'silent';\n\n  /** Return true to merge incoming data; false keeps existing entity\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n   */\n  static useIncoming(\n    existingMeta: { date: number; fetchedAt: number },\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ) {\n    return existingMeta.fetchedAt <= incomingMeta.fetchedAt;\n  }\n\n  /** Run when an existing entity is found in the store */\n  static mergeWithStore(\n    existingMeta:\n      | {\n          date: number;\n          fetchedAt: number;\n        }\n      | undefined,\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ) {\n    const useIncoming =\n      // we may have in store but not in meta; so this existance check is still important\n      !existingMeta ||\n      this.useIncoming(existingMeta, incomingMeta, existing, incoming);\n\n    if (useIncoming) {\n      // distinct types are not mergeable, so just replace\n      if (typeof incoming !== typeof existing) {\n        return incoming;\n      } else {\n        return this.merge(existing, incoming);\n      }\n    } else {\n      return existing;\n    }\n  }\n\n  static mergeMetaWithStore(\n    existingMeta: {\n      expiresAt: number;\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: { expiresAt: number; date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ) {\n    return {\n      expiresAt: Math.max(\n        (this as any).expiresAt(incomingMeta, incoming),\n        existingMeta.expiresAt,\n      ),\n      date: Math.max(incomingMeta.date, existingMeta.date),\n      fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt),\n    };\n  }\n\n  /** Factory method to convert from Plain JS Objects.\n   *\n   * @param [props] Plain Object of properties to assign.\n   */\n  declare static fromJS: <T extends typeof Entity>(\n    this: T,\n    // TODO: this should only accept members that are not functions\n    props?: Partial<AbstractInstanceType<T>>,\n  ) => AbstractInstanceType<T>;\n\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [value] POJO of the entity or subset used\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  declare static pk: <T extends typeof Entity>(\n    this: T,\n    value: Partial<AbstractInstanceType<T>>,\n    parent?: any,\n    key?: string,\n    args?: any[],\n  ) => string | undefined;\n\n  /** Do any transformations when first receiving input */\n  static process(input: any, parent: any, key: string | undefined): any {\n    /* istanbul ignore else */\n    if (\n      process.env.NODE_ENV !== 'production' &&\n      this.automaticValidation !== 'silent'\n    ) {\n      if (Array.isArray(input)) {\n        const errorMessage = `Attempted to initialize ${\n          this.name\n        } with an array, but named members were expected\n\nThis is likely due to a malformed response.\nTry inspecting the network response or fetch() return value.\nOr use debugging tools: https://resthooks.io/docs/guides/debugging\nLearn more about schemas: https://resthooks.io/docs/api/schema\nIf this is a mistake, you can disable this check by setting static automaticValidation = 'silent'\n\nFirst three members: ${JSON.stringify(input.slice(0, 3), null, 2)}`;\n        if (this.automaticValidation !== 'warn') {\n          const error = new Error(errorMessage);\n          (error as any).status = 400;\n          throw error;\n        }\n        console.warn(errorMessage);\n      }\n    }\n\n    return super.process(input, parent, key);\n  }\n\n  static validate(processedEntity: any): string | undefined {\n    /* istanbul ignore else */\n    if (\n      process.env.NODE_ENV !== 'production' &&\n      this.automaticValidation !== 'silent'\n    ) {\n      const keysOfRecord = new Set(Object.keys(this.defaults));\n      const keysOfProps = Object.keys(processedEntity);\n      const [found, missing, unexpected] = [[], [], []] as [\n        string[],\n        string[],\n        string[],\n      ];\n      for (const keyOfProps of keysOfProps) {\n        if (keysOfRecord.has(keyOfProps)) {\n          found.push(keyOfProps);\n        } else {\n          unexpected.push(keyOfProps);\n        }\n      }\n      for (const keyOfRecord of keysOfRecord) {\n        if (!found.includes(keyOfRecord)) {\n          missing.push(keyOfRecord);\n        }\n      }\n\n      // only bother with this if they used *any* defaults\n      if (keysOfRecord.size) {\n        const tooManyUnexpected =\n          // unexpected compared to members in response\n          Math.max(keysOfProps.length / 2, 1) <= unexpected.length &&\n          // unexpected compared to what we specified\n          keysOfRecord.size > Math.max(unexpected.length, 2) &&\n          // as we find more and more be more easily assured it is correct\n          found.length ** 1.5 / 2 <= unexpected.length;\n        const foundNothing = found.length < Math.min(1, keysOfRecord.size / 2);\n        // if we find nothing (we expect at least one member for a pk)\n        // or we find too many unexpected members\n        if (tooManyUnexpected || foundNothing) {\n          let extra = '';\n          let reason = 'substantially different than expected keys';\n          if (foundNothing) {\n            extra += `\\n    Missing: ${missing}`;\n            reason = 'no matching keys found';\n          }\n          if (tooManyUnexpected) {\n            extra += `\\n    Unexpected keys: ${unexpected}`;\n            reason = 'a large number of unexpected keys found';\n          }\n          const errorMessage = `Attempted to initialize ${\n            this.name\n          } with ${reason}\n\n  This is likely due to a malformed response.\n  Try inspecting the network response or fetch() return value.\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about schemas: https://resthooks.io/docs/api/schema\n  If this is a mistake, you can disable this check by setting static automaticValidation = 'silent'\n\n  Expected keys:\n    Found: ${found}${extra}\n  Value (processed): ${JSON.stringify(processedEntity, null, 2)}`;\n          if (\n            (found.length >= 4 && tooManyUnexpected) ||\n            this.automaticValidation === 'warn'\n          ) {\n            console.warn(errorMessage);\n          } else {\n            return errorMessage;\n          }\n        }\n      }\n    }\n    return super.validate(processedEntity);\n  }\n\n  static denormalize<T extends typeof Entity>(\n    this: T,\n    input: any,\n    unvisit: UnvisitFunction,\n  ): [denormalized: AbstractInstanceType<T>, found: boolean, suspend: boolean] {\n    // TODO: remove codecov ignore once denormalize is modified to expect this\n    /* istanbul ignore if */\n    if (typeof input === 'symbol') {\n      return [undefined, true, true] as any;\n    }\n    // TODO(breaking): Remove fromJS and setLocal call once old versions are no longer supported\n    if (isImmutable(input)) {\n      if (this.validate((input as any).toJS()))\n        return [undefined as any, false, true];\n      // Need to set this first so that if it is referenced further within the\n      // denormalization the reference will already exist.\n      unvisit.setLocal?.(input);\n      const [denormEntity, found, deleted] = denormalizeImmutable(\n        this.schema,\n        input,\n        unvisit,\n      );\n      return [this.fromJS(denormEntity.toObject()) as any, true, deleted];\n    }\n    let entityCopy: any;\n    // new path\n    if (input instanceof this) {\n      entityCopy = input;\n      // TODO(breaking): Remove fromJS and setLocal call once old versions are no longer supported\n    } else {\n      if (this.validate(input)) {\n        return [undefined as any, false, true];\n      }\n      entityCopy = this.fromJS(input);\n      // Need to set this first so that if it is referenced further within the\n      // denormalization the reference will already exist.\n      unvisit.setLocal?.(entityCopy);\n    }\n\n    let deleted = false;\n\n    // note: iteration order must be stable\n    Object.keys(this.schema).forEach(key => {\n      const schema = this.schema[key];\n      const nextInput = (input as any)[key];\n      const [value, , deletedItem] = unvisit(nextInput, schema);\n\n      if (deletedItem && !!this.defaults[key]) {\n        deleted = true;\n      }\n      if ((input as any)[key] !== value) {\n        // we're cheating because we know it is implemented\n        (this as any).set(entityCopy, key, value);\n      }\n    });\n\n    return [entityCopy, true, deleted];\n  }\n\n  /** Used by denormalize to set nested members */\n  protected static set?(entity: any, key: string, value: any) {\n    entity[key] = value;\n  }\n}\n\nif (process.env.NODE_ENV !== 'production') {\n  /* istanbul ignore else */\n  const superFrom = Entity.fromJS;\n  // for those not using TypeScript this is a good catch to ensure they are defining\n  // the abstract members\n  Entity.fromJS = function fromJS<T extends typeof Entity>(\n    this: T,\n    props?: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T> {\n    if ((this as any).prototype.pk === Entity.prototype.pk)\n      throw new Error('cannot construct on abstract types');\n    return superFrom.call(this, props) as any;\n  };\n}\n\n// we're avoiding this on the type\n(Entity as any).expiresAt = function (\n  meta: { expiresAt: number; date: number; fetchedAt: number },\n  input: any,\n): number {\n  return meta.expiresAt;\n};\n"],"mappings":"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"} |
@@ -8,3 +8,3 @@ import type { Schema, NormalizedIndex, UnvisitFunction } from '../interface.js'; | ||
export type PKClass = abstract new (...args: any[]) => { | ||
pk(parent?: any, key?: string): string | undefined; | ||
pk(parent?: any, key?: string, args?: readonly any[]): string | undefined; | ||
}; | ||
@@ -33,9 +33,18 @@ type ValidSchemas<TInstance> = { | ||
}; | ||
/** Defines nested entities */ | ||
/** Defines nested entities | ||
* | ||
* @see https://resthooks.io/rest/api/Entity#schema | ||
*/ | ||
schema: { | ||
[k: string]: Schema; | ||
}; | ||
/** Returns the globally unique identifier for the static Entity */ | ||
/** Returns the globally unique identifier for the static Entity | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#key | ||
*/ | ||
key: string; | ||
/** Defines indexes to enable lookup by */ | ||
/** Defines indexes to enable lookup by | ||
* | ||
* @see https://resthooks.io/rest/api/Entity#indexes | ||
*/ | ||
indexes?: readonly string[] | undefined; | ||
@@ -45,2 +54,3 @@ /** | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#pk | ||
* @param [value] POJO of the entity or subset used | ||
@@ -50,3 +60,3 @@ * @param [parent] When normalizing, the object which included the entity | ||
*/ | ||
pk<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, value: Partial<AbstractInstanceType<T>>, parent?: any, key?: string): string | undefined; | ||
pk<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, value: Partial<AbstractInstanceType<T>>, parent?: any, key?: string, args?: any[]): string | undefined; | ||
/** Return true to merge incoming data; false keeps existing entity | ||
@@ -75,5 +85,11 @@ * | ||
}, existing: any, incoming: any): boolean; | ||
/** Creates new instance copying over defined values of arguments */ | ||
/** Creates new instance copying over defined values of arguments | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#merge | ||
*/ | ||
merge(existing: any, incoming: any): any; | ||
/** Run when an existing entity is found in the store */ | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeWithStore | ||
*/ | ||
mergeWithStore(existingMeta: { | ||
@@ -86,2 +102,19 @@ date: number; | ||
}, existing: any, incoming: any): any; | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeMetaWithStore | ||
*/ | ||
mergeMetaWithStore(existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}; | ||
/** Factory method to convert from Plain JS Objects. | ||
@@ -92,18 +125,26 @@ * | ||
fromJS<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, props?: Partial<AbstractInstanceType<T>>): AbstractInstanceType<T>; | ||
/** Factory method to convert from Plain JS Objects. | ||
/** Called when denormalizing an entity to create an instance when 'valid' | ||
* | ||
* @param [props] Plain Object of properties to assign. | ||
* @see https://resthooks.io/docs/api/Entity#createIfValid | ||
*/ | ||
createIfValid<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, props: Partial<AbstractInstanceType<T>>): AbstractInstanceType<T> | undefined; | ||
/** Do any transformations when first receiving input */ | ||
/** Do any transformations when first receiving input | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#process | ||
*/ | ||
process(input: any, parent: any, key: string | undefined): any; | ||
normalize(input: any, parent: any, key: string | undefined, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): any; | ||
/** Do any transformations when first receiving input | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#validate | ||
*/ | ||
validate(processedEntity: any): string | undefined; | ||
/** Attempts to infer results | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#infer | ||
*/ | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: any): any; | ||
expiresAt(meta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, input: any): number; | ||
denormalize<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, input: any, unvisit: UnvisitFunction): [denormalized: AbstractInstanceType<T>, found: boolean, suspend: boolean]; | ||
denormalizeOnly<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, input: any, unvisit: (input: any, schema: any) => any): AbstractInstanceType<T>; | ||
/** All instance defaults set */ | ||
@@ -119,5 +160,5 @@ readonly defaults: any; | ||
*/ | ||
pk(parent?: any, key?: string): string | undefined; | ||
pk(parent?: any, key?: string, args?: readonly any[]): string | undefined; | ||
} | ||
export {}; | ||
//# sourceMappingURL=EntitySchema.d.ts.map |
@@ -27,2 +27,14 @@ /* eslint-disable @typescript-eslint/explicit-module-boundary-types */ | ||
* | ||
* @param [parent] When normalizing, the object which included the entity | ||
* @param [key] When normalizing, the key where this entity was found | ||
*/ | ||
/** Returns the globally unique identifier for the static Entity */ | ||
// default implementation in class static block at bottom of definition | ||
/** Defines indexes to enable lookup by */ | ||
/** | ||
* A unique identifier for each Entity | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#pk | ||
* @param [value] POJO of the entity or subset used | ||
@@ -32,4 +44,4 @@ * @param [parent] When normalizing, the object which included the entity | ||
*/ | ||
static pk(value, parent, key) { | ||
return this.prototype.pk.call(value, parent, key); | ||
static pk(value, parent, key, args) { | ||
return this.prototype.pk.call(value, parent, key, args); | ||
} | ||
@@ -54,3 +66,6 @@ | ||
/** Creates new instance copying over defined values of arguments */ | ||
/** Creates new instance copying over defined values of arguments | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#merge | ||
*/ | ||
static merge(existing, incoming) { | ||
@@ -63,3 +78,6 @@ return { | ||
/** Run when an existing entity is found in the store */ | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeWithStore | ||
*/ | ||
static mergeWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
@@ -79,2 +97,10 @@ const useIncoming = this.useIncoming(existingMeta, incomingMeta, existing, incoming); | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeMetaWithStore | ||
*/ | ||
static mergeMetaWithStore(existingMeta, incomingMeta, existing, incoming) { | ||
return this.shouldReorder(existingMeta, incomingMeta, existing, incoming) ? existingMeta : incomingMeta; | ||
} | ||
/** Factory method to convert from Plain JS Objects. | ||
@@ -95,5 +121,6 @@ * | ||
/** Factory method to convert from Plain JS Objects. | ||
/** Called when denormalizing an entity to create an instance when 'valid' | ||
* | ||
* @param [props] Plain Object of properties to assign. | ||
* @see https://resthooks.io/docs/api/schema.Entity#createIfValid | ||
*/ | ||
@@ -109,3 +136,6 @@ static createIfValid( | ||
/** Do any transformations when first receiving input */ | ||
/** Do any transformations when first receiving input | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#process | ||
*/ | ||
static process(input, parent, key) { | ||
@@ -116,5 +146,5 @@ return { | ||
} | ||
static normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
static normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
const processedEntity = this.process(input, parent, key); | ||
const id = this.pk(processedEntity, parent, key); | ||
const id = this.pk(processedEntity, parent, key, args); | ||
if (id === undefined || id === '') { | ||
@@ -135,4 +165,4 @@ if (process.env.NODE_ENV !== 'production') { | ||
} else { | ||
// these make the keys get deleted | ||
return undefined; | ||
// these make the keys get deleted; return undefined | ||
return; | ||
} | ||
@@ -156,3 +186,3 @@ } | ||
const schema = this.schema[key]; | ||
processedEntity[key] = visit(processedEntity[key], processedEntity, key, schema, addEntity, visitedEntities); | ||
processedEntity[key] = visit(processedEntity[key], processedEntity, key, schema, addEntity, visitedEntities, storeEntities, args); | ||
} | ||
@@ -182,22 +212,10 @@ }); | ||
} | ||
static infer(args, indexes, recurse) { | ||
static infer(args, indexes, recurse, entities) { | ||
var _entities$this$key; | ||
if (!args[0]) return undefined; | ||
if (['string', 'number'].includes(typeof args[0])) { | ||
return `${args[0]}`; | ||
} | ||
const id = this.pk(args[0], undefined, ''); | ||
// Was able to infer the entity's primary key from params | ||
if (id !== undefined && id !== '') return id; | ||
// now attempt lookup in indexes | ||
const indexName = indexFromParams(args[0], this.indexes); | ||
if (indexName && indexes[this.key]) { | ||
// 'as Record<string, any>': indexName can only be found if params is a string key'd object | ||
const id = indexes[this.key][indexName][args[0][indexName]]; | ||
return id; | ||
} | ||
const id = inferId(this, args, indexes); | ||
// no entity arg is back-compatibility | ||
if (!entities || (_entities$this$key = entities[this.key]) != null && _entities$this$key[id]) return id; | ||
return undefined; | ||
} | ||
static expiresAt(meta, input) { | ||
return meta.expiresAt; | ||
} | ||
static denormalize(input, unvisit) { | ||
@@ -222,3 +240,24 @@ // TODO: remove codecov ignore once denormalize is modified to expect this | ||
} | ||
static denormalizeOnly(input, args, unvisit) { | ||
if (typeof input === 'symbol') { | ||
return input; | ||
} | ||
// note: iteration order must be stable | ||
for (const key of Object.keys(this.schema)) { | ||
const schema = this.schema[key]; | ||
const value = unvisit(input[key], schema); | ||
if (typeof value === 'symbol') { | ||
// if default is not 'fasly', then this is required, so propagate INVALID symbol | ||
if (this.defaults[key]) { | ||
return value; | ||
} | ||
input[key] = undefined; | ||
} else { | ||
input[key] = value; | ||
} | ||
} | ||
return input; | ||
} | ||
/** All instance defaults set */ | ||
@@ -318,2 +357,17 @@ static get defaults() { | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["EntitySchema","Base","options","EntityMixin","toString","key","toJSON","name","schema","pk","value","parent","prototype","call","useIncoming","existingMeta","incomingMeta","existing","incoming","shouldReorder","fetchedAt","merge","mergeWithStore","fromJS","props","instance","Object","assign","createIfValid","validate","undefined","process","input","normalize","visit","addEntity","visitedEntities","processedEntity","id","env","NODE_ENV","error","Error","JSON","stringify","status","entityType","some","entity","errorMessage","throwValidationError","push","keys","forEach","hasOwn","defaults","infer","args","indexes","recurse","includes","indexName","indexFromParams","expiresAt","meta","denormalize","unvisit","deleted","nextInput","deletedItem","defineProperty","writable","configurable","__defaults","staticProps","set","enumerable","CLASSNAMEMANGLING","get","console","params","find","index"],"sources":["../../src/schemas/EntitySchema.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\nimport type { Schema, NormalizedIndex, UnvisitFunction } from '../interface.js';\nimport { AbstractInstanceType } from '../normal.js';\n\nexport type Constructor = abstract new (...args: any[]) => {};\nexport type IDClass = abstract new (...args: any[]) => {\n  id: string | number | undefined;\n};\nexport type PKClass = abstract new (...args: any[]) => {\n  pk(parent?: any, key?: string): string | undefined;\n};\n\n// TODO: Figure out what Schema must be for each key\ntype ValidSchemas<TInstance> = { [k in keyof TInstance]?: Schema };\n\nexport type EntityOptions<TInstance extends {}> = {\n  readonly schema?: ValidSchemas<TInstance>;\n  readonly pk?:\n    | ((value: TInstance, parent?: any, key?: string) => string | undefined)\n    | keyof TInstance;\n  readonly key?: string;\n} & {\n  readonly [K in Extract<\n    keyof IEntityClass,\n    | 'process'\n    | 'merge'\n    | 'expiresAt'\n    | 'createIfValid'\n    | 'mergeWithStore'\n    | 'validate'\n    | 'shouldReorder'\n    | 'useIncoming'\n  >]?: IEntityClass<abstract new (...args: any[]) => TInstance>[K];\n};\n\nexport interface RequiredPKOptions<TInstance extends {}>\n  extends EntityOptions<TInstance> {\n  readonly pk:\n    | ((value: TInstance, parent?: any, key?: string) => string | undefined)\n    | keyof TInstance;\n}\n\nexport default function EntitySchema<TBase extends Constructor>(\n  Base: TBase,\n  options: EntityOptions<InstanceType<TBase>> = {},\n) {\n  /**\n   * Represents data that should be deduped by specifying a primary key.\n   * @see https://resthooks.io/docs/api/Entity\n   */\n  abstract class EntityMixin extends Base {\n    static toString() {\n      return this.key;\n    }\n\n    static toJSON() {\n      return {\n        name: this.name,\n        schema: this.schema,\n        key: this.key,\n      };\n    }\n\n    /** Defines nested entities */\n    declare static schema: { [k: string]: Schema };\n\n    /**\n     * A unique identifier for each Entity\n     *\n     * @param [parent] When normalizing, the object which included the entity\n     * @param [key] When normalizing, the key where this entity was found\n     */\n    abstract pk(parent?: any, key?: string): string | undefined;\n\n    /** Returns the globally unique identifier for the static Entity */\n    declare static key: string;\n    // default implementation in class static block at bottom of definition\n\n    /** Defines indexes to enable lookup by */\n    declare static indexes?: readonly string[];\n\n    /**\n     * A unique identifier for each Entity\n     *\n     * @param [value] POJO of the entity or subset used\n     * @param [parent] When normalizing, the object which included the entity\n     * @param [key] When normalizing, the key where this entity was found\n     */\n    static pk<T extends typeof EntityMixin>(\n      this: T,\n      value: Partial<AbstractInstanceType<T>>,\n      parent?: any,\n      key?: string,\n    ): string | undefined {\n      return this.prototype.pk.call(value, parent, key);\n    }\n\n    /** Return true to merge incoming data; false keeps existing entity\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n     */\n    static useIncoming(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return true;\n    }\n\n    /** Determines the order of incoming entity vs entity already in store\\\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#shouldReorder\n     * @returns true if incoming entity should be first argument of merge()\n     */\n    static shouldReorder(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return incomingMeta.fetchedAt < existingMeta.fetchedAt;\n    }\n\n    /** Creates new instance copying over defined values of arguments */\n    static merge(existing: any, incoming: any) {\n      return {\n        ...existing,\n        ...incoming,\n      };\n    }\n\n    /** Run when an existing entity is found in the store */\n    static mergeWithStore(\n      existingMeta: {\n        date: number;\n        fetchedAt: number;\n      },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      const useIncoming = this.useIncoming(\n        existingMeta,\n        incomingMeta,\n        existing,\n        incoming,\n      );\n\n      if (useIncoming) {\n        // distinct types are not mergeable (like delete symbol), so just replace\n        if (typeof incoming !== typeof existing) {\n          return incoming;\n        } else {\n          return this.shouldReorder(\n            existingMeta,\n            incomingMeta,\n            existing,\n            incoming,\n          )\n            ? this.merge(incoming, existing)\n            : this.merge(existing, incoming);\n        }\n      } else {\n        return existing;\n      }\n    }\n\n    /** Factory method to convert from Plain JS Objects.\n     *\n     * @param [props] Plain Object of properties to assign.\n     */\n    static fromJS<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>> = {},\n    ): AbstractInstanceType<T> {\n      // we type guarded abstract case above, so ok to force typescript to allow constructor call\n      const instance = new (this as any)(props) as AbstractInstanceType<T>;\n      // we can't rely on constructors and override the defaults provided as property assignments\n      // all occur after the constructor\n      Object.assign(instance, props);\n      return instance;\n    }\n\n    /** Factory method to convert from Plain JS Objects.\n     *\n     * @param [props] Plain Object of properties to assign.\n     */\n    static createIfValid<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>>,\n    ): AbstractInstanceType<T> | undefined {\n      if (this.validate(props)) {\n        return undefined as any;\n      }\n      return this.fromJS(props);\n    }\n\n    /** Do any transformations when first receiving input */\n    static process(input: any, parent: any, key: string | undefined): any {\n      return { ...input };\n    }\n\n    static normalize(\n      input: any,\n      parent: any,\n      key: string | undefined,\n      visit: (...args: any) => any,\n      addEntity: (...args: any) => any,\n      visitedEntities: Record<string, any>,\n    ): any {\n      const processedEntity = this.process(input, parent, key);\n      const id = this.pk(processedEntity, parent, key);\n      if (id === undefined || id === '') {\n        if (process.env.NODE_ENV !== 'production') {\n          const error = new Error(\n            `Missing usable primary key when normalizing response.\n\n  This is likely due to a malformed response.\n  Try inspecting the network response or fetch() return value.\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about primary keys: https://resthooks.io/rest/api/Entity#pk\n\n  Entity: ${this.name}\n  Value (processed): ${\n    processedEntity && JSON.stringify(processedEntity, null, 2)\n  }\n  `,\n          );\n          (error as any).status = 400;\n          throw error;\n        } else {\n          // these make the keys get deleted\n          return undefined;\n        }\n      }\n      const entityType = this.key;\n\n      if (!(entityType in visitedEntities)) {\n        visitedEntities[entityType] = {};\n      }\n      if (!(id in visitedEntities[entityType])) {\n        visitedEntities[entityType][id] = [];\n      }\n      if (\n        visitedEntities[entityType][id].some((entity: any) => entity === input)\n      ) {\n        return id;\n      }\n      const errorMessage = this.validate(processedEntity);\n      throwValidationError(errorMessage);\n\n      visitedEntities[entityType][id].push(input);\n\n      Object.keys(this.schema).forEach(key => {\n        if (Object.hasOwn(processedEntity, key)) {\n          const schema = this.schema[key];\n          processedEntity[key] = visit(\n            processedEntity[key],\n            processedEntity,\n            key,\n            schema,\n            addEntity,\n            visitedEntities,\n          );\n        }\n      });\n\n      addEntity(this, processedEntity, id);\n      return id;\n    }\n\n    static validate(processedEntity: any): string | undefined {\n      if (process.env.NODE_ENV !== 'production') {\n        for (const key of Object.keys(this.schema)) {\n          if (!Object.hasOwn(processedEntity, key)) {\n            if (!Object.hasOwn(this.defaults, key)) {\n              return `Schema key is missing in Entity\n\n  Be sure all schema members are also part of the entity\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about nesting schemas: https://resthooks.io/rest/guides/relational-data\n\n  Entity keys: ${Object.keys(this.defaults)}\n  Schema key(missing): ${key}\n  `;\n            }\n          }\n        }\n      }\n    }\n\n    static infer(\n      args: readonly any[],\n      indexes: NormalizedIndex,\n      recurse: any,\n    ): any {\n      if (!args[0]) return undefined;\n      if (['string', 'number'].includes(typeof args[0])) {\n        return `${args[0]}`;\n      }\n      const id = this.pk(args[0], undefined, '');\n      // Was able to infer the entity's primary key from params\n      if (id !== undefined && id !== '') return id;\n      // now attempt lookup in indexes\n      const indexName = indexFromParams(args[0], this.indexes);\n      if (indexName && indexes[this.key]) {\n        // 'as Record<string, any>': indexName can only be found if params is a string key'd object\n        const id =\n          indexes[this.key][indexName][\n            (args[0] as Record<string, any>)[indexName]\n          ];\n        return id;\n      }\n      return undefined;\n    }\n\n    static expiresAt(\n      meta: { expiresAt: number; date: number; fetchedAt: number },\n      input: any,\n    ): number {\n      return meta.expiresAt;\n    }\n\n    static denormalize<T extends typeof EntityMixin>(\n      this: T,\n      input: any,\n      unvisit: UnvisitFunction,\n    ): [\n      denormalized: AbstractInstanceType<T>,\n      found: boolean,\n      suspend: boolean,\n    ] {\n      // TODO: remove codecov ignore once denormalize is modified to expect this\n      /* istanbul ignore if */\n      if (typeof input === 'symbol') {\n        return [undefined, true, true] as any;\n      }\n\n      let deleted = false;\n      // note: iteration order must be stable\n      Object.keys(this.schema).forEach(key => {\n        const schema = this.schema[key];\n        const nextInput = (input as any)[key];\n        const [value, , deletedItem] = unvisit(nextInput, schema);\n\n        if (deletedItem && !!this.defaults[key]) {\n          deleted = true;\n        }\n        input[key] = value;\n      });\n\n      return [input, true, deleted];\n    }\n\n    /** All instance defaults set */\n    static get defaults() {\n      // we use hasOwn because we don't want to use a parents' defaults\n      if (!Object.hasOwn(this, '__defaults'))\n        Object.defineProperty(this, '__defaults', {\n          value: new (this as any)(),\n          writable: true,\n          configurable: true,\n        });\n      return (this as any).__defaults;\n    }\n  }\n\n  const { pk, schema, key, ...staticProps } = options;\n  // remaining options\n  Object.assign(EntityMixin, staticProps);\n\n  if ('schema' in options) {\n    EntityMixin.schema = options.schema as any;\n  } else if (!(Base as any).schema) {\n    EntityMixin.schema = {};\n  }\n  if ('pk' in options) {\n    if (typeof options.pk === 'function') {\n      EntityMixin.prototype.pk = function (parent?: any, key?: string) {\n        return (options.pk as any)(this, parent, key);\n      };\n    } else {\n      EntityMixin.prototype.pk = function () {\n        return this[options.pk];\n      };\n    }\n    // default to 'id' field if the base class doesn't have a pk\n  } else if (typeof Base.prototype.pk !== 'function') {\n    EntityMixin.prototype.pk = function () {\n      return this.id;\n    };\n  }\n  if ('key' in options) {\n    Object.defineProperty(EntityMixin, 'key', {\n      value: options.key,\n      configurable: true,\n      writable: true,\n    });\n  } else if (!('key' in Base)) {\n    // this allows assignment in strict-mode\n    // eslint-disable-next-line no-inner-declarations\n    function set(this: any, value: string) {\n      Object.defineProperty(this, 'key', {\n        value,\n        writable: true,\n        enumerable: true,\n      });\n    }\n    const CLASSNAMEMANGLING = EntityMixin.name !== 'EntityMixin';\n    const get =\n      /* istanbul ignore if */\n      CLASSNAMEMANGLING\n        ? /* istanbul ignore next */ function (this: {\n            name: string;\n            key: string;\n          }): string {\n            const name = this.name === 'EntityMixin' ? Base.name : this.name;\n            console.error('Rest Hooks Error: https://resthooks.io/errors/dklj');\n            Object.defineProperty(this, 'key', {\n              get() {\n                return name;\n              },\n              set,\n            });\n            return this.key;\n          }\n        : function (this: { name: string }): string {\n            const name = this.name === 'EntityMixin' ? Base.name : this.name;\n            /* istanbul ignore next */\n            if (\n              process.env.NODE_ENV !== 'production' &&\n              (name === '' || name === 'EntityMixin' || name === '_temp')\n            )\n              throw new Error(\n                'Entity classes without a name must define `static key`\\nSee: https://resthooks.io/rest/api/Entity#key',\n              );\n            return name;\n          };\n\n    Object.defineProperty(EntityMixin, 'key', {\n      get,\n      set,\n    });\n  }\n\n  return EntityMixin as any;\n}\n\nfunction indexFromParams<I extends string>(\n  params: Readonly<object>,\n  indexes?: Readonly<I[]>,\n) {\n  if (!indexes) return undefined;\n  return indexes.find(index => Object.hasOwn(params, index));\n}\n\n// part of the reason for pulling this out is that all functions that throw are deoptimized\nfunction throwValidationError(errorMessage: string | undefined) {\n  if (errorMessage) {\n    const error = new Error(errorMessage);\n    (error as any).status = 400;\n    throw error;\n  }\n}\n\nexport interface IEntityClass<TBase extends Constructor = any> {\n  toJSON(): {\n    name: string;\n    schema: {\n      [k: string]: Schema;\n    };\n    key: string;\n  };\n  /** Defines nested entities */\n  schema: {\n    [k: string]: Schema;\n  };\n  /** Returns the globally unique identifier for the static Entity */\n  key: string;\n  /** Defines indexes to enable lookup by */\n  indexes?: readonly string[] | undefined;\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [value] POJO of the entity or subset used\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  pk<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    value: Partial<AbstractInstanceType<T>>,\n    parent?: any,\n    key?: string,\n  ): string | undefined;\n  /** Return true to merge incoming data; false keeps existing entity\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n   */\n  useIncoming(\n    existingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    existing: any,\n    incoming: any,\n  ): boolean;\n  /** Determines the order of incoming entity vs entity already in store\\\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#shouldReorder\n   * @returns true if incoming entity should be first argument of merge()\n   */\n  shouldReorder(\n    existingMeta: { date: number; fetchedAt: number },\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ): boolean;\n  /** Creates new instance copying over defined values of arguments */\n  merge(existing: any, incoming: any): any;\n  /** Run when an existing entity is found in the store */\n  mergeWithStore(\n    existingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    existing: any,\n    incoming: any,\n  ): any;\n  /** Factory method to convert from Plain JS Objects.\n   *\n   * @param [props] Plain Object of properties to assign.\n   */\n  fromJS<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    props?: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T>;\n  /** Factory method to convert from Plain JS Objects.\n   *\n   * @param [props] Plain Object of properties to assign.\n   */\n  createIfValid<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    props: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T> | undefined;\n  /** Do any transformations when first receiving input */\n  process(input: any, parent: any, key: string | undefined): any;\n  normalize(\n    input: any,\n    parent: any,\n    key: string | undefined,\n    visit: (...args: any) => any,\n    addEntity: (...args: any) => any,\n    visitedEntities: Record<string, any>,\n  ): any;\n  validate(processedEntity: any): string | undefined;\n  infer(args: readonly any[], indexes: NormalizedIndex, recurse: any): any;\n  expiresAt(\n    meta: {\n      expiresAt: number;\n      date: number;\n      fetchedAt: number;\n    },\n    input: any,\n  ): number;\n  denormalize<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    input: any,\n    unvisit: UnvisitFunction,\n  ): [denormalized: AbstractInstanceType<T>, found: boolean, suspend: boolean];\n  /** All instance defaults set */\n  readonly defaults: any;\n  //set(entity: any, key: string, value: any): void;\n}\nexport interface IEntityInstance {\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  pk(parent?: any, key?: string): string | undefined;\n}\n"],"mappings":"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"} | ||
function inferId(schema, args, indexes) { | ||
if (['string', 'number'].includes(typeof args[0])) { | ||
return `${args[0]}`; | ||
} | ||
const id = schema.pk(args[0], undefined, '', args); | ||
// Was able to infer the entity's primary key from params | ||
if (id !== undefined && id !== '') return id; | ||
// now attempt lookup in indexes | ||
const indexName = indexFromParams(args[0], schema.indexes); | ||
if (indexName && indexes[schema.key]) { | ||
// 'as Record<string, any>': indexName can only be found if params is a string key'd object | ||
const id = indexes[schema.key][indexName][args[0][indexName]]; | ||
return id; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["EntitySchema","Base","options","EntityMixin","toString","key","toJSON","name","schema","pk","value","parent","args","prototype","call","useIncoming","existingMeta","incomingMeta","existing","incoming","shouldReorder","fetchedAt","merge","mergeWithStore","mergeMetaWithStore","fromJS","props","instance","Object","assign","createIfValid","validate","undefined","process","input","normalize","visit","addEntity","visitedEntities","storeEntities","processedEntity","id","env","NODE_ENV","error","Error","JSON","stringify","status","entityType","some","entity","errorMessage","throwValidationError","push","keys","forEach","hasOwn","defaults","infer","indexes","recurse","entities","_entities$this$key","inferId","denormalize","unvisit","deleted","nextInput","deletedItem","denormalizeOnly","defineProperty","writable","configurable","__defaults","staticProps","set","enumerable","CLASSNAMEMANGLING","get","console","indexFromParams","params","find","index","includes","indexName"],"sources":["../../src/schemas/EntitySchema.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/explicit-module-boundary-types */\nimport type { Schema, NormalizedIndex, UnvisitFunction } from '../interface.js';\nimport { AbstractInstanceType } from '../normal.js';\n\nexport type Constructor = abstract new (...args: any[]) => {};\nexport type IDClass = abstract new (...args: any[]) => {\n  id: string | number | undefined;\n};\nexport type PKClass = abstract new (...args: any[]) => {\n  pk(parent?: any, key?: string, args?: readonly any[]): string | undefined;\n};\n\n// TODO: Figure out what Schema must be for each key\ntype ValidSchemas<TInstance> = { [k in keyof TInstance]?: Schema };\n\nexport type EntityOptions<TInstance extends {}> = {\n  readonly schema?: ValidSchemas<TInstance>;\n  readonly pk?:\n    | ((value: TInstance, parent?: any, key?: string) => string | undefined)\n    | keyof TInstance;\n  readonly key?: string;\n} & {\n  readonly [K in Extract<\n    keyof IEntityClass,\n    | 'process'\n    | 'merge'\n    | 'expiresAt'\n    | 'createIfValid'\n    | 'mergeWithStore'\n    | 'validate'\n    | 'shouldReorder'\n    | 'useIncoming'\n  >]?: IEntityClass<abstract new (...args: any[]) => TInstance>[K];\n};\n\nexport interface RequiredPKOptions<TInstance extends {}>\n  extends EntityOptions<TInstance> {\n  readonly pk:\n    | ((value: TInstance, parent?: any, key?: string) => string | undefined)\n    | keyof TInstance;\n}\n\nexport default function EntitySchema<TBase extends Constructor>(\n  Base: TBase,\n  options: EntityOptions<InstanceType<TBase>> = {},\n) {\n  /**\n   * Represents data that should be deduped by specifying a primary key.\n   * @see https://resthooks.io/docs/api/Entity\n   */\n  abstract class EntityMixin extends Base {\n    static toString() {\n      return this.key;\n    }\n\n    static toJSON() {\n      return {\n        name: this.name,\n        schema: this.schema,\n        key: this.key,\n      };\n    }\n\n    /** Defines nested entities */\n    declare static schema: { [k: string]: Schema };\n\n    /**\n     * A unique identifier for each Entity\n     *\n     * @param [parent] When normalizing, the object which included the entity\n     * @param [key] When normalizing, the key where this entity was found\n     */\n    abstract pk(\n      parent?: any,\n      key?: string,\n      args?: readonly any[],\n    ): string | undefined;\n\n    /** Returns the globally unique identifier for the static Entity */\n    declare static key: string;\n    // default implementation in class static block at bottom of definition\n\n    /** Defines indexes to enable lookup by */\n    declare static indexes?: readonly string[];\n\n    /**\n     * A unique identifier for each Entity\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#pk\n     * @param [value] POJO of the entity or subset used\n     * @param [parent] When normalizing, the object which included the entity\n     * @param [key] When normalizing, the key where this entity was found\n     */\n    static pk<T extends typeof EntityMixin>(\n      this: T,\n      value: Partial<AbstractInstanceType<T>>,\n      parent?: any,\n      key?: string,\n      args?: readonly any[],\n    ): string | undefined {\n      return this.prototype.pk.call(value, parent, key, args);\n    }\n\n    /** Return true to merge incoming data; false keeps existing entity\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n     */\n    static useIncoming(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return true;\n    }\n\n    /** Determines the order of incoming entity vs entity already in store\\\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#shouldReorder\n     * @returns true if incoming entity should be first argument of merge()\n     */\n    static shouldReorder(\n      existingMeta: { date: number; fetchedAt: number },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return incomingMeta.fetchedAt < existingMeta.fetchedAt;\n    }\n\n    /** Creates new instance copying over defined values of arguments\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#merge\n     */\n    static merge(existing: any, incoming: any) {\n      return {\n        ...existing,\n        ...incoming,\n      };\n    }\n\n    /** Run when an existing entity is found in the store\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#mergeWithStore\n     */\n    static mergeWithStore(\n      existingMeta: {\n        date: number;\n        fetchedAt: number;\n      },\n      incomingMeta: { date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      const useIncoming = this.useIncoming(\n        existingMeta,\n        incomingMeta,\n        existing,\n        incoming,\n      );\n\n      if (useIncoming) {\n        // distinct types are not mergeable (like delete symbol), so just replace\n        if (typeof incoming !== typeof existing) {\n          return incoming;\n        } else {\n          return this.shouldReorder(\n            existingMeta,\n            incomingMeta,\n            existing,\n            incoming,\n          )\n            ? this.merge(incoming, existing)\n            : this.merge(existing, incoming);\n        }\n      } else {\n        return existing;\n      }\n    }\n\n    /** Run when an existing entity is found in the store\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#mergeMetaWithStore\n     */\n    static mergeMetaWithStore(\n      existingMeta: {\n        expiresAt: number;\n        date: number;\n        fetchedAt: number;\n      },\n      incomingMeta: { expiresAt: number; date: number; fetchedAt: number },\n      existing: any,\n      incoming: any,\n    ) {\n      return this.shouldReorder(existingMeta, incomingMeta, existing, incoming)\n        ? existingMeta\n        : incomingMeta;\n    }\n\n    /** Factory method to convert from Plain JS Objects.\n     *\n     * @param [props] Plain Object of properties to assign.\n     */\n    static fromJS<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>> = {},\n    ): AbstractInstanceType<T> {\n      // we type guarded abstract case above, so ok to force typescript to allow constructor call\n      const instance = new (this as any)(props) as AbstractInstanceType<T>;\n      // we can't rely on constructors and override the defaults provided as property assignments\n      // all occur after the constructor\n      Object.assign(instance, props);\n      return instance;\n    }\n\n    /** Called when denormalizing an entity to create an instance when 'valid'\n     *\n     * @param [props] Plain Object of properties to assign.\n     * @see https://resthooks.io/docs/api/schema.Entity#createIfValid\n     */\n    static createIfValid<T extends typeof EntityMixin>(\n      this: T,\n      // TODO: this should only accept members that are not functions\n      props: Partial<AbstractInstanceType<T>>,\n    ): AbstractInstanceType<T> | undefined {\n      if (this.validate(props)) {\n        return undefined as any;\n      }\n      return this.fromJS(props);\n    }\n\n    /** Do any transformations when first receiving input\n     *\n     * @see https://resthooks.io/docs/api/schema.Entity#process\n     */\n    static process(input: any, parent: any, key: string | undefined): any {\n      return { ...input };\n    }\n\n    static normalize(\n      input: any,\n      parent: any,\n      key: string | undefined,\n      visit: (...args: any) => any,\n      addEntity: (...args: any) => any,\n      visitedEntities: Record<string, any>,\n      storeEntities: any,\n      args?: readonly any[],\n    ): any {\n      const processedEntity = this.process(input, parent, key);\n      const id = this.pk(processedEntity, parent, key, args);\n      if (id === undefined || id === '') {\n        if (process.env.NODE_ENV !== 'production') {\n          const error = new Error(\n            `Missing usable primary key when normalizing response.\n\n  This is likely due to a malformed response.\n  Try inspecting the network response or fetch() return value.\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about primary keys: https://resthooks.io/rest/api/Entity#pk\n\n  Entity: ${this.name}\n  Value (processed): ${\n    processedEntity && JSON.stringify(processedEntity, null, 2)\n  }\n  `,\n          );\n          (error as any).status = 400;\n          throw error;\n        } else {\n          // these make the keys get deleted; return undefined\n          return;\n        }\n      }\n      const entityType = this.key;\n\n      if (!(entityType in visitedEntities)) {\n        visitedEntities[entityType] = {};\n      }\n      if (!(id in visitedEntities[entityType])) {\n        visitedEntities[entityType][id] = [];\n      }\n      if (\n        visitedEntities[entityType][id].some((entity: any) => entity === input)\n      ) {\n        return id;\n      }\n      const errorMessage = this.validate(processedEntity);\n      throwValidationError(errorMessage);\n\n      visitedEntities[entityType][id].push(input);\n\n      Object.keys(this.schema).forEach(key => {\n        if (Object.hasOwn(processedEntity, key)) {\n          const schema = this.schema[key];\n          processedEntity[key] = visit(\n            processedEntity[key],\n            processedEntity,\n            key,\n            schema,\n            addEntity,\n            visitedEntities,\n            storeEntities,\n            args,\n          );\n        }\n      });\n\n      addEntity(this, processedEntity, id);\n      return id;\n    }\n\n    static validate(processedEntity: any): string | undefined {\n      if (process.env.NODE_ENV !== 'production') {\n        for (const key of Object.keys(this.schema)) {\n          if (!Object.hasOwn(processedEntity, key)) {\n            if (!Object.hasOwn(this.defaults, key)) {\n              return `Schema key is missing in Entity\n\n  Be sure all schema members are also part of the entity\n  Or use debugging tools: https://resthooks.io/docs/guides/debugging\n  Learn more about nesting schemas: https://resthooks.io/rest/guides/relational-data\n\n  Entity keys: ${Object.keys(this.defaults)}\n  Schema key(missing): ${key}\n  `;\n            }\n          }\n        }\n      }\n    }\n\n    static infer(\n      args: readonly any[],\n      indexes: NormalizedIndex,\n      recurse: any,\n      entities: any,\n    ): any {\n      if (!args[0]) return undefined;\n      const id = inferId(this, args, indexes);\n      // no entity arg is back-compatibility\n      if (!entities || entities[this.key]?.[id]) return id;\n      return undefined;\n    }\n\n    static denormalize<T extends typeof EntityMixin>(\n      this: T,\n      input: any,\n      unvisit: UnvisitFunction,\n    ): [\n      denormalized: AbstractInstanceType<T>,\n      found: boolean,\n      suspend: boolean,\n    ] {\n      // TODO: remove codecov ignore once denormalize is modified to expect this\n      /* istanbul ignore if */\n      if (typeof input === 'symbol') {\n        return [undefined, true, true] as any;\n      }\n\n      let deleted = false;\n      // note: iteration order must be stable\n      Object.keys(this.schema).forEach(key => {\n        const schema = this.schema[key];\n        const nextInput = (input as any)[key];\n        const [value, , deletedItem] = unvisit(nextInput, schema);\n\n        if (deletedItem && !!this.defaults[key]) {\n          deleted = true;\n        }\n        input[key] = value;\n      });\n\n      return [input, true, deleted];\n    }\n\n    static denormalizeOnly<T extends typeof EntityMixin>(\n      this: T,\n      input: any,\n      args: any[],\n      unvisit: (input: any, schema: any) => any,\n    ): AbstractInstanceType<T> {\n      if (typeof input === 'symbol') {\n        return input as any;\n      }\n\n      // note: iteration order must be stable\n      for (const key of Object.keys(this.schema)) {\n        const schema = this.schema[key];\n        const value = unvisit(input[key], schema);\n\n        if (typeof value === 'symbol') {\n          // if default is not 'fasly', then this is required, so propagate INVALID symbol\n          if (this.defaults[key]) {\n            return value as any;\n          }\n          input[key] = undefined;\n        } else {\n          input[key] = value;\n        }\n      }\n      return input;\n    }\n\n    /** All instance defaults set */\n    static get defaults() {\n      // we use hasOwn because we don't want to use a parents' defaults\n      if (!Object.hasOwn(this, '__defaults'))\n        Object.defineProperty(this, '__defaults', {\n          value: new (this as any)(),\n          writable: true,\n          configurable: true,\n        });\n      return (this as any).__defaults;\n    }\n  }\n\n  const { pk, schema, key, ...staticProps } = options;\n  // remaining options\n  Object.assign(EntityMixin, staticProps);\n\n  if ('schema' in options) {\n    EntityMixin.schema = options.schema as any;\n  } else if (!(Base as any).schema) {\n    EntityMixin.schema = {};\n  }\n  if ('pk' in options) {\n    if (typeof options.pk === 'function') {\n      EntityMixin.prototype.pk = function (parent?: any, key?: string) {\n        return (options.pk as any)(this, parent, key);\n      };\n    } else {\n      EntityMixin.prototype.pk = function () {\n        return this[options.pk];\n      };\n    }\n    // default to 'id' field if the base class doesn't have a pk\n  } else if (typeof Base.prototype.pk !== 'function') {\n    EntityMixin.prototype.pk = function () {\n      return this.id;\n    };\n  }\n  if ('key' in options) {\n    Object.defineProperty(EntityMixin, 'key', {\n      value: options.key,\n      configurable: true,\n      writable: true,\n    });\n  } else if (!('key' in Base)) {\n    // this allows assignment in strict-mode\n    // eslint-disable-next-line no-inner-declarations\n    function set(this: any, value: string) {\n      Object.defineProperty(this, 'key', {\n        value,\n        writable: true,\n        enumerable: true,\n      });\n    }\n    const CLASSNAMEMANGLING = EntityMixin.name !== 'EntityMixin';\n    const get =\n      /* istanbul ignore if */\n      CLASSNAMEMANGLING\n        ? /* istanbul ignore next */ function (this: {\n            name: string;\n            key: string;\n          }): string {\n            const name = this.name === 'EntityMixin' ? Base.name : this.name;\n            console.error('Rest Hooks Error: https://resthooks.io/errors/dklj');\n            Object.defineProperty(this, 'key', {\n              get() {\n                return name;\n              },\n              set,\n            });\n            return this.key;\n          }\n        : function (this: { name: string }): string {\n            const name = this.name === 'EntityMixin' ? Base.name : this.name;\n            /* istanbul ignore next */\n            if (\n              process.env.NODE_ENV !== 'production' &&\n              (name === '' || name === 'EntityMixin' || name === '_temp')\n            )\n              throw new Error(\n                'Entity classes without a name must define `static key`\\nSee: https://resthooks.io/rest/api/Entity#key',\n              );\n            return name;\n          };\n\n    Object.defineProperty(EntityMixin, 'key', {\n      get,\n      set,\n    });\n  }\n\n  return EntityMixin as any;\n}\n\nfunction indexFromParams<I extends string>(\n  params: Readonly<object>,\n  indexes?: Readonly<I[]>,\n) {\n  if (!indexes) return undefined;\n  return indexes.find(index => Object.hasOwn(params, index));\n}\n\n// part of the reason for pulling this out is that all functions that throw are deoptimized\nfunction throwValidationError(errorMessage: string | undefined) {\n  if (errorMessage) {\n    const error = new Error(errorMessage);\n    (error as any).status = 400;\n    throw error;\n  }\n}\n\nexport interface IEntityClass<TBase extends Constructor = any> {\n  toJSON(): {\n    name: string;\n    schema: {\n      [k: string]: Schema;\n    };\n    key: string;\n  };\n  /** Defines nested entities\n   *\n   * @see https://resthooks.io/rest/api/Entity#schema\n   */\n  schema: {\n    [k: string]: Schema;\n  };\n  /** Returns the globally unique identifier for the static Entity\n   *\n   * @see https://resthooks.io/docs/api/Entity#key\n   */\n  key: string;\n  /** Defines indexes to enable lookup by\n   *\n   * @see https://resthooks.io/rest/api/Entity#indexes\n   */\n  indexes?: readonly string[] | undefined;\n  /**\n   * A unique identifier for each Entity\n   *\n   * @see https://resthooks.io/docs/api/Entity#pk\n   * @param [value] POJO of the entity or subset used\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  pk<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    value: Partial<AbstractInstanceType<T>>,\n    parent?: any,\n    key?: string,\n    args?: any[],\n  ): string | undefined;\n  /** Return true to merge incoming data; false keeps existing entity\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#useIncoming\n   */\n  useIncoming(\n    existingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    existing: any,\n    incoming: any,\n  ): boolean;\n  /** Determines the order of incoming entity vs entity already in store\\\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#shouldReorder\n   * @returns true if incoming entity should be first argument of merge()\n   */\n  shouldReorder(\n    existingMeta: { date: number; fetchedAt: number },\n    incomingMeta: { date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ): boolean;\n  /** Creates new instance copying over defined values of arguments\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#merge\n   */\n  merge(existing: any, incoming: any): any;\n  /** Run when an existing entity is found in the store\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#mergeWithStore\n   */\n  mergeWithStore(\n    existingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: {\n      date: number;\n      fetchedAt: number;\n    },\n    existing: any,\n    incoming: any,\n  ): any;\n  /** Run when an existing entity is found in the store\n   *\n   * @see https://resthooks.io/docs/api/schema.Entity#mergeMetaWithStore\n   */\n  mergeMetaWithStore(\n    existingMeta: {\n      expiresAt: number;\n      date: number;\n      fetchedAt: number;\n    },\n    incomingMeta: { expiresAt: number; date: number; fetchedAt: number },\n    existing: any,\n    incoming: any,\n  ): {\n    expiresAt: number;\n    date: number;\n    fetchedAt: number;\n  };\n  /** Factory method to convert from Plain JS Objects.\n   *\n   * @param [props] Plain Object of properties to assign.\n   */\n  fromJS<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    props?: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T>;\n  /** Called when denormalizing an entity to create an instance when 'valid'\n   *\n   * @param [props] Plain Object of properties to assign.\n   * @see https://resthooks.io/docs/api/Entity#createIfValid\n   */\n  createIfValid<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    props: Partial<AbstractInstanceType<T>>,\n  ): AbstractInstanceType<T> | undefined;\n  /** Do any transformations when first receiving input\n   *\n   * @see https://resthooks.io/docs/api/Entity#process\n   */\n  process(input: any, parent: any, key: string | undefined): any;\n  normalize(\n    input: any,\n    parent: any,\n    key: string | undefined,\n    visit: (...args: any) => any,\n    addEntity: (...args: any) => any,\n    visitedEntities: Record<string, any>,\n  ): any;\n  /** Do any transformations when first receiving input\n   *\n   * @see https://resthooks.io/docs/api/Entity#validate\n   */\n  validate(processedEntity: any): string | undefined;\n  /** Attempts to infer results\n   *\n   * @see https://resthooks.io/docs/api/Entity#infer\n   */\n\n  infer(args: readonly any[], indexes: NormalizedIndex, recurse: any): any;\n  denormalize<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    input: any,\n    unvisit: UnvisitFunction,\n  ): [denormalized: AbstractInstanceType<T>, found: boolean, suspend: boolean];\n  denormalizeOnly<\n    T extends (abstract new (...args: any[]) => IEntityInstance &\n      InstanceType<TBase>) &\n      IEntityClass &\n      TBase,\n  >(\n    this: T,\n    input: any,\n    unvisit: (input: any, schema: any) => any,\n  ): AbstractInstanceType<T>;\n  /** All instance defaults set */\n  readonly defaults: any;\n  //set(entity: any, key: string, value: any): void;\n}\nexport interface IEntityInstance {\n  /**\n   * A unique identifier for each Entity\n   *\n   * @param [parent] When normalizing, the object which included the entity\n   * @param [key] When normalizing, the key where this entity was found\n   */\n  pk(parent?: any, key?: string, args?: readonly any[]): string | undefined;\n}\n\nfunction inferId(schema: any, args: readonly any[], indexes: NormalizedIndex) {\n  if (['string', 'number'].includes(typeof args[0])) {\n    return `${args[0]}`;\n  }\n  const id = schema.pk(args[0], undefined, '', args);\n  // Was able to infer the entity's primary key from params\n  if (id !== undefined && id !== '') return id;\n  // now attempt lookup in indexes\n  const indexName = indexFromParams(args[0], schema.indexes);\n  if (indexName && indexes[schema.key]) {\n    // 'as Record<string, any>': indexName can only be found if params is a string key'd object\n    const id =\n      indexes[schema.key][indexName][\n        (args[0] as Record<string, any>)[indexName]\n      ];\n    return id;\n  }\n}\n"],"mappings":"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"} |
@@ -26,2 +26,12 @@ /** | ||
export declare function denormalizeImmutable(schema: any, input: any, unvisit: any): [denormalized: any, found: boolean, deleted: boolean]; | ||
/** | ||
* Denormalize an immutable entity. | ||
* | ||
* @param {Schema} schema | ||
* @param {Immutable.Map|Immutable.Record} input | ||
* @param {function} unvisit | ||
* @param {function} getDenormalizedEntity | ||
* @return {Immutable.Map|Immutable.Record} | ||
*/ | ||
export declare function denormalizeOnlyImmutable(schema: any, input: any, unvisit: (input: any, schema: any) => any): any; | ||
//# sourceMappingURL=ImmutableUtils.d.ts.map |
@@ -50,2 +50,31 @@ /** | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpc0ltbXV0YWJsZSIsIm9iamVjdCIsImhhc093blByb3BlcnR5IiwiT2JqZWN0IiwiY2FsbCIsIl9tYXAiLCJkZW5vcm1hbGl6ZUltbXV0YWJsZSIsInNjaGVtYSIsImlucHV0IiwidW52aXNpdCIsImZvdW5kIiwiZGVsZXRlZCIsImtleXMiLCJyZWR1Y2UiLCJrZXkiLCJzdHJpbmdLZXkiLCJpdGVtIiwiZm91bmRJdGVtIiwiZGVsZXRlZEl0ZW0iLCJnZXQiLCJoYXMiLCJzZXQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9JbW11dGFibGVVdGlscy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEhlbHBlcnMgdG8gZW5hYmxlIEltbXV0YWJsZSBjb21wYXRpYmlsaXR5ICp3aXRob3V0KiBicmluZ2luZyBpblxuICogdGhlICdpbW11dGFibGUnIHBhY2thZ2UgYXMgYSBkZXBlbmRlbmN5LlxuICovXG5cbi8qKlxuICogQ2hlY2sgaWYgYW4gb2JqZWN0IGlzIGltbXV0YWJsZSBieSBjaGVja2luZyBpZiBpdCBoYXMgYSBrZXkgc3BlY2lmaWNcbiAqIHRvIHRoZSBpbW11dGFibGUgbGlicmFyeS5cbiAqXG4gKiBAcGFyYW0gIHthbnl9IG9iamVjdFxuICogQHJldHVybiB7Ym9vbH1cbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbmV4cG9ydCBmdW5jdGlvbiBpc0ltbXV0YWJsZShvYmplY3Q6IHt9KTogb2JqZWN0IGlzIHtcbiAgZ2V0KGs6IHN0cmluZyk6IGFueTtcbiAgW2s6IHN0cmluZ106IGFueTtcbn0ge1xuICByZXR1cm4gISEoXG4gICAgdHlwZW9mIG9iamVjdC5oYXNPd25Qcm9wZXJ0eSA9PT0gJ2Z1bmN0aW9uJyAmJlxuICAgIChPYmplY3QuaGFzT3duUHJvcGVydHkuY2FsbChvYmplY3QsICdfX293bmVySUQnKSB8fCAvLyBJbW11dGFibGUuTWFwXG4gICAgICAoKG9iamVjdCBhcyBhbnkpLl9tYXAgJiZcbiAgICAgICAgT2JqZWN0Lmhhc093blByb3BlcnR5LmNhbGwoKG9iamVjdCBhcyBhbnkpLl9tYXAsICdfX293bmVySUQnKSkpXG4gICk7IC8vIEltbXV0YWJsZS5SZWNvcmRcbn1cblxuLyoqXG4gKiBEZW5vcm1hbGl6ZSBhbiBpbW11dGFibGUgZW50aXR5LlxuICpcbiAqIEBwYXJhbSAge1NjaGVtYX0gc2NoZW1hXG4gKiBAcGFyYW0gIHtJbW11dGFibGUuTWFwfEltbXV0YWJsZS5SZWNvcmR9IGlucHV0XG4gKiBAcGFyYW0gIHtmdW5jdGlvbn0gdW52aXNpdFxuICogQHBhcmFtICB7ZnVuY3Rpb259IGdldERlbm9ybWFsaXplZEVudGl0eVxuICogQHJldHVybiB7SW1tdXRhYmxlLk1hcHxJbW11dGFibGUuUmVjb3JkfVxuICovXG5leHBvcnQgZnVuY3Rpb24gZGVub3JtYWxpemVJbW11dGFibGUoXG4gIHNjaGVtYTogYW55LFxuICBpbnB1dDogYW55LFxuICB1bnZpc2l0OiBhbnksXG4pOiBbZGVub3JtYWxpemVkOiBhbnksIGZvdW5kOiBib29sZWFuLCBkZWxldGVkOiBib29sZWFuXSB7XG4gIGxldCBmb3VuZCA9IHRydWU7XG4gIGxldCBkZWxldGVkID0gZmFsc2U7XG4gIHJldHVybiBbXG4gICAgT2JqZWN0LmtleXMoc2NoZW1hKS5yZWR1Y2UoKG9iamVjdCwga2V5KSA9PiB7XG4gICAgICAvLyBJbW11dGFibGUgbWFwcyBjYXN0IGtleXMgdG8gc3RyaW5ncyBvbiB3cml0ZSBzbyB3ZSBuZWVkIHRvIGVuc3VyZVxuICAgICAgLy8gd2UncmUgYWNjZXNzaW5nIHRoZW0gdXNpbmcgc3RyaW5nIGtleXMuXG4gICAgICBjb25zdCBzdHJpbmdLZXkgPSBgJHtrZXl9YDtcblxuICAgICAgY29uc3QgW2l0ZW0sIGZvdW5kSXRlbSwgZGVsZXRlZEl0ZW1dID0gdW52aXNpdChcbiAgICAgICAgb2JqZWN0LmdldChzdHJpbmdLZXkpLFxuICAgICAgICBzY2hlbWFbc3RyaW5nS2V5XSxcbiAgICAgICk7XG4gICAgICBpZiAoIWZvdW5kSXRlbSkge1xuICAgICAgICBmb3VuZCA9IGZhbHNlO1xuICAgICAgfVxuICAgICAgaWYgKGRlbGV0ZWRJdGVtKSB7XG4gICAgICAgIGRlbGV0ZWQgPSB0cnVlO1xuICAgICAgfVxuICAgICAgaWYgKG9iamVjdC5oYXMoc3RyaW5nS2V5KSkge1xuICAgICAgICByZXR1cm4gb2JqZWN0LnNldChzdHJpbmdLZXksIGl0ZW0pO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuIG9iamVjdDtcbiAgICAgIH1cbiAgICB9LCBpbnB1dCksXG4gICAgZm91bmQsXG4gICAgZGVsZXRlZCxcbiAgXTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sU0FBU0EsV0FBV0EsQ0FBQ0MsTUFBVSxFQUdwQztFQUNBLE9BQU8sQ0FBQyxFQUNOLE9BQU9BLE1BQU0sQ0FBQ0MsY0FBYyxLQUFLLFVBQVUsS0FDMUNDLE1BQU0sQ0FBQ0QsY0FBYyxDQUFDRSxJQUFJLENBQUNILE1BQU0sRUFBRSxXQUFXLENBQUM7RUFBSTtFQUNoREEsTUFBTSxDQUFTSSxJQUFJLElBQ25CRixNQUFNLENBQUNELGNBQWMsQ0FBQ0UsSUFBSSxDQUFFSCxNQUFNLENBQVNJLElBQUksRUFBRSxXQUFXLENBQUUsQ0FBQyxDQUNwRSxDQUFDLENBQUM7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLFNBQVNDLG9CQUFvQkEsQ0FDbENDLE1BQVcsRUFDWEMsS0FBVSxFQUNWQyxPQUFZLEVBQzJDO0VBQ3ZELElBQUlDLEtBQUssR0FBRyxJQUFJO0VBQ2hCLElBQUlDLE9BQU8sR0FBRyxLQUFLO0VBQ25CLE9BQU8sQ0FDTFIsTUFBTSxDQUFDUyxJQUFJLENBQUNMLE1BQU0sQ0FBQyxDQUFDTSxNQUFNLENBQUMsQ0FBQ1osTUFBTSxFQUFFYSxHQUFHLEtBQUs7SUFDMUM7SUFDQTtJQUNBLE1BQU1DLFNBQVMsR0FBSSxHQUFFRCxHQUFJLEVBQUM7SUFFMUIsTUFBTSxDQUFDRSxJQUFJLEVBQUVDLFNBQVMsRUFBRUMsV0FBVyxDQUFDLEdBQUdULE9BQU8sQ0FDNUNSLE1BQU0sQ0FBQ2tCLEdBQUcsQ0FBQ0osU0FBUyxDQUFDLEVBQ3JCUixNQUFNLENBQUNRLFNBQVMsQ0FBQyxDQUNsQjtJQUNELElBQUksQ0FBQ0UsU0FBUyxFQUFFO01BQ2RQLEtBQUssR0FBRyxLQUFLO0lBQ2Y7SUFDQSxJQUFJUSxXQUFXLEVBQUU7TUFDZlAsT0FBTyxHQUFHLElBQUk7SUFDaEI7SUFDQSxJQUFJVixNQUFNLENBQUNtQixHQUFHLENBQUNMLFNBQVMsQ0FBQyxFQUFFO01BQ3pCLE9BQU9kLE1BQU0sQ0FBQ29CLEdBQUcsQ0FBQ04sU0FBUyxFQUFFQyxJQUFJLENBQUM7SUFDcEMsQ0FBQyxNQUFNO01BQ0wsT0FBT2YsTUFBTTtJQUNmO0VBQ0YsQ0FBQyxFQUFFTyxLQUFLLENBQUMsRUFDVEUsS0FBSyxFQUNMQyxPQUFPLENBQ1I7QUFDSCJ9 | ||
/** | ||
* Denormalize an immutable entity. | ||
* | ||
* @param {Schema} schema | ||
* @param {Immutable.Map|Immutable.Record} input | ||
* @param {function} unvisit | ||
* @param {function} getDenormalizedEntity | ||
* @return {Immutable.Map|Immutable.Record} | ||
*/ | ||
export function denormalizeOnlyImmutable(schema, input, unvisit) { | ||
var _deleted; | ||
let deleted; | ||
const value = Object.keys(schema).reduce((object, key) => { | ||
// Immutable maps cast keys to strings on write so we need to ensure | ||
// we're accessing them using string keys. | ||
const stringKey = `${key}`; | ||
const item = unvisit(object.get(stringKey), schema[stringKey]); | ||
if (typeof item === 'symbol') { | ||
deleted = item; | ||
} | ||
if (object.has(stringKey)) { | ||
return object.set(stringKey, item); | ||
} else { | ||
return object; | ||
} | ||
}, input); | ||
return (_deleted = deleted) != null ? _deleted : value; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpc0ltbXV0YWJsZSIsIm9iamVjdCIsImhhc093blByb3BlcnR5IiwiT2JqZWN0IiwiY2FsbCIsIl9tYXAiLCJkZW5vcm1hbGl6ZUltbXV0YWJsZSIsInNjaGVtYSIsImlucHV0IiwidW52aXNpdCIsImZvdW5kIiwiZGVsZXRlZCIsImtleXMiLCJyZWR1Y2UiLCJrZXkiLCJzdHJpbmdLZXkiLCJpdGVtIiwiZm91bmRJdGVtIiwiZGVsZXRlZEl0ZW0iLCJnZXQiLCJoYXMiLCJzZXQiLCJkZW5vcm1hbGl6ZU9ubHlJbW11dGFibGUiLCJfZGVsZXRlZCIsInZhbHVlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvSW1tdXRhYmxlVXRpbHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBIZWxwZXJzIHRvIGVuYWJsZSBJbW11dGFibGUgY29tcGF0aWJpbGl0eSAqd2l0aG91dCogYnJpbmdpbmcgaW5cbiAqIHRoZSAnaW1tdXRhYmxlJyBwYWNrYWdlIGFzIGEgZGVwZW5kZW5jeS5cbiAqL1xuXG4vKipcbiAqIENoZWNrIGlmIGFuIG9iamVjdCBpcyBpbW11dGFibGUgYnkgY2hlY2tpbmcgaWYgaXQgaGFzIGEga2V5IHNwZWNpZmljXG4gKiB0byB0aGUgaW1tdXRhYmxlIGxpYnJhcnkuXG4gKlxuICogQHBhcmFtICB7YW55fSBvYmplY3RcbiAqIEByZXR1cm4ge2Jvb2x9XG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG5leHBvcnQgZnVuY3Rpb24gaXNJbW11dGFibGUob2JqZWN0OiB7fSk6IG9iamVjdCBpcyB7XG4gIGdldChrOiBzdHJpbmcpOiBhbnk7XG4gIFtrOiBzdHJpbmddOiBhbnk7XG59IHtcbiAgcmV0dXJuICEhKFxuICAgIHR5cGVvZiBvYmplY3QuaGFzT3duUHJvcGVydHkgPT09ICdmdW5jdGlvbicgJiZcbiAgICAoT2JqZWN0Lmhhc093blByb3BlcnR5LmNhbGwob2JqZWN0LCAnX19vd25lcklEJykgfHwgLy8gSW1tdXRhYmxlLk1hcFxuICAgICAgKChvYmplY3QgYXMgYW55KS5fbWFwICYmXG4gICAgICAgIE9iamVjdC5oYXNPd25Qcm9wZXJ0eS5jYWxsKChvYmplY3QgYXMgYW55KS5fbWFwLCAnX19vd25lcklEJykpKVxuICApOyAvLyBJbW11dGFibGUuUmVjb3JkXG59XG5cbi8qKlxuICogRGVub3JtYWxpemUgYW4gaW1tdXRhYmxlIGVudGl0eS5cbiAqXG4gKiBAcGFyYW0gIHtTY2hlbWF9IHNjaGVtYVxuICogQHBhcmFtICB7SW1tdXRhYmxlLk1hcHxJbW11dGFibGUuUmVjb3JkfSBpbnB1dFxuICogQHBhcmFtICB7ZnVuY3Rpb259IHVudmlzaXRcbiAqIEBwYXJhbSAge2Z1bmN0aW9ufSBnZXREZW5vcm1hbGl6ZWRFbnRpdHlcbiAqIEByZXR1cm4ge0ltbXV0YWJsZS5NYXB8SW1tdXRhYmxlLlJlY29yZH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGRlbm9ybWFsaXplSW1tdXRhYmxlKFxuICBzY2hlbWE6IGFueSxcbiAgaW5wdXQ6IGFueSxcbiAgdW52aXNpdDogYW55LFxuKTogW2Rlbm9ybWFsaXplZDogYW55LCBmb3VuZDogYm9vbGVhbiwgZGVsZXRlZDogYm9vbGVhbl0ge1xuICBsZXQgZm91bmQgPSB0cnVlO1xuICBsZXQgZGVsZXRlZCA9IGZhbHNlO1xuICByZXR1cm4gW1xuICAgIE9iamVjdC5rZXlzKHNjaGVtYSkucmVkdWNlKChvYmplY3QsIGtleSkgPT4ge1xuICAgICAgLy8gSW1tdXRhYmxlIG1hcHMgY2FzdCBrZXlzIHRvIHN0cmluZ3Mgb24gd3JpdGUgc28gd2UgbmVlZCB0byBlbnN1cmVcbiAgICAgIC8vIHdlJ3JlIGFjY2Vzc2luZyB0aGVtIHVzaW5nIHN0cmluZyBrZXlzLlxuICAgICAgY29uc3Qgc3RyaW5nS2V5ID0gYCR7a2V5fWA7XG5cbiAgICAgIGNvbnN0IFtpdGVtLCBmb3VuZEl0ZW0sIGRlbGV0ZWRJdGVtXSA9IHVudmlzaXQoXG4gICAgICAgIG9iamVjdC5nZXQoc3RyaW5nS2V5KSxcbiAgICAgICAgc2NoZW1hW3N0cmluZ0tleV0sXG4gICAgICApO1xuICAgICAgaWYgKCFmb3VuZEl0ZW0pIHtcbiAgICAgICAgZm91bmQgPSBmYWxzZTtcbiAgICAgIH1cbiAgICAgIGlmIChkZWxldGVkSXRlbSkge1xuICAgICAgICBkZWxldGVkID0gdHJ1ZTtcbiAgICAgIH1cbiAgICAgIGlmIChvYmplY3QuaGFzKHN0cmluZ0tleSkpIHtcbiAgICAgICAgcmV0dXJuIG9iamVjdC5zZXQoc3RyaW5nS2V5LCBpdGVtKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBvYmplY3Q7XG4gICAgICB9XG4gICAgfSwgaW5wdXQpLFxuICAgIGZvdW5kLFxuICAgIGRlbGV0ZWQsXG4gIF07XG59XG5cbi8qKlxuICogRGVub3JtYWxpemUgYW4gaW1tdXRhYmxlIGVudGl0eS5cbiAqXG4gKiBAcGFyYW0gIHtTY2hlbWF9IHNjaGVtYVxuICogQHBhcmFtICB7SW1tdXRhYmxlLk1hcHxJbW11dGFibGUuUmVjb3JkfSBpbnB1dFxuICogQHBhcmFtICB7ZnVuY3Rpb259IHVudmlzaXRcbiAqIEBwYXJhbSAge2Z1bmN0aW9ufSBnZXREZW5vcm1hbGl6ZWRFbnRpdHlcbiAqIEByZXR1cm4ge0ltbXV0YWJsZS5NYXB8SW1tdXRhYmxlLlJlY29yZH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGRlbm9ybWFsaXplT25seUltbXV0YWJsZShcbiAgc2NoZW1hOiBhbnksXG4gIGlucHV0OiBhbnksXG4gIHVudmlzaXQ6IChpbnB1dDogYW55LCBzY2hlbWE6IGFueSkgPT4gYW55LFxuKTogYW55IHtcbiAgbGV0IGRlbGV0ZWQ7XG4gIGNvbnN0IHZhbHVlID0gT2JqZWN0LmtleXMoc2NoZW1hKS5yZWR1Y2UoKG9iamVjdCwga2V5KSA9PiB7XG4gICAgLy8gSW1tdXRhYmxlIG1hcHMgY2FzdCBrZXlzIHRvIHN0cmluZ3Mgb24gd3JpdGUgc28gd2UgbmVlZCB0byBlbnN1cmVcbiAgICAvLyB3ZSdyZSBhY2Nlc3NpbmcgdGhlbSB1c2luZyBzdHJpbmcga2V5cy5cbiAgICBjb25zdCBzdHJpbmdLZXkgPSBgJHtrZXl9YDtcblxuICAgIGNvbnN0IGl0ZW0gPSB1bnZpc2l0KG9iamVjdC5nZXQoc3RyaW5nS2V5KSwgc2NoZW1hW3N0cmluZ0tleV0pO1xuICAgIGlmICh0eXBlb2YgaXRlbSA9PT0gJ3N5bWJvbCcpIHtcbiAgICAgIGRlbGV0ZWQgPSBpdGVtO1xuICAgIH1cbiAgICBpZiAob2JqZWN0LmhhcyhzdHJpbmdLZXkpKSB7XG4gICAgICByZXR1cm4gb2JqZWN0LnNldChzdHJpbmdLZXksIGl0ZW0pO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gb2JqZWN0O1xuICAgIH1cbiAgfSwgaW5wdXQpO1xuICByZXR1cm4gZGVsZXRlZCA/PyB2YWx1ZTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7O0FBRUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE9BQU8sU0FBU0EsV0FBV0EsQ0FBQ0MsTUFBVSxFQUdwQztFQUNBLE9BQU8sQ0FBQyxFQUNOLE9BQU9BLE1BQU0sQ0FBQ0MsY0FBYyxLQUFLLFVBQVUsS0FDMUNDLE1BQU0sQ0FBQ0QsY0FBYyxDQUFDRSxJQUFJLENBQUNILE1BQU0sRUFBRSxXQUFXLENBQUM7RUFBSTtFQUNoREEsTUFBTSxDQUFTSSxJQUFJLElBQ25CRixNQUFNLENBQUNELGNBQWMsQ0FBQ0UsSUFBSSxDQUFFSCxNQUFNLENBQVNJLElBQUksRUFBRSxXQUFXLENBQUUsQ0FBQyxDQUNwRSxDQUFDLENBQUM7QUFDTDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLFNBQVNDLG9CQUFvQkEsQ0FDbENDLE1BQVcsRUFDWEMsS0FBVSxFQUNWQyxPQUFZLEVBQzJDO0VBQ3ZELElBQUlDLEtBQUssR0FBRyxJQUFJO0VBQ2hCLElBQUlDLE9BQU8sR0FBRyxLQUFLO0VBQ25CLE9BQU8sQ0FDTFIsTUFBTSxDQUFDUyxJQUFJLENBQUNMLE1BQU0sQ0FBQyxDQUFDTSxNQUFNLENBQUMsQ0FBQ1osTUFBTSxFQUFFYSxHQUFHLEtBQUs7SUFDMUM7SUFDQTtJQUNBLE1BQU1DLFNBQVMsR0FBSSxHQUFFRCxHQUFJLEVBQUM7SUFFMUIsTUFBTSxDQUFDRSxJQUFJLEVBQUVDLFNBQVMsRUFBRUMsV0FBVyxDQUFDLEdBQUdULE9BQU8sQ0FDNUNSLE1BQU0sQ0FBQ2tCLEdBQUcsQ0FBQ0osU0FBUyxDQUFDLEVBQ3JCUixNQUFNLENBQUNRLFNBQVMsQ0FBQyxDQUNsQjtJQUNELElBQUksQ0FBQ0UsU0FBUyxFQUFFO01BQ2RQLEtBQUssR0FBRyxLQUFLO0lBQ2Y7SUFDQSxJQUFJUSxXQUFXLEVBQUU7TUFDZlAsT0FBTyxHQUFHLElBQUk7SUFDaEI7SUFDQSxJQUFJVixNQUFNLENBQUNtQixHQUFHLENBQUNMLFNBQVMsQ0FBQyxFQUFFO01BQ3pCLE9BQU9kLE1BQU0sQ0FBQ29CLEdBQUcsQ0FBQ04sU0FBUyxFQUFFQyxJQUFJLENBQUM7SUFDcEMsQ0FBQyxNQUFNO01BQ0wsT0FBT2YsTUFBTTtJQUNmO0VBQ0YsQ0FBQyxFQUFFTyxLQUFLLENBQUMsRUFDVEUsS0FBSyxFQUNMQyxPQUFPLENBQ1I7QUFDSDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxPQUFPLFNBQVNXLHdCQUF3QkEsQ0FDdENmLE1BQVcsRUFDWEMsS0FBVSxFQUNWQyxPQUF5QyxFQUNwQztFQUFBLElBQUFjLFFBQUE7RUFDTCxJQUFJWixPQUFPO0VBQ1gsTUFBTWEsS0FBSyxHQUFHckIsTUFBTSxDQUFDUyxJQUFJLENBQUNMLE1BQU0sQ0FBQyxDQUFDTSxNQUFNLENBQUMsQ0FBQ1osTUFBTSxFQUFFYSxHQUFHLEtBQUs7SUFDeEQ7SUFDQTtJQUNBLE1BQU1DLFNBQVMsR0FBSSxHQUFFRCxHQUFJLEVBQUM7SUFFMUIsTUFBTUUsSUFBSSxHQUFHUCxPQUFPLENBQUNSLE1BQU0sQ0FBQ2tCLEdBQUcsQ0FBQ0osU0FBUyxDQUFDLEVBQUVSLE1BQU0sQ0FBQ1EsU0FBUyxDQUFDLENBQUM7SUFDOUQsSUFBSSxPQUFPQyxJQUFJLEtBQUssUUFBUSxFQUFFO01BQzVCTCxPQUFPLEdBQUdLLElBQUk7SUFDaEI7SUFDQSxJQUFJZixNQUFNLENBQUNtQixHQUFHLENBQUNMLFNBQVMsQ0FBQyxFQUFFO01BQ3pCLE9BQU9kLE1BQU0sQ0FBQ29CLEdBQUcsQ0FBQ04sU0FBUyxFQUFFQyxJQUFJLENBQUM7SUFDcEMsQ0FBQyxNQUFNO01BQ0wsT0FBT2YsTUFBTTtJQUNmO0VBQ0YsQ0FBQyxFQUFFTyxLQUFLLENBQUM7RUFDVCxRQUFBZSxRQUFBLEdBQU9aLE9BQU8sWUFBQVksUUFBQSxHQUFJQyxLQUFLO0FBQ3pCIn0= |
@@ -1,3 +0,4 @@ | ||
export declare const normalize: (schema: any, input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any) => any; | ||
export declare const normalize: (schema: any, input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]) => any; | ||
export declare const denormalize: (schema: any, input: {}, unvisit: any) => [denormalized: any, found: boolean, deleted: boolean]; | ||
export declare function denormalizeOnly(schema: any, input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
export declare function infer(schema: any, args: readonly any[], indexes: any, recurse: any, entities: any): any; | ||
@@ -18,7 +19,10 @@ /** | ||
addEntity: any, | ||
visitedEntities: any | ||
visitedEntities: any, | ||
storeEntities: any, | ||
args: any[] | ||
]): any; | ||
denormalize(...args: readonly [input: {}, unvisit: any]): [denormalized: any, found: boolean, deleted: boolean]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any, entities: any): any; | ||
} | ||
//# sourceMappingURL=Object.d.ts.map |
@@ -1,3 +0,3 @@ | ||
import { isImmutable, denormalizeImmutable } from './ImmutableUtils.js'; | ||
export const normalize = (schema, input, parent, key, visit, addEntity, visitedEntities) => { | ||
import { isImmutable, denormalizeImmutable, denormalizeOnlyImmutable } from './ImmutableUtils.js'; | ||
export const normalize = (schema, input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) => { | ||
const object = { | ||
@@ -8,3 +8,3 @@ ...input | ||
const localSchema = schema[key]; | ||
const value = visit(input[key], input, key, localSchema, addEntity, visitedEntities); | ||
const value = visit(input[key], input, key, localSchema, addEntity, visitedEntities, storeEntities, args); | ||
if (value === undefined || value === null) { | ||
@@ -41,2 +41,20 @@ delete object[key]; | ||
}; | ||
export function denormalizeOnly(schema, input, args, unvisit) { | ||
if (isImmutable(input)) { | ||
return denormalizeOnlyImmutable(schema, input, unvisit); | ||
} | ||
const object = { | ||
...input | ||
}; | ||
for (const key of Object.keys(schema)) { | ||
const item = unvisit(object[key], schema[key]); | ||
if (object[key] !== undefined) { | ||
object[key] = item; | ||
} | ||
if (typeof item === 'symbol') { | ||
return item; | ||
} | ||
} | ||
return object; | ||
} | ||
export function infer(schema, args, indexes, recurse, entities) { | ||
@@ -49,3 +67,2 @@ const resultObject = {}; | ||
} | ||
/** | ||
@@ -77,2 +94,5 @@ * Represents objects with statically known members | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return denormalizeOnly(this.schema, input, args, unvisit); | ||
} | ||
infer(args, indexes, recurse, entities) { | ||
@@ -82,2 +102,2 @@ return infer(this.schema, args, indexes, recurse, entities); | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpc0ltbXV0YWJsZSIsImRlbm9ybWFsaXplSW1tdXRhYmxlIiwibm9ybWFsaXplIiwic2NoZW1hIiwiaW5wdXQiLCJwYXJlbnQiLCJrZXkiLCJ2aXNpdCIsImFkZEVudGl0eSIsInZpc2l0ZWRFbnRpdGllcyIsIm9iamVjdCIsIk9iamVjdCIsImtleXMiLCJmb3JFYWNoIiwibG9jYWxTY2hlbWEiLCJ2YWx1ZSIsInVuZGVmaW5lZCIsImRlbm9ybWFsaXplIiwidW52aXNpdCIsImZvdW5kIiwiZGVsZXRlZCIsIml0ZW0iLCJmb3VuZEl0ZW0iLCJkZWxldGVkSXRlbSIsImluZmVyIiwiYXJncyIsImluZGV4ZXMiLCJyZWN1cnNlIiwiZW50aXRpZXMiLCJyZXN1bHRPYmplY3QiLCJrIiwiT2JqZWN0U2NoZW1hIiwiY29uc3RydWN0b3IiLCJkZWZpbml0aW9uIiwiZGVmaW5lIiwicmVkdWNlIiwiZW50aXR5U2NoZW1hIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvT2JqZWN0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzSW1tdXRhYmxlLCBkZW5vcm1hbGl6ZUltbXV0YWJsZSB9IGZyb20gJy4vSW1tdXRhYmxlVXRpbHMuanMnO1xuXG5leHBvcnQgY29uc3Qgbm9ybWFsaXplID0gKFxuICBzY2hlbWE6IGFueSxcbiAgaW5wdXQ6IGFueSxcbiAgcGFyZW50OiBhbnksXG4gIGtleTogYW55LFxuICB2aXNpdDogYW55LFxuICBhZGRFbnRpdHk6IGFueSxcbiAgdmlzaXRlZEVudGl0aWVzOiBhbnksXG4pID0+IHtcbiAgY29uc3Qgb2JqZWN0ID0geyAuLi5pbnB1dCB9O1xuICBPYmplY3Qua2V5cyhzY2hlbWEpLmZvckVhY2goa2V5ID0+IHtcbiAgICBjb25zdCBsb2NhbFNjaGVtYSA9IHNjaGVtYVtrZXldO1xuICAgIGNvbnN0IHZhbHVlID0gdmlzaXQoXG4gICAgICBpbnB1dFtrZXldLFxuICAgICAgaW5wdXQsXG4gICAgICBrZXksXG4gICAgICBsb2NhbFNjaGVtYSxcbiAgICAgIGFkZEVudGl0eSxcbiAgICAgIHZpc2l0ZWRFbnRpdGllcyxcbiAgICApO1xuICAgIGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkIHx8IHZhbHVlID09PSBudWxsKSB7XG4gICAgICBkZWxldGUgb2JqZWN0W2tleV07XG4gICAgfSBlbHNlIHtcbiAgICAgIG9iamVjdFtrZXldID0gdmFsdWU7XG4gICAgfVxuICB9KTtcbiAgcmV0dXJuIG9iamVjdDtcbn07XG5cbmV4cG9ydCBjb25zdCBkZW5vcm1hbGl6ZSA9IChcbiAgc2NoZW1hOiBhbnksXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvYmFuLXR5cGVzXG4gIGlucHV0OiB7fSxcbiAgdW52aXNpdDogYW55LFxuKTogW2Rlbm9ybWFsaXplZDogYW55LCBmb3VuZDogYm9vbGVhbiwgZGVsZXRlZDogYm9vbGVhbl0gPT4ge1xuICBpZiAoaXNJbW11dGFibGUoaW5wdXQpKSB7XG4gICAgcmV0dXJuIGRlbm9ybWFsaXplSW1tdXRhYmxlKHNjaGVtYSwgaW5wdXQsIHVudmlzaXQpO1xuICB9XG5cbiAgY29uc3Qgb2JqZWN0OiBSZWNvcmQ8c3RyaW5nLCBhbnk+ID0geyAuLi5pbnB1dCB9O1xuICBsZXQgZm91bmQgPSB0cnVlO1xuICBsZXQgZGVsZXRlZCA9IGZhbHNlO1xuICBPYmplY3Qua2V5cyhzY2hlbWEpLmZvckVhY2goa2V5ID0+IHtcbiAgICBjb25zdCBbaXRlbSwgZm91bmRJdGVtLCBkZWxldGVkSXRlbV0gPSB1bnZpc2l0KG9iamVjdFtrZXldLCBzY2hlbWFba2V5XSk7XG4gICAgaWYgKG9iamVjdFtrZXldICE9PSB1bmRlZmluZWQpIHtcbiAgICAgIG9iamVjdFtrZXldID0gaXRlbTtcbiAgICB9XG4gICAgaWYgKGRlbGV0ZWRJdGVtKSB7XG4gICAgICBkZWxldGVkID0gdHJ1ZTtcbiAgICB9XG4gICAgaWYgKCFmb3VuZEl0ZW0pIHtcbiAgICAgIGZvdW5kID0gZmFsc2U7XG4gICAgfVxuICB9KTtcbiAgcmV0dXJuIFtvYmplY3QsIGZvdW5kLCBkZWxldGVkXTtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBpbmZlcihcbiAgc2NoZW1hOiBhbnksXG4gIGFyZ3M6IHJlYWRvbmx5IGFueVtdLFxuICBpbmRleGVzOiBhbnksXG4gIHJlY3Vyc2U6IGFueSxcbiAgZW50aXRpZXM6IGFueSxcbikge1xuICBjb25zdCByZXN1bHRPYmplY3Q6IGFueSA9IHt9O1xuICBPYmplY3Qua2V5cyhzY2hlbWEpLmZvckVhY2goayA9PiB7XG4gICAgcmVzdWx0T2JqZWN0W2tdID0gcmVjdXJzZShzY2hlbWFba10sIGFyZ3MsIGluZGV4ZXMsIGVudGl0aWVzKTtcbiAgfSk7XG4gIHJldHVybiByZXN1bHRPYmplY3Q7XG59XG5cbi8qKlxuICogUmVwcmVzZW50cyBvYmplY3RzIHdpdGggc3RhdGljYWxseSBrbm93biBtZW1iZXJzXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL3Jlc3QvYXBpL09iamVjdFxuICovXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBPYmplY3RTY2hlbWEge1xuICBwcm90ZWN0ZWQgc2NoZW1hOiBhbnk7XG5cbiAgY29uc3RydWN0b3IoZGVmaW5pdGlvbjogUmVjb3JkPHN0cmluZywgYW55Pikge1xuICAgIHRoaXMuZGVmaW5lKGRlZmluaXRpb24pO1xuICB9XG5cbiAgZGVmaW5lKGRlZmluaXRpb246IFJlY29yZDxzdHJpbmcsIGFueT4pIHtcbiAgICB0aGlzLnNjaGVtYSA9IE9iamVjdC5rZXlzKGRlZmluaXRpb24pLnJlZHVjZSgoZW50aXR5U2NoZW1hLCBrZXkpID0+IHtcbiAgICAgIGNvbnN0IHNjaGVtYSA9IGRlZmluaXRpb25ba2V5XTtcbiAgICAgIHJldHVybiB7IC4uLmVudGl0eVNjaGVtYSwgW2tleV06IHNjaGVtYSB9O1xuICAgIH0sIHRoaXMuc2NoZW1hIHx8IHt9KTtcbiAgfVxuXG4gIG5vcm1hbGl6ZShcbiAgICAuLi5hcmdzOiByZWFkb25seSBbXG4gICAgICBpbnB1dDogYW55LFxuICAgICAgcGFyZW50OiBhbnksXG4gICAgICBrZXk6IGFueSxcbiAgICAgIHZpc2l0OiBhbnksXG4gICAgICBhZGRFbnRpdHk6IGFueSxcbiAgICAgIHZpc2l0ZWRFbnRpdGllczogYW55LFxuICAgIF1cbiAgKSB7XG4gICAgcmV0dXJuIG5vcm1hbGl6ZSh0aGlzLnNjaGVtYSwgLi4uYXJncyk7XG4gIH1cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuICBkZW5vcm1hbGl6ZSguLi5hcmdzOiByZWFkb25seSBbaW5wdXQ6IHt9LCB1bnZpc2l0OiBhbnldKSB7XG4gICAgcmV0dXJuIGRlbm9ybWFsaXplKHRoaXMuc2NoZW1hLCAuLi5hcmdzKTtcbiAgfVxuXG4gIGluZmVyKGFyZ3M6IGFueSwgaW5kZXhlczogYW55LCByZWN1cnNlOiBhbnksIGVudGl0aWVzOiBhbnkpIHtcbiAgICByZXR1cm4gaW5mZXIodGhpcy5zY2hlbWEsIGFyZ3MsIGluZGV4ZXMsIHJlY3Vyc2UsIGVudGl0aWVzKTtcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxXQUFXLEVBQUVDLG9CQUFvQixRQUFRLHFCQUFxQjtBQUV2RSxPQUFPLE1BQU1DLFNBQVMsR0FBR0EsQ0FDdkJDLE1BQVcsRUFDWEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEtBQ2pCO0VBQ0gsTUFBTUMsTUFBTSxHQUFHO0lBQUUsR0FBR047RUFBTSxDQUFDO0VBQzNCTyxNQUFNLENBQUNDLElBQUksQ0FBQ1QsTUFBTSxDQUFDLENBQUNVLE9BQU8sQ0FBQ1AsR0FBRyxJQUFJO0lBQ2pDLE1BQU1RLFdBQVcsR0FBR1gsTUFBTSxDQUFDRyxHQUFHLENBQUM7SUFDL0IsTUFBTVMsS0FBSyxHQUFHUixLQUFLLENBQ2pCSCxLQUFLLENBQUNFLEdBQUcsQ0FBQyxFQUNWRixLQUFLLEVBQ0xFLEdBQUcsRUFDSFEsV0FBVyxFQUNYTixTQUFTLEVBQ1RDLGVBQWUsQ0FDaEI7SUFDRCxJQUFJTSxLQUFLLEtBQUtDLFNBQVMsSUFBSUQsS0FBSyxLQUFLLElBQUksRUFBRTtNQUN6QyxPQUFPTCxNQUFNLENBQUNKLEdBQUcsQ0FBQztJQUNwQixDQUFDLE1BQU07TUFDTEksTUFBTSxDQUFDSixHQUFHLENBQUMsR0FBR1MsS0FBSztJQUNyQjtFQUNGLENBQUMsQ0FBQztFQUNGLE9BQU9MLE1BQU07QUFDZixDQUFDO0FBRUQsT0FBTyxNQUFNTyxXQUFXLEdBQUdBLENBQ3pCZCxNQUFXLEVBRVhDLEtBQVMsRUFDVGMsT0FBWSxLQUM4QztFQUMxRCxJQUFJbEIsV0FBVyxDQUFDSSxLQUFLLENBQUMsRUFBRTtJQUN0QixPQUFPSCxvQkFBb0IsQ0FBQ0UsTUFBTSxFQUFFQyxLQUFLLEVBQUVjLE9BQU8sQ0FBQztFQUNyRDtFQUVBLE1BQU1SLE1BQTJCLEdBQUc7SUFBRSxHQUFHTjtFQUFNLENBQUM7RUFDaEQsSUFBSWUsS0FBSyxHQUFHLElBQUk7RUFDaEIsSUFBSUMsT0FBTyxHQUFHLEtBQUs7RUFDbkJULE1BQU0sQ0FBQ0MsSUFBSSxDQUFDVCxNQUFNLENBQUMsQ0FBQ1UsT0FBTyxDQUFDUCxHQUFHLElBQUk7SUFDakMsTUFBTSxDQUFDZSxJQUFJLEVBQUVDLFNBQVMsRUFBRUMsV0FBVyxDQUFDLEdBQUdMLE9BQU8sQ0FBQ1IsTUFBTSxDQUFDSixHQUFHLENBQUMsRUFBRUgsTUFBTSxDQUFDRyxHQUFHLENBQUMsQ0FBQztJQUN4RSxJQUFJSSxNQUFNLENBQUNKLEdBQUcsQ0FBQyxLQUFLVSxTQUFTLEVBQUU7TUFDN0JOLE1BQU0sQ0FBQ0osR0FBRyxDQUFDLEdBQUdlLElBQUk7SUFDcEI7SUFDQSxJQUFJRSxXQUFXLEVBQUU7TUFDZkgsT0FBTyxHQUFHLElBQUk7SUFDaEI7SUFDQSxJQUFJLENBQUNFLFNBQVMsRUFBRTtNQUNkSCxLQUFLLEdBQUcsS0FBSztJQUNmO0VBQ0YsQ0FBQyxDQUFDO0VBQ0YsT0FBTyxDQUFDVCxNQUFNLEVBQUVTLEtBQUssRUFBRUMsT0FBTyxDQUFDO0FBQ2pDLENBQUM7QUFFRCxPQUFPLFNBQVNJLEtBQUtBLENBQ25CckIsTUFBVyxFQUNYc0IsSUFBb0IsRUFDcEJDLE9BQVksRUFDWkMsT0FBWSxFQUNaQyxRQUFhLEVBQ2I7RUFDQSxNQUFNQyxZQUFpQixHQUFHLENBQUMsQ0FBQztFQUM1QmxCLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDVCxNQUFNLENBQUMsQ0FBQ1UsT0FBTyxDQUFDaUIsQ0FBQyxJQUFJO0lBQy9CRCxZQUFZLENBQUNDLENBQUMsQ0FBQyxHQUFHSCxPQUFPLENBQUN4QixNQUFNLENBQUMyQixDQUFDLENBQUMsRUFBRUwsSUFBSSxFQUFFQyxPQUFPLEVBQUVFLFFBQVEsQ0FBQztFQUMvRCxDQUFDLENBQUM7RUFDRixPQUFPQyxZQUFZO0FBQ3JCOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxNQUFNRSxZQUFZLENBQUM7RUFHaENDLFdBQVdBLENBQUNDLFVBQStCLEVBQUU7SUFBQSxLQUZuQzlCLE1BQU07SUFHZCxJQUFJLENBQUMrQixNQUFNLENBQUNELFVBQVUsQ0FBQztFQUN6QjtFQUVBQyxNQUFNQSxDQUFDRCxVQUErQixFQUFFO0lBQ3RDLElBQUksQ0FBQzlCLE1BQU0sR0FBR1EsTUFBTSxDQUFDQyxJQUFJLENBQUNxQixVQUFVLENBQUMsQ0FBQ0UsTUFBTSxDQUFDLENBQUNDLFlBQVksRUFBRTlCLEdBQUcsS0FBSztNQUNsRSxNQUFNSCxNQUFNLEdBQUc4QixVQUFVLENBQUMzQixHQUFHLENBQUM7TUFDOUIsT0FBTztRQUFFLEdBQUc4QixZQUFZO1FBQUUsQ0FBQzlCLEdBQUcsR0FBR0g7TUFBTyxDQUFDO0lBQzNDLENBQUMsRUFBRSxJQUFJLENBQUNBLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQztFQUN2QjtFQUVBRCxTQUFTQSxDQUNQLEdBQUd1QixJQU9GLEVBQ0Q7SUFDQSxPQUFPdkIsU0FBUyxDQUFDLElBQUksQ0FBQ0MsTUFBTSxFQUFFLEdBQUdzQixJQUFJLENBQUM7RUFDeEM7O0VBRUE7RUFDQVIsV0FBV0EsQ0FBQyxHQUFHUSxJQUF3QyxFQUFFO0lBQ3ZELE9BQU9SLFdBQVcsQ0FBQyxJQUFJLENBQUNkLE1BQU0sRUFBRSxHQUFHc0IsSUFBSSxDQUFDO0VBQzFDO0VBRUFELEtBQUtBLENBQUNDLElBQVMsRUFBRUMsT0FBWSxFQUFFQyxPQUFZLEVBQUVDLFFBQWEsRUFBRTtJQUMxRCxPQUFPSixLQUFLLENBQUMsSUFBSSxDQUFDckIsTUFBTSxFQUFFc0IsSUFBSSxFQUFFQyxPQUFPLEVBQUVDLE9BQU8sRUFBRUMsUUFBUSxDQUFDO0VBQzdEO0FBQ0YifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["isImmutable","denormalizeImmutable","denormalizeOnlyImmutable","normalize","schema","input","parent","key","visit","addEntity","visitedEntities","storeEntities","args","object","Object","keys","forEach","localSchema","value","undefined","denormalize","unvisit","found","deleted","item","foundItem","deletedItem","denormalizeOnly","infer","indexes","recurse","entities","resultObject","k","ObjectSchema","constructor","definition","define","reduce","entitySchema"],"sources":["../../src/schemas/Object.ts"],"sourcesContent":["import {\n  isImmutable,\n  denormalizeImmutable,\n  denormalizeOnlyImmutable,\n} from './ImmutableUtils.js';\n\nexport const normalize = (\n  schema: any,\n  input: any,\n  parent: any,\n  key: any,\n  visit: any,\n  addEntity: any,\n  visitedEntities: any,\n  storeEntities: any,\n  args: any[],\n) => {\n  const object = { ...input };\n  Object.keys(schema).forEach(key => {\n    const localSchema = schema[key];\n    const value = visit(\n      input[key],\n      input,\n      key,\n      localSchema,\n      addEntity,\n      visitedEntities,\n      storeEntities,\n      args,\n    );\n    if (value === undefined || value === null) {\n      delete object[key];\n    } else {\n      object[key] = value;\n    }\n  });\n  return object;\n};\n\nexport const denormalize = (\n  schema: any,\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  input: {},\n  unvisit: any,\n): [denormalized: any, found: boolean, deleted: boolean] => {\n  if (isImmutable(input)) {\n    return denormalizeImmutable(schema, input, unvisit);\n  }\n\n  const object: Record<string, any> = { ...input };\n  let found = true;\n  let deleted = false;\n  Object.keys(schema).forEach(key => {\n    const [item, foundItem, deletedItem] = unvisit(object[key], schema[key]);\n    if (object[key] !== undefined) {\n      object[key] = item;\n    }\n    if (deletedItem) {\n      deleted = true;\n    }\n    if (!foundItem) {\n      found = false;\n    }\n  });\n  return [object, found, deleted];\n};\n\nexport function denormalizeOnly(\n  schema: any,\n  input: {},\n  args: readonly any[],\n  unvisit: (input: any, schema: any) => any,\n): any {\n  if (isImmutable(input)) {\n    return denormalizeOnlyImmutable(schema, input, unvisit);\n  }\n\n  const object: Record<string, any> = { ...input };\n\n  for (const key of Object.keys(schema)) {\n    const item = unvisit(object[key], schema[key]);\n    if (object[key] !== undefined) {\n      object[key] = item;\n    }\n    if (typeof item === 'symbol') {\n      return item;\n    }\n  }\n  return object;\n}\n\nexport function infer(\n  schema: any,\n  args: readonly any[],\n  indexes: any,\n  recurse: any,\n  entities: any,\n) {\n  const resultObject: any = {};\n  Object.keys(schema).forEach(k => {\n    resultObject[k] = recurse(schema[k], args, indexes, entities);\n  });\n  return resultObject;\n}\n/**\n * Represents objects with statically known members\n * @see https://resthooks.io/rest/api/Object\n */\nexport default class ObjectSchema {\n  protected schema: any;\n\n  constructor(definition: Record<string, any>) {\n    this.define(definition);\n  }\n\n  define(definition: Record<string, any>) {\n    this.schema = Object.keys(definition).reduce((entitySchema, key) => {\n      const schema = definition[key];\n      return { ...entitySchema, [key]: schema };\n    }, this.schema || {});\n  }\n\n  normalize(\n    ...args: readonly [\n      input: any,\n      parent: any,\n      key: any,\n      visit: any,\n      addEntity: any,\n      visitedEntities: any,\n      storeEntities: any,\n      args: any[],\n    ]\n  ) {\n    return normalize(this.schema, ...args);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  denormalize(...args: readonly [input: {}, unvisit: any]) {\n    return denormalize(this.schema, ...args);\n  }\n\n  denormalizeOnly(\n    input: {},\n    args: readonly any[],\n    unvisit: (input: any, schema: any) => any,\n  ): any {\n    return denormalizeOnly(this.schema, input, args, unvisit);\n  }\n\n  infer(args: any, indexes: any, recurse: any, entities: any) {\n    return infer(this.schema, args, indexes, recurse, entities);\n  }\n}\n"],"mappings":"AAAA,SACEA,WAAW,EACXC,oBAAoB,EACpBC,wBAAwB,QACnB,qBAAqB;AAE5B,OAAO,MAAMC,SAAS,GAAGA,CACvBC,MAAW,EACXC,KAAU,EACVC,MAAW,EACXC,GAAQ,EACRC,KAAU,EACVC,SAAc,EACdC,eAAoB,EACpBC,aAAkB,EAClBC,IAAW,KACR;EACH,MAAMC,MAAM,GAAG;IAAE,GAAGR;EAAM,CAAC;EAC3BS,MAAM,CAACC,IAAI,CAACX,MAAM,CAAC,CAACY,OAAO,CAACT,GAAG,IAAI;IACjC,MAAMU,WAAW,GAAGb,MAAM,CAACG,GAAG,CAAC;IAC/B,MAAMW,KAAK,GAAGV,KAAK,CACjBH,KAAK,CAACE,GAAG,CAAC,EACVF,KAAK,EACLE,GAAG,EACHU,WAAW,EACXR,SAAS,EACTC,eAAe,EACfC,aAAa,EACbC,IAAI,CACL;IACD,IAAIM,KAAK,KAAKC,SAAS,IAAID,KAAK,KAAK,IAAI,EAAE;MACzC,OAAOL,MAAM,CAACN,GAAG,CAAC;IACpB,CAAC,MAAM;MACLM,MAAM,CAACN,GAAG,CAAC,GAAGW,KAAK;IACrB;EACF,CAAC,CAAC;EACF,OAAOL,MAAM;AACf,CAAC;AAED,OAAO,MAAMO,WAAW,GAAGA,CACzBhB,MAAW,EAEXC,KAAS,EACTgB,OAAY,KAC8C;EAC1D,IAAIrB,WAAW,CAACK,KAAK,CAAC,EAAE;IACtB,OAAOJ,oBAAoB,CAACG,MAAM,EAAEC,KAAK,EAAEgB,OAAO,CAAC;EACrD;EAEA,MAAMR,MAA2B,GAAG;IAAE,GAAGR;EAAM,CAAC;EAChD,IAAIiB,KAAK,GAAG,IAAI;EAChB,IAAIC,OAAO,GAAG,KAAK;EACnBT,MAAM,CAACC,IAAI,CAACX,MAAM,CAAC,CAACY,OAAO,CAACT,GAAG,IAAI;IACjC,MAAM,CAACiB,IAAI,EAAEC,SAAS,EAAEC,WAAW,CAAC,GAAGL,OAAO,CAACR,MAAM,CAACN,GAAG,CAAC,EAAEH,MAAM,CAACG,GAAG,CAAC,CAAC;IACxE,IAAIM,MAAM,CAACN,GAAG,CAAC,KAAKY,SAAS,EAAE;MAC7BN,MAAM,CAACN,GAAG,CAAC,GAAGiB,IAAI;IACpB;IACA,IAAIE,WAAW,EAAE;MACfH,OAAO,GAAG,IAAI;IAChB;IACA,IAAI,CAACE,SAAS,EAAE;MACdH,KAAK,GAAG,KAAK;IACf;EACF,CAAC,CAAC;EACF,OAAO,CAACT,MAAM,EAAES,KAAK,EAAEC,OAAO,CAAC;AACjC,CAAC;AAED,OAAO,SAASI,eAAeA,CAC7BvB,MAAW,EACXC,KAAS,EACTO,IAAoB,EACpBS,OAAyC,EACpC;EACL,IAAIrB,WAAW,CAACK,KAAK,CAAC,EAAE;IACtB,OAAOH,wBAAwB,CAACE,MAAM,EAAEC,KAAK,EAAEgB,OAAO,CAAC;EACzD;EAEA,MAAMR,MAA2B,GAAG;IAAE,GAAGR;EAAM,CAAC;EAEhD,KAAK,MAAME,GAAG,IAAIO,MAAM,CAACC,IAAI,CAACX,MAAM,CAAC,EAAE;IACrC,MAAMoB,IAAI,GAAGH,OAAO,CAACR,MAAM,CAACN,GAAG,CAAC,EAAEH,MAAM,CAACG,GAAG,CAAC,CAAC;IAC9C,IAAIM,MAAM,CAACN,GAAG,CAAC,KAAKY,SAAS,EAAE;MAC7BN,MAAM,CAACN,GAAG,CAAC,GAAGiB,IAAI;IACpB;IACA,IAAI,OAAOA,IAAI,KAAK,QAAQ,EAAE;MAC5B,OAAOA,IAAI;IACb;EACF;EACA,OAAOX,MAAM;AACf;AAEA,OAAO,SAASe,KAAKA,CACnBxB,MAAW,EACXQ,IAAoB,EACpBiB,OAAY,EACZC,OAAY,EACZC,QAAa,EACb;EACA,MAAMC,YAAiB,GAAG,CAAC,CAAC;EAC5BlB,MAAM,CAACC,IAAI,CAACX,MAAM,CAAC,CAACY,OAAO,CAACiB,CAAC,IAAI;IAC/BD,YAAY,CAACC,CAAC,CAAC,GAAGH,OAAO,CAAC1B,MAAM,CAAC6B,CAAC,CAAC,EAAErB,IAAI,EAAEiB,OAAO,EAAEE,QAAQ,CAAC;EAC/D,CAAC,CAAC;EACF,OAAOC,YAAY;AACrB;AACA;AACA;AACA;AACA;AACA,eAAe,MAAME,YAAY,CAAC;EAGhCC,WAAWA,CAACC,UAA+B,EAAE;IAAA,KAFnChC,MAAM;IAGd,IAAI,CAACiC,MAAM,CAACD,UAAU,CAAC;EACzB;EAEAC,MAAMA,CAACD,UAA+B,EAAE;IACtC,IAAI,CAAChC,MAAM,GAAGU,MAAM,CAACC,IAAI,CAACqB,UAAU,CAAC,CAACE,MAAM,CAAC,CAACC,YAAY,EAAEhC,GAAG,KAAK;MAClE,MAAMH,MAAM,GAAGgC,UAAU,CAAC7B,GAAG,CAAC;MAC9B,OAAO;QAAE,GAAGgC,YAAY;QAAE,CAAChC,GAAG,GAAGH;MAAO,CAAC;IAC3C,CAAC,EAAE,IAAI,CAACA,MAAM,IAAI,CAAC,CAAC,CAAC;EACvB;EAEAD,SAASA,CACP,GAAGS,IASF,EACD;IACA,OAAOT,SAAS,CAAC,IAAI,CAACC,MAAM,EAAE,GAAGQ,IAAI,CAAC;EACxC;;EAEA;EACAQ,WAAWA,CAAC,GAAGR,IAAwC,EAAE;IACvD,OAAOQ,WAAW,CAAC,IAAI,CAAChB,MAAM,EAAE,GAAGQ,IAAI,CAAC;EAC1C;EAEAe,eAAeA,CACbtB,KAAS,EACTO,IAAoB,EACpBS,OAAyC,EACpC;IACL,OAAOM,eAAe,CAAC,IAAI,CAACvB,MAAM,EAAEC,KAAK,EAAEO,IAAI,EAAES,OAAO,CAAC;EAC3D;EAEAO,KAAKA,CAAChB,IAAS,EAAEiB,OAAY,EAAEC,OAAY,EAAEC,QAAa,EAAE;IAC1D,OAAOH,KAAK,CAAC,IAAI,CAACxB,MAAM,EAAEQ,IAAI,EAAEiB,OAAO,EAAEC,OAAO,EAAEC,QAAQ,CAAC;EAC7D;AACF"} |
@@ -9,5 +9,5 @@ export default class PolymorphicSchema { | ||
inferSchema(input: any, parent: any, key: any): any; | ||
normalizeValue(value: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalizeValue(value: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
denormalizeValue(value: any, unvisit: any): any; | ||
} | ||
//# sourceMappingURL=Polymorphic.d.ts.map |
import { isImmutable } from './ImmutableUtils.js'; | ||
import { DELETED } from '../special.js'; | ||
export default class PolymorphicSchema { | ||
@@ -14,3 +15,9 @@ constructor(definition, schemaAttribute) { | ||
define(definition) { | ||
this.schema = definition; | ||
// sending Union into another Polymorphic gets hoisted | ||
if ('_schemaAttribute' in definition && !this._schemaAttribute) { | ||
this.schema = definition.schema; | ||
this._schemaAttribute = definition._schemaAttribute; | ||
} else { | ||
this.schema = definition; | ||
} | ||
} | ||
@@ -27,3 +34,4 @@ getSchemaAttribute(input, parent, key) { | ||
} | ||
normalizeValue(value, parent, key, visit, addEntity, visitedEntities) { | ||
normalizeValue(value, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
if (!value) return value; | ||
const schema = this.inferSchema(value, parent, key); | ||
@@ -41,3 +49,3 @@ if (!schema) { | ||
} | ||
const normalizedValue = visit(value, parent, key, schema, addEntity, visitedEntities); | ||
const normalizedValue = visit(value, parent, key, schema, addEntity, visitedEntities, storeEntities, args); | ||
return this.isSingleSchema || normalizedValue === undefined || normalizedValue === null ? normalizedValue : { | ||
@@ -58,9 +66,14 @@ id: normalizedValue, | ||
} | ||
return [value, true, false]; | ||
return value; | ||
} | ||
const id = this.isSingleSchema ? undefined : isImmutable(value) ? value.get('id') : value.id; | ||
const schema = this.isSingleSchema ? this.schema : this.schema[schemaKey]; | ||
return unvisit(id || value, schema); | ||
const ret = unvisit(id || value, schema); | ||
if (Array.isArray(ret) && ret.length === 3) { | ||
if (ret[2] === true) return DELETED; | ||
return ret[0]; | ||
} | ||
return ret; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["isImmutable","PolymorphicSchema","constructor","definition","schemaAttribute","schema","_schemaAttribute","input","define","isSingleSchema","getSchemaAttribute","parent","key","inferSchema","attr","normalizeValue","value","visit","addEntity","visitedEntities","process","env","NODE_ENV","console","warn","JSON","stringify","undefined","Object","keys","map","k","join","normalizedValue","id","denormalizeValue","unvisit","schemaKey","get","name"],"sources":["../../src/schemas/Polymorphic.ts"],"sourcesContent":["import { isImmutable } from './ImmutableUtils.js';\n\nexport default class PolymorphicSchema {\n  private declare _schemaAttribute: any;\n  protected schema: any;\n\n  constructor(\n    definition: any,\n    schemaAttribute?: string | ((...args: any) => any),\n  ) {\n    if (schemaAttribute) {\n      this._schemaAttribute =\n        typeof schemaAttribute === 'string'\n          ? (input: any) => input[schemaAttribute]\n          : schemaAttribute;\n    }\n    this.define(definition);\n  }\n\n  get isSingleSchema() {\n    return !this._schemaAttribute;\n  }\n\n  define(definition: any) {\n    this.schema = definition;\n  }\n\n  getSchemaAttribute(input: any, parent: any, key: any) {\n    return !this.isSingleSchema && this._schemaAttribute(input, parent, key);\n  }\n\n  inferSchema(input: any, parent: any, key: any) {\n    if (this.isSingleSchema) {\n      return this.schema;\n    }\n\n    const attr = this.getSchemaAttribute(input, parent, key);\n    return this.schema[attr];\n  }\n\n  normalizeValue(\n    value: any,\n    parent: any,\n    key: any,\n    visit: any,\n    addEntity: any,\n    visitedEntities: any,\n  ) {\n    const schema = this.inferSchema(value, parent, key);\n    if (!schema) {\n      /* istanbul ignore else */\n      if (process.env.NODE_ENV !== 'production') {\n        const attr = this.getSchemaAttribute(value, parent, key);\n        console.warn(\n          `Schema attribute ${JSON.stringify(\n            attr,\n            undefined,\n            2,\n          )} is not expected.\nExpected one of: ${Object.keys(this.schema)\n            .map(k => `\"${k}\"`)\n            .join(', ')}\n\nValue: ${JSON.stringify(value, undefined, 2)}`,\n        );\n      }\n      return value;\n    }\n    const normalizedValue = visit(\n      value,\n      parent,\n      key,\n      schema,\n      addEntity,\n      visitedEntities,\n    );\n    return this.isSingleSchema ||\n      normalizedValue === undefined ||\n      normalizedValue === null\n      ? normalizedValue\n      : {\n          id: normalizedValue,\n          schema: this.getSchemaAttribute(value, parent, key),\n        };\n  }\n\n  // value is guaranteed by caller to not be null\n  denormalizeValue(value: any, unvisit: any) {\n    const schemaKey =\n      !this.isSingleSchema &&\n      (isImmutable(value) ? value.get('schema') : value.schema);\n    if (!this.isSingleSchema && !schemaKey) {\n      /* istanbul ignore else */\n      if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `TypeError: Unable to infer schema for ${this.constructor.name}\nValue: ${JSON.stringify(value, undefined, 2)}.`,\n        );\n      }\n      return [value, true, false];\n    }\n    const id = this.isSingleSchema\n      ? undefined\n      : isImmutable(value)\n      ? value.get('id')\n      : value.id;\n    const schema = this.isSingleSchema ? this.schema : this.schema[schemaKey];\n    return unvisit(id || value, schema);\n  }\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["isImmutable","DELETED","PolymorphicSchema","constructor","definition","schemaAttribute","schema","_schemaAttribute","input","define","isSingleSchema","getSchemaAttribute","parent","key","inferSchema","attr","normalizeValue","value","visit","addEntity","visitedEntities","storeEntities","args","process","env","NODE_ENV","console","warn","JSON","stringify","undefined","Object","keys","map","k","join","normalizedValue","id","denormalizeValue","unvisit","schemaKey","get","name","ret","Array","isArray","length"],"sources":["../../src/schemas/Polymorphic.ts"],"sourcesContent":["import { isImmutable } from './ImmutableUtils.js';\nimport { DELETED } from '../special.js';\n\nexport default class PolymorphicSchema {\n  private declare _schemaAttribute: any;\n  protected schema: any;\n\n  constructor(\n    definition: any,\n    schemaAttribute?: string | ((...args: any) => any),\n  ) {\n    if (schemaAttribute) {\n      this._schemaAttribute =\n        typeof schemaAttribute === 'string'\n          ? (input: any) => input[schemaAttribute]\n          : schemaAttribute;\n    }\n    this.define(definition);\n  }\n\n  get isSingleSchema() {\n    return !this._schemaAttribute;\n  }\n\n  define(definition: any) {\n    // sending Union into another Polymorphic gets hoisted\n    if ('_schemaAttribute' in definition && !this._schemaAttribute) {\n      this.schema = definition.schema;\n      this._schemaAttribute = definition._schemaAttribute;\n    } else {\n      this.schema = definition;\n    }\n  }\n\n  getSchemaAttribute(input: any, parent: any, key: any) {\n    return !this.isSingleSchema && this._schemaAttribute(input, parent, key);\n  }\n\n  inferSchema(input: any, parent: any, key: any) {\n    if (this.isSingleSchema) {\n      return this.schema;\n    }\n\n    const attr = this.getSchemaAttribute(input, parent, key);\n    return this.schema[attr];\n  }\n\n  normalizeValue(\n    value: any,\n    parent: any,\n    key: any,\n    visit: any,\n    addEntity: any,\n    visitedEntities: any,\n    storeEntities: any,\n    args?: any[],\n  ) {\n    if (!value) return value;\n    const schema = this.inferSchema(value, parent, key);\n    if (!schema) {\n      /* istanbul ignore else */\n      if (process.env.NODE_ENV !== 'production') {\n        const attr = this.getSchemaAttribute(value, parent, key);\n        console.warn(\n          `Schema attribute ${JSON.stringify(\n            attr,\n            undefined,\n            2,\n          )} is not expected.\nExpected one of: ${Object.keys(this.schema)\n            .map(k => `\"${k}\"`)\n            .join(', ')}\n\nValue: ${JSON.stringify(value, undefined, 2)}`,\n        );\n      }\n      return value;\n    }\n    const normalizedValue = visit(\n      value,\n      parent,\n      key,\n      schema,\n      addEntity,\n      visitedEntities,\n      storeEntities,\n      args,\n    );\n    return this.isSingleSchema ||\n      normalizedValue === undefined ||\n      normalizedValue === null\n      ? normalizedValue\n      : {\n          id: normalizedValue,\n          schema: this.getSchemaAttribute(value, parent, key),\n        };\n  }\n\n  // value is guaranteed by caller to not be null\n  denormalizeValue(value: any, unvisit: any) {\n    const schemaKey =\n      !this.isSingleSchema &&\n      (isImmutable(value) ? value.get('schema') : value.schema);\n    if (!this.isSingleSchema && !schemaKey) {\n      /* istanbul ignore else */\n      if (process.env.NODE_ENV !== 'production') {\n        console.warn(\n          `TypeError: Unable to infer schema for ${this.constructor.name}\nValue: ${JSON.stringify(value, undefined, 2)}.`,\n        );\n      }\n      return value;\n    }\n    const id = this.isSingleSchema\n      ? undefined\n      : isImmutable(value)\n      ? value.get('id')\n      : value.id;\n    const schema = this.isSingleSchema ? this.schema : this.schema[schemaKey];\n    const ret = unvisit(id || value, schema);\n    if (Array.isArray(ret) && ret.length === 3) {\n      if (ret[2] === true) return DELETED;\n      return ret[0];\n    }\n    return ret;\n  }\n}\n"],"mappings":"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"} |
@@ -8,4 +8,5 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
constructor(definition: any, schemaAttribute: any); | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]): any; | ||
denormalize(input: {}, unvisit: any): any; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any, entities: any): { | ||
@@ -12,0 +13,0 @@ id: any; |
@@ -14,4 +14,4 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
} | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
return this.normalizeValue(input, parent, key, visit, addEntity, visitedEntities); | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
return this.normalizeValue(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args); | ||
} | ||
@@ -21,2 +21,6 @@ | ||
denormalize(input, unvisit) { | ||
const value = this.denormalizeValue(input, unvisit); | ||
return [value, value !== undefined, typeof value === 'symbol']; | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return this.denormalizeValue(input, unvisit); | ||
@@ -37,2 +41,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsIlVuaW9uU2NoZW1hIiwiY29uc3RydWN0b3IiLCJkZWZpbml0aW9uIiwic2NoZW1hQXR0cmlidXRlIiwiRXJyb3IiLCJub3JtYWxpemUiLCJpbnB1dCIsInBhcmVudCIsImtleSIsInZpc2l0IiwiYWRkRW50aXR5IiwidmlzaXRlZEVudGl0aWVzIiwibm9ybWFsaXplVmFsdWUiLCJkZW5vcm1hbGl6ZSIsInVudmlzaXQiLCJkZW5vcm1hbGl6ZVZhbHVlIiwiaW5mZXIiLCJhcmdzIiwiaW5kZXhlcyIsInJlY3Vyc2UiLCJlbnRpdGllcyIsInVuZGVmaW5lZCIsImF0dHIiLCJnZXRTY2hlbWFBdHRyaWJ1dGUiLCJkaXNjcmltaW5hdGVkU2NoZW1hIiwic2NoZW1hIiwiaWQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9Vbmlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUG9seW1vcnBoaWNTY2hlbWEgZnJvbSAnLi9Qb2x5bW9ycGhpYy5qcyc7XG5cbi8qKlxuICogUmVwcmVzZW50cyBwb2x5bW9ycGhpYyB2YWx1ZXMuXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL3Jlc3QvYXBpL1VuaW9uXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFVuaW9uU2NoZW1hIGV4dGVuZHMgUG9seW1vcnBoaWNTY2hlbWEge1xuICBjb25zdHJ1Y3RvcihkZWZpbml0aW9uOiBhbnksIHNjaGVtYUF0dHJpYnV0ZTogYW55KSB7XG4gICAgaWYgKCFzY2hlbWFBdHRyaWJ1dGUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgJ0V4cGVjdGVkIG9wdGlvbiBcInNjaGVtYUF0dHJpYnV0ZVwiIG5vdCBmb3VuZCBvbiBVbmlvblNjaGVtYS4nLFxuICAgICAgKTtcbiAgICB9XG4gICAgc3VwZXIoZGVmaW5pdGlvbiwgc2NoZW1hQXR0cmlidXRlKTtcbiAgfVxuXG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiBhbnksXG4gICAgYWRkRW50aXR5OiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBhbnksXG4gICkge1xuICAgIHJldHVybiB0aGlzLm5vcm1hbGl6ZVZhbHVlKFxuICAgICAgaW5wdXQsXG4gICAgICBwYXJlbnQsXG4gICAgICBrZXksXG4gICAgICB2aXNpdCxcbiAgICAgIGFkZEVudGl0eSxcbiAgICAgIHZpc2l0ZWRFbnRpdGllcyxcbiAgICApO1xuICB9XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbiAgZGVub3JtYWxpemUoaW5wdXQ6IHt9LCB1bnZpc2l0OiBhbnkpIHtcbiAgICByZXR1cm4gdGhpcy5kZW5vcm1hbGl6ZVZhbHVlKGlucHV0LCB1bnZpc2l0KTtcbiAgfVxuXG4gIGluZmVyKGFyZ3M6IGFueSwgaW5kZXhlczogYW55LCByZWN1cnNlOiBhbnksIGVudGl0aWVzOiBhbnkpIHtcbiAgICBpZiAoIWFyZ3NbMF0pIHJldHVybiB1bmRlZmluZWQ7XG4gICAgY29uc3QgYXR0ciA9IHRoaXMuZ2V0U2NoZW1hQXR0cmlidXRlKGFyZ3NbMF0sIHVuZGVmaW5lZCwgJycpO1xuICAgIGNvbnN0IGRpc2NyaW1pbmF0ZWRTY2hlbWEgPSB0aGlzLnNjaGVtYVthdHRyXTtcblxuICAgIC8vIFdhcyB1bmFibGUgdG8gaW5mZXIgdGhlIGVudGl0eSdzIHNjaGVtYSBmcm9tIHBhcmFtc1xuICAgIGlmIChkaXNjcmltaW5hdGVkU2NoZW1hID09PSB1bmRlZmluZWQpIHJldHVybiB1bmRlZmluZWQ7XG4gICAgcmV0dXJuIHtcbiAgICAgIGlkOiByZWN1cnNlKGRpc2NyaW1pbmF0ZWRTY2hlbWEsIGFyZ3MsIGluZGV4ZXMsIGVudGl0aWVzKSxcbiAgICAgIHNjaGVtYTogYXR0cixcbiAgICB9O1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLGlCQUFpQixNQUFNLGtCQUFrQjs7QUFFaEQ7QUFDQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLE1BQU1DLFdBQVcsU0FBU0QsaUJBQWlCLENBQUM7RUFDekRFLFdBQVdBLENBQUNDLFVBQWUsRUFBRUMsZUFBb0IsRUFBRTtJQUNqRCxJQUFJLENBQUNBLGVBQWUsRUFBRTtNQUNwQixNQUFNLElBQUlDLEtBQUssQ0FDYiw2REFBNkQsQ0FDOUQ7SUFDSDtJQUNBLEtBQUssQ0FBQ0YsVUFBVSxFQUFFQyxlQUFlLENBQUM7RUFDcEM7RUFFQUUsU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEVBQ3BCO0lBQ0EsT0FBTyxJQUFJLENBQUNDLGNBQWMsQ0FDeEJOLEtBQUssRUFDTEMsTUFBTSxFQUNOQyxHQUFHLEVBQ0hDLEtBQUssRUFDTEMsU0FBUyxFQUNUQyxlQUFlLENBQ2hCO0VBQ0g7O0VBRUE7RUFDQUUsV0FBV0EsQ0FBQ1AsS0FBUyxFQUFFUSxPQUFZLEVBQUU7SUFDbkMsT0FBTyxJQUFJLENBQUNDLGdCQUFnQixDQUFDVCxLQUFLLEVBQUVRLE9BQU8sQ0FBQztFQUM5QztFQUVBRSxLQUFLQSxDQUFDQyxJQUFTLEVBQUVDLE9BQVksRUFBRUMsT0FBWSxFQUFFQyxRQUFhLEVBQUU7SUFDMUQsSUFBSSxDQUFDSCxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsT0FBT0ksU0FBUztJQUM5QixNQUFNQyxJQUFJLEdBQUcsSUFBSSxDQUFDQyxrQkFBa0IsQ0FBQ04sSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFSSxTQUFTLEVBQUUsRUFBRSxDQUFDO0lBQzVELE1BQU1HLG1CQUFtQixHQUFHLElBQUksQ0FBQ0MsTUFBTSxDQUFDSCxJQUFJLENBQUM7O0lBRTdDO0lBQ0EsSUFBSUUsbUJBQW1CLEtBQUtILFNBQVMsRUFBRSxPQUFPQSxTQUFTO0lBQ3ZELE9BQU87TUFDTEssRUFBRSxFQUFFUCxPQUFPLENBQUNLLG1CQUFtQixFQUFFUCxJQUFJLEVBQUVDLE9BQU8sRUFBRUUsUUFBUSxDQUFDO01BQ3pESyxNQUFNLEVBQUVIO0lBQ1YsQ0FBQztFQUNIO0FBQ0YifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsIlVuaW9uU2NoZW1hIiwiY29uc3RydWN0b3IiLCJkZWZpbml0aW9uIiwic2NoZW1hQXR0cmlidXRlIiwiRXJyb3IiLCJub3JtYWxpemUiLCJpbnB1dCIsInBhcmVudCIsImtleSIsInZpc2l0IiwiYWRkRW50aXR5IiwidmlzaXRlZEVudGl0aWVzIiwic3RvcmVFbnRpdGllcyIsImFyZ3MiLCJub3JtYWxpemVWYWx1ZSIsImRlbm9ybWFsaXplIiwidW52aXNpdCIsInZhbHVlIiwiZGVub3JtYWxpemVWYWx1ZSIsInVuZGVmaW5lZCIsImRlbm9ybWFsaXplT25seSIsImluZmVyIiwiaW5kZXhlcyIsInJlY3Vyc2UiLCJlbnRpdGllcyIsImF0dHIiLCJnZXRTY2hlbWFBdHRyaWJ1dGUiLCJkaXNjcmltaW5hdGVkU2NoZW1hIiwic2NoZW1hIiwiaWQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9Vbmlvbi50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUG9seW1vcnBoaWNTY2hlbWEgZnJvbSAnLi9Qb2x5bW9ycGhpYy5qcyc7XG5cbi8qKlxuICogUmVwcmVzZW50cyBwb2x5bW9ycGhpYyB2YWx1ZXMuXG4gKiBAc2VlIGh0dHBzOi8vcmVzdGhvb2tzLmlvL3Jlc3QvYXBpL1VuaW9uXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFVuaW9uU2NoZW1hIGV4dGVuZHMgUG9seW1vcnBoaWNTY2hlbWEge1xuICBjb25zdHJ1Y3RvcihkZWZpbml0aW9uOiBhbnksIHNjaGVtYUF0dHJpYnV0ZTogYW55KSB7XG4gICAgaWYgKCFzY2hlbWFBdHRyaWJ1dGUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgJ0V4cGVjdGVkIG9wdGlvbiBcInNjaGVtYUF0dHJpYnV0ZVwiIG5vdCBmb3VuZCBvbiBVbmlvblNjaGVtYS4nLFxuICAgICAgKTtcbiAgICB9XG4gICAgc3VwZXIoZGVmaW5pdGlvbiwgc2NoZW1hQXR0cmlidXRlKTtcbiAgfVxuXG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiBhbnksXG4gICAgYWRkRW50aXR5OiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBhbnksXG4gICAgc3RvcmVFbnRpdGllczogYW55LFxuICAgIGFyZ3M6IGFueVtdLFxuICApIHtcbiAgICByZXR1cm4gdGhpcy5ub3JtYWxpemVWYWx1ZShcbiAgICAgIGlucHV0LFxuICAgICAgcGFyZW50LFxuICAgICAga2V5LFxuICAgICAgdmlzaXQsXG4gICAgICBhZGRFbnRpdHksXG4gICAgICB2aXNpdGVkRW50aXRpZXMsXG4gICAgICBzdG9yZUVudGl0aWVzLFxuICAgICAgYXJncyxcbiAgICApO1xuICB9XG5cbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbiAgZGVub3JtYWxpemUoaW5wdXQ6IHt9LCB1bnZpc2l0OiBhbnkpOiBhbnkge1xuICAgIGNvbnN0IHZhbHVlID0gdGhpcy5kZW5vcm1hbGl6ZVZhbHVlKGlucHV0LCB1bnZpc2l0KTtcbiAgICByZXR1cm4gW3ZhbHVlLCB2YWx1ZSAhPT0gdW5kZWZpbmVkLCB0eXBlb2YgdmFsdWUgPT09ICdzeW1ib2wnXTtcbiAgfVxuXG4gIGRlbm9ybWFsaXplT25seShcbiAgICBpbnB1dDoge30sXG4gICAgYXJnczogcmVhZG9ubHkgYW55W10sXG4gICAgdW52aXNpdDogKGlucHV0OiBhbnksIHNjaGVtYTogYW55KSA9PiBhbnksXG4gICkge1xuICAgIHJldHVybiB0aGlzLmRlbm9ybWFsaXplVmFsdWUoaW5wdXQsIHVudmlzaXQpO1xuICB9XG5cbiAgaW5mZXIoYXJnczogYW55LCBpbmRleGVzOiBhbnksIHJlY3Vyc2U6IGFueSwgZW50aXRpZXM6IGFueSkge1xuICAgIGlmICghYXJnc1swXSkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICBjb25zdCBhdHRyID0gdGhpcy5nZXRTY2hlbWFBdHRyaWJ1dGUoYXJnc1swXSwgdW5kZWZpbmVkLCAnJyk7XG4gICAgY29uc3QgZGlzY3JpbWluYXRlZFNjaGVtYSA9IHRoaXMuc2NoZW1hW2F0dHJdO1xuXG4gICAgLy8gV2FzIHVuYWJsZSB0byBpbmZlciB0aGUgZW50aXR5J3Mgc2NoZW1hIGZyb20gcGFyYW1zXG4gICAgaWYgKGRpc2NyaW1pbmF0ZWRTY2hlbWEgPT09IHVuZGVmaW5lZCkgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICByZXR1cm4ge1xuICAgICAgaWQ6IHJlY3Vyc2UoZGlzY3JpbWluYXRlZFNjaGVtYSwgYXJncywgaW5kZXhlcywgZW50aXRpZXMpLFxuICAgICAgc2NoZW1hOiBhdHRyLFxuICAgIH07XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsaUJBQWlCLE1BQU0sa0JBQWtCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsTUFBTUMsV0FBVyxTQUFTRCxpQkFBaUIsQ0FBQztFQUN6REUsV0FBV0EsQ0FBQ0MsVUFBZSxFQUFFQyxlQUFvQixFQUFFO0lBQ2pELElBQUksQ0FBQ0EsZUFBZSxFQUFFO01BQ3BCLE1BQU0sSUFBSUMsS0FBSyxDQUNiLDZEQUE2RCxDQUM5RDtJQUNIO0lBQ0EsS0FBSyxDQUFDRixVQUFVLEVBQUVDLGVBQWUsQ0FBQztFQUNwQztFQUVBRSxTQUFTQSxDQUNQQyxLQUFVLEVBQ1ZDLE1BQVcsRUFDWEMsR0FBUSxFQUNSQyxLQUFVLEVBQ1ZDLFNBQWMsRUFDZEMsZUFBb0IsRUFDcEJDLGFBQWtCLEVBQ2xCQyxJQUFXLEVBQ1g7SUFDQSxPQUFPLElBQUksQ0FBQ0MsY0FBYyxDQUN4QlIsS0FBSyxFQUNMQyxNQUFNLEVBQ05DLEdBQUcsRUFDSEMsS0FBSyxFQUNMQyxTQUFTLEVBQ1RDLGVBQWUsRUFDZkMsYUFBYSxFQUNiQyxJQUFJLENBQ0w7RUFDSDs7RUFFQTtFQUNBRSxXQUFXQSxDQUFDVCxLQUFTLEVBQUVVLE9BQVksRUFBTztJQUN4QyxNQUFNQyxLQUFLLEdBQUcsSUFBSSxDQUFDQyxnQkFBZ0IsQ0FBQ1osS0FBSyxFQUFFVSxPQUFPLENBQUM7SUFDbkQsT0FBTyxDQUFDQyxLQUFLLEVBQUVBLEtBQUssS0FBS0UsU0FBUyxFQUFFLE9BQU9GLEtBQUssS0FBSyxRQUFRLENBQUM7RUFDaEU7RUFFQUcsZUFBZUEsQ0FDYmQsS0FBUyxFQUNUTyxJQUFvQixFQUNwQkcsT0FBeUMsRUFDekM7SUFDQSxPQUFPLElBQUksQ0FBQ0UsZ0JBQWdCLENBQUNaLEtBQUssRUFBRVUsT0FBTyxDQUFDO0VBQzlDO0VBRUFLLEtBQUtBLENBQUNSLElBQVMsRUFBRVMsT0FBWSxFQUFFQyxPQUFZLEVBQUVDLFFBQWEsRUFBRTtJQUMxRCxJQUFJLENBQUNYLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxPQUFPTSxTQUFTO0lBQzlCLE1BQU1NLElBQUksR0FBRyxJQUFJLENBQUNDLGtCQUFrQixDQUFDYixJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUVNLFNBQVMsRUFBRSxFQUFFLENBQUM7SUFDNUQsTUFBTVEsbUJBQW1CLEdBQUcsSUFBSSxDQUFDQyxNQUFNLENBQUNILElBQUksQ0FBQzs7SUFFN0M7SUFDQSxJQUFJRSxtQkFBbUIsS0FBS1IsU0FBUyxFQUFFLE9BQU9BLFNBQVM7SUFDdkQsT0FBTztNQUNMVSxFQUFFLEVBQUVOLE9BQU8sQ0FBQ0ksbUJBQW1CLEVBQUVkLElBQUksRUFBRVMsT0FBTyxFQUFFRSxRQUFRLENBQUM7TUFDekRJLE1BQU0sRUFBRUg7SUFDVixDQUFDO0VBQ0g7QUFDRiJ9 |
export declare const getValues: (input: any) => any[]; | ||
export declare const filterEmpty: ([item, , deletedItem]: any) => boolean; | ||
export declare const filterEmpty: (item: any) => boolean; | ||
//# sourceMappingURL=utils.d.ts.map |
export const getValues = input => Array.isArray(input) ? input : Object.keys(input).map(key => input[key]); | ||
export const filterEmpty = ([item,, deletedItem]) => item !== undefined && !deletedItem; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJnZXRWYWx1ZXMiLCJpbnB1dCIsIkFycmF5IiwiaXNBcnJheSIsIk9iamVjdCIsImtleXMiLCJtYXAiLCJrZXkiLCJmaWx0ZXJFbXB0eSIsIml0ZW0iLCJkZWxldGVkSXRlbSIsInVuZGVmaW5lZCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWFzL3V0aWxzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBnZXRWYWx1ZXMgPSAoaW5wdXQ6IGFueSkgPT5cbiAgQXJyYXkuaXNBcnJheShpbnB1dCkgPyBpbnB1dCA6IE9iamVjdC5rZXlzKGlucHV0KS5tYXAoa2V5ID0+IGlucHV0W2tleV0pO1xuXG5leHBvcnQgY29uc3QgZmlsdGVyRW1wdHkgPSAoW2l0ZW0sICwgZGVsZXRlZEl0ZW1dOiBhbnkpID0+XG4gIGl0ZW0gIT09IHVuZGVmaW5lZCAmJiAhZGVsZXRlZEl0ZW07XG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sTUFBTUEsU0FBUyxHQUFJQyxLQUFVLElBQ2xDQyxLQUFLLENBQUNDLE9BQU8sQ0FBQ0YsS0FBSyxDQUFDLEdBQUdBLEtBQUssR0FBR0csTUFBTSxDQUFDQyxJQUFJLENBQUNKLEtBQUssQ0FBQyxDQUFDSyxHQUFHLENBQUNDLEdBQUcsSUFBSU4sS0FBSyxDQUFDTSxHQUFHLENBQUMsQ0FBQztBQUUxRSxPQUFPLE1BQU1DLFdBQVcsR0FBR0EsQ0FBQyxDQUFDQyxJQUFJLEdBQUlDLFdBQVcsQ0FBTSxLQUNwREQsSUFBSSxLQUFLRSxTQUFTLElBQUksQ0FBQ0QsV0FBVyJ9 | ||
export const filterEmpty = item => item !== undefined && typeof item !== 'symbol'; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJnZXRWYWx1ZXMiLCJpbnB1dCIsIkFycmF5IiwiaXNBcnJheSIsIk9iamVjdCIsImtleXMiLCJtYXAiLCJrZXkiLCJmaWx0ZXJFbXB0eSIsIml0ZW0iLCJ1bmRlZmluZWQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy91dGlscy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgZ2V0VmFsdWVzID0gKGlucHV0OiBhbnkpID0+XG4gIEFycmF5LmlzQXJyYXkoaW5wdXQpID8gaW5wdXQgOiBPYmplY3Qua2V5cyhpbnB1dCkubWFwKGtleSA9PiBpbnB1dFtrZXldKTtcblxuZXhwb3J0IGNvbnN0IGZpbHRlckVtcHR5ID0gKGl0ZW06IGFueSkgPT5cbiAgaXRlbSAhPT0gdW5kZWZpbmVkICYmIHR5cGVvZiBpdGVtICE9PSAnc3ltYm9sJztcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxNQUFNQSxTQUFTLEdBQUlDLEtBQVUsSUFDbENDLEtBQUssQ0FBQ0MsT0FBTyxDQUFDRixLQUFLLENBQUMsR0FBR0EsS0FBSyxHQUFHRyxNQUFNLENBQUNDLElBQUksQ0FBQ0osS0FBSyxDQUFDLENBQUNLLEdBQUcsQ0FBQ0MsR0FBRyxJQUFJTixLQUFLLENBQUNNLEdBQUcsQ0FBQyxDQUFDO0FBRTFFLE9BQU8sTUFBTUMsV0FBVyxHQUFJQyxJQUFTLElBQ25DQSxJQUFJLEtBQUtDLFNBQVMsSUFBSSxPQUFPRCxJQUFJLEtBQUssUUFBUSJ9 |
@@ -7,6 +7,7 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ValuesSchema extends PolymorphicSchema { | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): {}; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]): {}; | ||
denormalize(input: {}, unvisit: any): {}[]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any): undefined; | ||
} | ||
//# sourceMappingURL=Values.d.ts.map |
@@ -8,3 +8,3 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ValuesSchema extends PolymorphicSchema { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities) { | ||
normalize(input, parent, key, visit, addEntity, visitedEntities, storeEntities, args) { | ||
return Object.keys(input).reduce((output, key, index) => { | ||
@@ -14,3 +14,3 @@ const value = input[key]; | ||
...output, | ||
[key]: this.normalizeValue(value, input, key, visit, addEntity, visitedEntities) | ||
[key]: this.normalizeValue(value, input, key, visit, addEntity, visitedEntities, storeEntities, args) | ||
} : output; | ||
@@ -22,14 +22,6 @@ }, {}); | ||
denormalize(input, unvisit) { | ||
let found = true; | ||
let deleted = false; | ||
return [Object.keys(input).reduce((output, key) => { | ||
const entityOrId = input[key]; | ||
const [value, foundItem, deletedItem] = this.denormalizeValue(entityOrId, unvisit); | ||
if (!foundItem) { | ||
found = false; | ||
} | ||
if (deletedItem) { | ||
deleted = true; | ||
} | ||
if (!foundItem || deletedItem) return output; | ||
const value = this.denormalizeValue(entityOrId, unvisit); | ||
if (!value || typeof value === 'symbol') return output; | ||
return { | ||
@@ -39,4 +31,17 @@ ...output, | ||
}; | ||
}, {}), found, deleted]; | ||
}, {}), true, false]; | ||
} | ||
denormalizeOnly(input, args, unvisit) { | ||
return Object.keys(input).reduce((output, key) => { | ||
const entityOrId = input[key]; | ||
const value = this.denormalizeValue(entityOrId, unvisit); | ||
// remove empty or deleted values | ||
if (!value || typeof value === 'symbol') return output; | ||
return { | ||
...output, | ||
[key]: value | ||
}; | ||
}, {}); | ||
} | ||
infer(args, indexes, recurse) { | ||
@@ -46,2 +51,2 @@ return undefined; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsIlZhbHVlc1NjaGVtYSIsIm5vcm1hbGl6ZSIsImlucHV0IiwicGFyZW50Iiwia2V5IiwidmlzaXQiLCJhZGRFbnRpdHkiLCJ2aXNpdGVkRW50aXRpZXMiLCJPYmplY3QiLCJrZXlzIiwicmVkdWNlIiwib3V0cHV0IiwiaW5kZXgiLCJ2YWx1ZSIsInVuZGVmaW5lZCIsIm5vcm1hbGl6ZVZhbHVlIiwiZGVub3JtYWxpemUiLCJ1bnZpc2l0IiwiZm91bmQiLCJkZWxldGVkIiwiZW50aXR5T3JJZCIsImZvdW5kSXRlbSIsImRlbGV0ZWRJdGVtIiwiZGVub3JtYWxpemVWYWx1ZSIsImluZmVyIiwiYXJncyIsImluZGV4ZXMiLCJyZWN1cnNlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjaGVtYXMvVmFsdWVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQb2x5bW9ycGhpY1NjaGVtYSBmcm9tICcuL1BvbHltb3JwaGljLmpzJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIHZhcmlhYmx5IHNpemVkIG9iamVjdHNcbiAqIEBzZWUgaHR0cHM6Ly9yZXN0aG9va3MuaW8vcmVzdC9hcGkvVmFsdWVzXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIFZhbHVlc1NjaGVtYSBleHRlbmRzIFBvbHltb3JwaGljU2NoZW1hIHtcbiAgbm9ybWFsaXplKFxuICAgIGlucHV0OiBhbnksXG4gICAgcGFyZW50OiBhbnksXG4gICAga2V5OiBhbnksXG4gICAgdmlzaXQ6IGFueSxcbiAgICBhZGRFbnRpdHk6IGFueSxcbiAgICB2aXNpdGVkRW50aXRpZXM6IGFueSxcbiAgKSB7XG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKGlucHV0KS5yZWR1Y2UoKG91dHB1dCwga2V5LCBpbmRleCkgPT4ge1xuICAgICAgY29uc3QgdmFsdWUgPSBpbnB1dFtrZXldO1xuICAgICAgcmV0dXJuIHZhbHVlICE9PSB1bmRlZmluZWQgJiYgdmFsdWUgIT09IG51bGxcbiAgICAgICAgPyB7XG4gICAgICAgICAgICAuLi5vdXRwdXQsXG4gICAgICAgICAgICBba2V5XTogdGhpcy5ub3JtYWxpemVWYWx1ZShcbiAgICAgICAgICAgICAgdmFsdWUsXG4gICAgICAgICAgICAgIGlucHV0LFxuICAgICAgICAgICAgICBrZXksXG4gICAgICAgICAgICAgIHZpc2l0LFxuICAgICAgICAgICAgICBhZGRFbnRpdHksXG4gICAgICAgICAgICAgIHZpc2l0ZWRFbnRpdGllcyxcbiAgICAgICAgICAgICksXG4gICAgICAgICAgfVxuICAgICAgICA6IG91dHB1dDtcbiAgICB9LCB7fSk7XG4gIH1cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuICBkZW5vcm1hbGl6ZShpbnB1dDoge30sIHVudmlzaXQ6IGFueSkge1xuICAgIGxldCBmb3VuZCA9IHRydWU7XG4gICAgbGV0IGRlbGV0ZWQgPSBmYWxzZTtcbiAgICByZXR1cm4gW1xuICAgICAgT2JqZWN0LmtleXMoaW5wdXQpLnJlZHVjZSgob3V0cHV0LCBrZXkpID0+IHtcbiAgICAgICAgY29uc3QgZW50aXR5T3JJZCA9IChpbnB1dCBhcyBhbnkpW2tleV07XG4gICAgICAgIGNvbnN0IFt2YWx1ZSwgZm91bmRJdGVtLCBkZWxldGVkSXRlbV0gPSB0aGlzLmRlbm9ybWFsaXplVmFsdWUoXG4gICAgICAgICAgZW50aXR5T3JJZCxcbiAgICAgICAgICB1bnZpc2l0LFxuICAgICAgICApO1xuICAgICAgICBpZiAoIWZvdW5kSXRlbSkge1xuICAgICAgICAgIGZvdW5kID0gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGRlbGV0ZWRJdGVtKSB7XG4gICAgICAgICAgZGVsZXRlZCA9IHRydWU7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCFmb3VuZEl0ZW0gfHwgZGVsZXRlZEl0ZW0pIHJldHVybiBvdXRwdXQ7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgLi4ub3V0cHV0LFxuICAgICAgICAgIFtrZXldOiB2YWx1ZSxcbiAgICAgICAgfTtcbiAgICAgIH0sIHt9KSxcbiAgICAgIGZvdW5kLFxuICAgICAgZGVsZXRlZCxcbiAgICBdO1xuICB9XG5cbiAgaW5mZXIoYXJnczogYW55LCBpbmRleGVzOiBhbnksIHJlY3Vyc2U6IGFueSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsaUJBQWlCLE1BQU0sa0JBQWtCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsTUFBTUMsWUFBWSxTQUFTRCxpQkFBaUIsQ0FBQztFQUMxREUsU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEVBQ3BCO0lBQ0EsT0FBT0MsTUFBTSxDQUFDQyxJQUFJLENBQUNQLEtBQUssQ0FBQyxDQUFDUSxNQUFNLENBQUMsQ0FBQ0MsTUFBTSxFQUFFUCxHQUFHLEVBQUVRLEtBQUssS0FBSztNQUN2RCxNQUFNQyxLQUFLLEdBQUdYLEtBQUssQ0FBQ0UsR0FBRyxDQUFDO01BQ3hCLE9BQU9TLEtBQUssS0FBS0MsU0FBUyxJQUFJRCxLQUFLLEtBQUssSUFBSSxHQUN4QztRQUNFLEdBQUdGLE1BQU07UUFDVCxDQUFDUCxHQUFHLEdBQUcsSUFBSSxDQUFDVyxjQUFjLENBQ3hCRixLQUFLLEVBQ0xYLEtBQUssRUFDTEUsR0FBRyxFQUNIQyxLQUFLLEVBQ0xDLFNBQVMsRUFDVEMsZUFBZTtNQUVuQixDQUFDLEdBQ0RJLE1BQU07SUFDWixDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7RUFDUjs7RUFFQTtFQUNBSyxXQUFXQSxDQUFDZCxLQUFTLEVBQUVlLE9BQVksRUFBRTtJQUNuQyxJQUFJQyxLQUFLLEdBQUcsSUFBSTtJQUNoQixJQUFJQyxPQUFPLEdBQUcsS0FBSztJQUNuQixPQUFPLENBQ0xYLE1BQU0sQ0FBQ0MsSUFBSSxDQUFDUCxLQUFLLENBQUMsQ0FBQ1EsTUFBTSxDQUFDLENBQUNDLE1BQU0sRUFBRVAsR0FBRyxLQUFLO01BQ3pDLE1BQU1nQixVQUFVLEdBQUlsQixLQUFLLENBQVNFLEdBQUcsQ0FBQztNQUN0QyxNQUFNLENBQUNTLEtBQUssRUFBRVEsU0FBUyxFQUFFQyxXQUFXLENBQUMsR0FBRyxJQUFJLENBQUNDLGdCQUFnQixDQUMzREgsVUFBVSxFQUNWSCxPQUFPLENBQ1I7TUFDRCxJQUFJLENBQUNJLFNBQVMsRUFBRTtRQUNkSCxLQUFLLEdBQUcsS0FBSztNQUNmO01BQ0EsSUFBSUksV0FBVyxFQUFFO1FBQ2ZILE9BQU8sR0FBRyxJQUFJO01BQ2hCO01BQ0EsSUFBSSxDQUFDRSxTQUFTLElBQUlDLFdBQVcsRUFBRSxPQUFPWCxNQUFNO01BQzVDLE9BQU87UUFDTCxHQUFHQSxNQUFNO1FBQ1QsQ0FBQ1AsR0FBRyxHQUFHUztNQUNULENBQUM7SUFDSCxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFDTkssS0FBSyxFQUNMQyxPQUFPLENBQ1I7RUFDSDtFQUVBSyxLQUFLQSxDQUFDQyxJQUFTLEVBQUVDLE9BQVksRUFBRUMsT0FBWSxFQUFFO0lBQzNDLE9BQU9iLFNBQVM7RUFDbEI7QUFDRiJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJQb2x5bW9ycGhpY1NjaGVtYSIsIlZhbHVlc1NjaGVtYSIsIm5vcm1hbGl6ZSIsImlucHV0IiwicGFyZW50Iiwia2V5IiwidmlzaXQiLCJhZGRFbnRpdHkiLCJ2aXNpdGVkRW50aXRpZXMiLCJzdG9yZUVudGl0aWVzIiwiYXJncyIsIk9iamVjdCIsImtleXMiLCJyZWR1Y2UiLCJvdXRwdXQiLCJpbmRleCIsInZhbHVlIiwidW5kZWZpbmVkIiwibm9ybWFsaXplVmFsdWUiLCJkZW5vcm1hbGl6ZSIsInVudmlzaXQiLCJlbnRpdHlPcklkIiwiZGVub3JtYWxpemVWYWx1ZSIsImRlbm9ybWFsaXplT25seSIsImluZmVyIiwiaW5kZXhlcyIsInJlY3Vyc2UiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NoZW1hcy9WYWx1ZXMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFBvbHltb3JwaGljU2NoZW1hIGZyb20gJy4vUG9seW1vcnBoaWMuanMnO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgdmFyaWFibHkgc2l6ZWQgb2JqZWN0c1xuICogQHNlZSBodHRwczovL3Jlc3Rob29rcy5pby9yZXN0L2FwaS9WYWx1ZXNcbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgVmFsdWVzU2NoZW1hIGV4dGVuZHMgUG9seW1vcnBoaWNTY2hlbWEge1xuICBub3JtYWxpemUoXG4gICAgaW5wdXQ6IGFueSxcbiAgICBwYXJlbnQ6IGFueSxcbiAgICBrZXk6IGFueSxcbiAgICB2aXNpdDogYW55LFxuICAgIGFkZEVudGl0eTogYW55LFxuICAgIHZpc2l0ZWRFbnRpdGllczogYW55LFxuICAgIHN0b3JlRW50aXRpZXM6IGFueSxcbiAgICBhcmdzOiBhbnlbXSxcbiAgKSB7XG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKGlucHV0KS5yZWR1Y2UoKG91dHB1dCwga2V5LCBpbmRleCkgPT4ge1xuICAgICAgY29uc3QgdmFsdWUgPSBpbnB1dFtrZXldO1xuICAgICAgcmV0dXJuIHZhbHVlICE9PSB1bmRlZmluZWQgJiYgdmFsdWUgIT09IG51bGxcbiAgICAgICAgPyB7XG4gICAgICAgICAgICAuLi5vdXRwdXQsXG4gICAgICAgICAgICBba2V5XTogdGhpcy5ub3JtYWxpemVWYWx1ZShcbiAgICAgICAgICAgICAgdmFsdWUsXG4gICAgICAgICAgICAgIGlucHV0LFxuICAgICAgICAgICAgICBrZXksXG4gICAgICAgICAgICAgIHZpc2l0LFxuICAgICAgICAgICAgICBhZGRFbnRpdHksXG4gICAgICAgICAgICAgIHZpc2l0ZWRFbnRpdGllcyxcbiAgICAgICAgICAgICAgc3RvcmVFbnRpdGllcyxcbiAgICAgICAgICAgICAgYXJncyxcbiAgICAgICAgICAgICksXG4gICAgICAgICAgfVxuICAgICAgICA6IG91dHB1dDtcbiAgICB9LCB7fSk7XG4gIH1cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L2Jhbi10eXBlc1xuICBkZW5vcm1hbGl6ZShpbnB1dDoge30sIHVudmlzaXQ6IGFueSkge1xuICAgIHJldHVybiBbXG4gICAgICBPYmplY3Qua2V5cyhpbnB1dCkucmVkdWNlKChvdXRwdXQsIGtleSkgPT4ge1xuICAgICAgICBjb25zdCBlbnRpdHlPcklkID0gKGlucHV0IGFzIGFueSlba2V5XTtcbiAgICAgICAgY29uc3QgdmFsdWUgPSB0aGlzLmRlbm9ybWFsaXplVmFsdWUoZW50aXR5T3JJZCwgdW52aXNpdCk7XG4gICAgICAgIGlmICghdmFsdWUgfHwgdHlwZW9mIHZhbHVlID09PSAnc3ltYm9sJykgcmV0dXJuIG91dHB1dDtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAuLi5vdXRwdXQsXG4gICAgICAgICAgW2tleV06IHZhbHVlLFxuICAgICAgICB9O1xuICAgICAgfSwge30pLFxuICAgICAgdHJ1ZSxcbiAgICAgIGZhbHNlLFxuICAgIF07XG4gIH1cblxuICBkZW5vcm1hbGl6ZU9ubHkoXG4gICAgaW5wdXQ6IHt9LFxuICAgIGFyZ3M6IHJlYWRvbmx5IGFueVtdLFxuICAgIHVudmlzaXQ6IChpbnB1dDogYW55LCBzY2hlbWE6IGFueSkgPT4gYW55LFxuICApOiBhbnkge1xuICAgIHJldHVybiBPYmplY3Qua2V5cyhpbnB1dCkucmVkdWNlKChvdXRwdXQsIGtleSkgPT4ge1xuICAgICAgY29uc3QgZW50aXR5T3JJZCA9IChpbnB1dCBhcyBhbnkpW2tleV07XG4gICAgICBjb25zdCB2YWx1ZSA9IHRoaXMuZGVub3JtYWxpemVWYWx1ZShlbnRpdHlPcklkLCB1bnZpc2l0KTtcblxuICAgICAgLy8gcmVtb3ZlIGVtcHR5IG9yIGRlbGV0ZWQgdmFsdWVzXG4gICAgICBpZiAoIXZhbHVlIHx8IHR5cGVvZiB2YWx1ZSA9PT0gJ3N5bWJvbCcpIHJldHVybiBvdXRwdXQ7XG4gICAgICByZXR1cm4ge1xuICAgICAgICAuLi5vdXRwdXQsXG4gICAgICAgIFtrZXldOiB2YWx1ZSxcbiAgICAgIH07XG4gICAgfSwge30pO1xuICB9XG5cbiAgaW5mZXIoYXJnczogYW55LCBpbmRleGVzOiBhbnksIHJlY3Vyc2U6IGFueSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsaUJBQWlCLE1BQU0sa0JBQWtCOztBQUVoRDtBQUNBO0FBQ0E7QUFDQTtBQUNBLGVBQWUsTUFBTUMsWUFBWSxTQUFTRCxpQkFBaUIsQ0FBQztFQUMxREUsU0FBU0EsQ0FDUEMsS0FBVSxFQUNWQyxNQUFXLEVBQ1hDLEdBQVEsRUFDUkMsS0FBVSxFQUNWQyxTQUFjLEVBQ2RDLGVBQW9CLEVBQ3BCQyxhQUFrQixFQUNsQkMsSUFBVyxFQUNYO0lBQ0EsT0FBT0MsTUFBTSxDQUFDQyxJQUFJLENBQUNULEtBQUssQ0FBQyxDQUFDVSxNQUFNLENBQUMsQ0FBQ0MsTUFBTSxFQUFFVCxHQUFHLEVBQUVVLEtBQUssS0FBSztNQUN2RCxNQUFNQyxLQUFLLEdBQUdiLEtBQUssQ0FBQ0UsR0FBRyxDQUFDO01BQ3hCLE9BQU9XLEtBQUssS0FBS0MsU0FBUyxJQUFJRCxLQUFLLEtBQUssSUFBSSxHQUN4QztRQUNFLEdBQUdGLE1BQU07UUFDVCxDQUFDVCxHQUFHLEdBQUcsSUFBSSxDQUFDYSxjQUFjLENBQ3hCRixLQUFLLEVBQ0xiLEtBQUssRUFDTEUsR0FBRyxFQUNIQyxLQUFLLEVBQ0xDLFNBQVMsRUFDVEMsZUFBZSxFQUNmQyxhQUFhLEVBQ2JDLElBQUk7TUFFUixDQUFDLEdBQ0RJLE1BQU07SUFDWixDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7RUFDUjs7RUFFQTtFQUNBSyxXQUFXQSxDQUFDaEIsS0FBUyxFQUFFaUIsT0FBWSxFQUFFO0lBQ25DLE9BQU8sQ0FDTFQsTUFBTSxDQUFDQyxJQUFJLENBQUNULEtBQUssQ0FBQyxDQUFDVSxNQUFNLENBQUMsQ0FBQ0MsTUFBTSxFQUFFVCxHQUFHLEtBQUs7TUFDekMsTUFBTWdCLFVBQVUsR0FBSWxCLEtBQUssQ0FBU0UsR0FBRyxDQUFDO01BQ3RDLE1BQU1XLEtBQUssR0FBRyxJQUFJLENBQUNNLGdCQUFnQixDQUFDRCxVQUFVLEVBQUVELE9BQU8sQ0FBQztNQUN4RCxJQUFJLENBQUNKLEtBQUssSUFBSSxPQUFPQSxLQUFLLEtBQUssUUFBUSxFQUFFLE9BQU9GLE1BQU07TUFDdEQsT0FBTztRQUNMLEdBQUdBLE1BQU07UUFDVCxDQUFDVCxHQUFHLEdBQUdXO01BQ1QsQ0FBQztJQUNILENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUNOLElBQUksRUFDSixLQUFLLENBQ047RUFDSDtFQUVBTyxlQUFlQSxDQUNicEIsS0FBUyxFQUNUTyxJQUFvQixFQUNwQlUsT0FBeUMsRUFDcEM7SUFDTCxPQUFPVCxNQUFNLENBQUNDLElBQUksQ0FBQ1QsS0FBSyxDQUFDLENBQUNVLE1BQU0sQ0FBQyxDQUFDQyxNQUFNLEVBQUVULEdBQUcsS0FBSztNQUNoRCxNQUFNZ0IsVUFBVSxHQUFJbEIsS0FBSyxDQUFTRSxHQUFHLENBQUM7TUFDdEMsTUFBTVcsS0FBSyxHQUFHLElBQUksQ0FBQ00sZ0JBQWdCLENBQUNELFVBQVUsRUFBRUQsT0FBTyxDQUFDOztNQUV4RDtNQUNBLElBQUksQ0FBQ0osS0FBSyxJQUFJLE9BQU9BLEtBQUssS0FBSyxRQUFRLEVBQUUsT0FBT0YsTUFBTTtNQUN0RCxPQUFPO1FBQ0wsR0FBR0EsTUFBTTtRQUNULENBQUNULEdBQUcsR0FBR1c7TUFDVCxDQUFDO0lBQ0gsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0VBQ1I7RUFFQVEsS0FBS0EsQ0FBQ2QsSUFBUyxFQUFFZSxPQUFZLEVBQUVDLE9BQVksRUFBRTtJQUMzQyxPQUFPVCxTQUFTO0VBQ2xCO0FBQ0YifQ== |
export declare const DELETED: unique symbol; | ||
export declare const INVALID: symbol; | ||
//# sourceMappingURL=special.d.ts.map |
export const DELETED = Symbol('ENTITY WAS DELETED'); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJERUxFVEVEIiwiU3ltYm9sIl0sInNvdXJjZXMiOlsiLi4vc3JjL3NwZWNpYWwudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IERFTEVURUQgPSBTeW1ib2woJ0VOVElUWSBXQVMgREVMRVRFRCcpO1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU1BLE9BQU8sR0FBR0MsTUFBTSxDQUFDLG9CQUFvQixDQUFDIn0= | ||
export const INVALID = DELETED; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJERUxFVEVEIiwiU3ltYm9sIiwiSU5WQUxJRCJdLCJzb3VyY2VzIjpbIi4uL3NyYy9zcGVjaWFsLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBERUxFVEVEID0gU3ltYm9sKCdFTlRJVFkgV0FTIERFTEVURUQnKTtcbmV4cG9ydCBjb25zdCBJTlZBTElEID0gREVMRVRFRDtcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxNQUFNQSxPQUFPLEdBQUdDLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQztBQUNuRCxPQUFPLE1BQU1DLE9BQU8sR0FBR0YsT0FBTyJ9 |
export * from './utility.js'; | ||
export * from './ErrorTypes.js'; | ||
// This hack is only needed for @rest-hooks/rest@5 or below | ||
/** @deprecated */ | ||
/** @deprecated */ | ||
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU2NoZW1hLCBFbnRpdHlJbnRlcmZhY2UgfSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IFNjaGVtYUNsYXNzIH0gZnJvbSAnLi9zY2hlbWEuanMnO1xuaW1wb3J0IHsgU25hcHNob3RJbnRlcmZhY2UgfSBmcm9tICcuL1NuYXBzaG90SW50ZXJmYWNlLmpzJztcbmltcG9ydCB7IFJlc29sdmVUeXBlIH0gZnJvbSAnLi91dGlsaXR5LmpzJztcblxuZXhwb3J0ICogZnJvbSAnLi91dGlsaXR5LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vRXJyb3JUeXBlcy5qcyc7XG5cbmV4cG9ydCB0eXBlIEZldGNoRnVuY3Rpb248QSBleHRlbmRzIHJlYWRvbmx5IGFueVtdID0gYW55LCBSID0gYW55PiA9IChcbiAgLi4uYXJnczogQVxuKSA9PiBQcm9taXNlPFI+O1xuXG4vLyBUaGlzIGhhY2sgaXMgb25seSBuZWVkZWQgZm9yIEByZXN0LWhvb2tzL3Jlc3RANSBvciBiZWxvd1xuLyoqIEBkZXByZWNhdGVkICovXG5leHBvcnQgdHlwZSBTY2hlbWFEZXRhaWw8VD4gPVxuICB8IEVudGl0eUludGVyZmFjZTxUPlxuICB8IHsgW0s6IHN0cmluZ106IGFueSB9XG4gIHwgU2NoZW1hQ2xhc3M7XG5cbi8qKiBAZGVwcmVjYXRlZCAqL1xuZXhwb3J0IHR5cGUgU2NoZW1hTGlzdDxUPiA9XG4gIHwgRW50aXR5SW50ZXJmYWNlPFQ+W11cbiAgfCB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICB8IFNjaGVtYVtdXG4gIHwgU2NoZW1hQ2xhc3M7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW5kcG9pbnRFeHRyYU9wdGlvbnM8RiBleHRlbmRzIEZldGNoRnVuY3Rpb24gPSBGZXRjaEZ1bmN0aW9uPiB7XG4gIC8qKiBEZWZhdWx0IGRhdGEgZXhwaXJ5IGxlbmd0aCwgd2lsbCBmYWxsIGJhY2sgdG8gTmV0d29ya01hbmFnZXIgZGVmYXVsdCBpZiBub3QgZGVmaW5lZCAqL1xuICByZWFkb25seSBkYXRhRXhwaXJ5TGVuZ3RoPzogbnVtYmVyO1xuICAvKiogRGVmYXVsdCBlcnJvciBleHBpcnkgbGVuZ3RoLCB3aWxsIGZhbGwgYmFjayB0byBOZXR3b3JrTWFuYWdlciBkZWZhdWx0IGlmIG5vdCBkZWZpbmVkICovXG4gIHJlYWRvbmx5IGVycm9yRXhwaXJ5TGVuZ3RoPzogbnVtYmVyO1xuICAvKiogUG9sbCB3aXRoIGF0IGxlYXN0IHRoaXMgZnJlcXVlbmN5IGluIG1pbGlzZWNvbmRzICovXG4gIHJlYWRvbmx5IHBvbGxGcmVxdWVuY3k/OiBudW1iZXI7XG4gIC8qKiBNYXJrcyBjYWNoZWQgcmVzb3VyY2VzIGFzIGludmFsaWQgaWYgdGhleSBhcmUgc3RhbGUgKi9cbiAgcmVhZG9ubHkgaW52YWxpZElmU3RhbGU/OiBib29sZWFuO1xuICAvKiogRW5hYmxlcyBvcHRpbWlzdGljIHVwZGF0ZXMgZm9yIHRoaXMgcmVxdWVzdCAtIHVzZXMgcmV0dXJuIHZhbHVlIGFzIGFzc3VtZWQgbmV0d29yayByZXNwb25zZVxuICAgKiBAZGVwcmVjYXRlZCB1c2UgaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9hcGkvRW5kcG9pbnQjZ2V0b3B0aW1pc3RpY3Jlc3BvbnNlIGluc3RlYWRcbiAgICovXG4gIG9wdGltaXN0aWNVcGRhdGU/KC4uLmFyZ3M6IFBhcmFtZXRlcnM8Rj4pOiBSZXNvbHZlVHlwZTxGPjtcbiAgLyoqIEVuYWJsZXMgb3B0aW1pc3RpYyB1cGRhdGVzIGZvciB0aGlzIHJlcXVlc3QgLSB1c2VzIHJldHVybiB2YWx1ZSBhcyBhc3N1bWVkIG5ldHdvcmsgcmVzcG9uc2UgKi9cbiAgZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlPyhcbiAgICBzbmFwOiBTbmFwc2hvdEludGVyZmFjZSxcbiAgICAuLi5hcmdzOiBQYXJhbWV0ZXJzPEY+XG4gICk6IFJlc29sdmVUeXBlPEY+O1xuICAvKiogRGV0ZXJtaW5lcyB3aGV0aGVyIHRvIHRocm93IG9yIGZhbGxiYWNrIHRvICovXG4gIGVycm9yUG9saWN5PyhlcnJvcjogYW55KTogJ2hhcmQnIHwgJ3NvZnQnIHwgdW5kZWZpbmVkO1xuICAvKiogVXNlci1sYW5kIGV4dHJhIGRhdGEgdG8gc2VuZCAqL1xuICByZWFkb25seSBleHRyYT86IGFueTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBS0EsY0FBYyxjQUFjO0FBQzVCLGNBQWMsaUJBQWlCO0FBQUMifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU2NoZW1hLCBFbnRpdHlJbnRlcmZhY2UgfSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgdHlwZSB7IFNjaGVtYUNsYXNzIH0gZnJvbSAnLi9zY2hlbWEuanMnO1xuaW1wb3J0IHsgU25hcHNob3RJbnRlcmZhY2UgfSBmcm9tICcuL1NuYXBzaG90SW50ZXJmYWNlLmpzJztcbmltcG9ydCB7IFJlc29sdmVUeXBlIH0gZnJvbSAnLi91dGlsaXR5LmpzJztcblxuZXhwb3J0ICogZnJvbSAnLi91dGlsaXR5LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vRXJyb3JUeXBlcy5qcyc7XG5cbmV4cG9ydCB0eXBlIEZldGNoRnVuY3Rpb248QSBleHRlbmRzIHJlYWRvbmx5IGFueVtdID0gYW55LCBSID0gYW55PiA9IChcbiAgLi4uYXJnczogQVxuKSA9PiBQcm9taXNlPFI+O1xuXG4vLyBUaGlzIGhhY2sgaXMgb25seSBuZWVkZWQgZm9yIEByZXN0LWhvb2tzL3Jlc3RANSBvciBiZWxvd1xuLyoqIEBkZXByZWNhdGVkICovXG5leHBvcnQgdHlwZSBTY2hlbWFEZXRhaWw8VD4gPVxuICB8IEVudGl0eUludGVyZmFjZTxUPlxuICB8IHsgW0s6IHN0cmluZ106IGFueSB9XG4gIHwgU2NoZW1hQ2xhc3M7XG5cbi8qKiBAZGVwcmVjYXRlZCAqL1xuZXhwb3J0IHR5cGUgU2NoZW1hTGlzdDxUPiA9XG4gIHwgRW50aXR5SW50ZXJmYWNlPFQ+W11cbiAgfCB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICB8IFNjaGVtYVtdXG4gIHwgU2NoZW1hQ2xhc3M7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW5kcG9pbnRFeHRyYU9wdGlvbnM8RiBleHRlbmRzIEZldGNoRnVuY3Rpb24gPSBGZXRjaEZ1bmN0aW9uPiB7XG4gIC8qKiBEZWZhdWx0IGRhdGEgZXhwaXJ5IGxlbmd0aCwgd2lsbCBmYWxsIGJhY2sgdG8gTmV0d29ya01hbmFnZXIgZGVmYXVsdCBpZiBub3QgZGVmaW5lZCAqL1xuICByZWFkb25seSBkYXRhRXhwaXJ5TGVuZ3RoPzogbnVtYmVyO1xuICAvKiogRGVmYXVsdCBlcnJvciBleHBpcnkgbGVuZ3RoLCB3aWxsIGZhbGwgYmFjayB0byBOZXR3b3JrTWFuYWdlciBkZWZhdWx0IGlmIG5vdCBkZWZpbmVkICovXG4gIHJlYWRvbmx5IGVycm9yRXhwaXJ5TGVuZ3RoPzogbnVtYmVyO1xuICAvKiogUG9sbCB3aXRoIGF0IGxlYXN0IHRoaXMgZnJlcXVlbmN5IGluIG1pbGlzZWNvbmRzICovXG4gIHJlYWRvbmx5IHBvbGxGcmVxdWVuY3k/OiBudW1iZXI7XG4gIC8qKiBNYXJrcyBjYWNoZWQgcmVzb3VyY2VzIGFzIGludmFsaWQgaWYgdGhleSBhcmUgc3RhbGUgKi9cbiAgcmVhZG9ubHkgaW52YWxpZElmU3RhbGU/OiBib29sZWFuO1xuICAvKiogRW5hYmxlcyBvcHRpbWlzdGljIHVwZGF0ZXMgZm9yIHRoaXMgcmVxdWVzdCAtIHVzZXMgcmV0dXJuIHZhbHVlIGFzIGFzc3VtZWQgbmV0d29yayByZXNwb25zZVxuICAgKiBAZGVwcmVjYXRlZCB1c2UgaHR0cHM6Ly9yZXN0aG9va3MuaW8vZG9jcy9hcGkvRW5kcG9pbnQjZ2V0b3B0aW1pc3RpY3Jlc3BvbnNlIGluc3RlYWRcbiAgICovXG4gIG9wdGltaXN0aWNVcGRhdGU/KC4uLmFyZ3M6IFBhcmFtZXRlcnM8Rj4pOiBSZXNvbHZlVHlwZTxGPjtcbiAgLyoqIEVuYWJsZXMgb3B0aW1pc3RpYyB1cGRhdGVzIGZvciB0aGlzIHJlcXVlc3QgLSB1c2VzIHJldHVybiB2YWx1ZSBhcyBhc3N1bWVkIG5ldHdvcmsgcmVzcG9uc2UgKi9cbiAgZ2V0T3B0aW1pc3RpY1Jlc3BvbnNlPyhcbiAgICBzbmFwOiBTbmFwc2hvdEludGVyZmFjZSxcbiAgICAuLi5hcmdzOiBQYXJhbWV0ZXJzPEY+XG4gICk6IFJlc29sdmVUeXBlPEY+O1xuICAvKiogRGV0ZXJtaW5lcyB3aGV0aGVyIHRvIHRocm93IG9yIGZhbGxiYWNrIHRvICovXG4gIGVycm9yUG9saWN5PyhlcnJvcjogYW55KTogJ2hhcmQnIHwgJ3NvZnQnIHwgdW5kZWZpbmVkO1xuICAvKiogVXNlci1sYW5kIGV4dHJhIGRhdGEgdG8gc2VuZCAqL1xuICByZWFkb25seSBleHRyYT86IGFueTtcbn1cbiJdLCJtYXBwaW5ncyI6IkFBS0EsY0FBYyxjQUFjO0FBQzVCLGNBQWMsaUJBQWlCOztBQU0vQjtBQUNBO0FBTUE7QUFBQSJ9 |
{ | ||
"name": "@rest-hooks/endpoint", | ||
"version": "3.7.4", | ||
"version": "3.8.0-next.0", | ||
"description": "Declarative Network Interface Definitions", | ||
@@ -71,16 +71,15 @@ "sideEffects": false, | ||
"scripts": { | ||
"build:lib": "NODE_ENV=production BROWSERSLIST_ENV='2020' babel --root-mode upward src --out-dir lib --extensions '.ts,.tsx,.js' --ignore '**/__tests__/**' --ignore '**/*.d.ts'", | ||
"build:legacy:lib": "NODE_ENV=production BROWSERSLIST_ENV='2018' babel --root-mode upward src --out-dir legacy --extensions '.ts,.tsx,.js' --ignore '**/__tests__/**' --ignore '**/*.d.ts'", | ||
"build:js:node": "BROWSERSLIST_ENV=node12 rollup -c && echo '{\"type\":\"commonjs\"}' > dist/package.json", | ||
"build:js:browser": "BROWSERSLIST_ENV=legacy rollup -c", | ||
"build:bundle": "run-s build:js:\\*", | ||
"build:clean": "rimraf lib dist legacy ts3.4 ts4.0 ts4.2 *.tsbuildinfo", | ||
"build": "yarn run build:lib && yarn run build:legacy:lib && yarn run build:bundle", | ||
"build:legacy-types": "yarn run downlevel-dts lib ts3.4 && yarn run downlevel-dts lib ts4.0 --to=4.0 && yarn run downlevel-dts lib ts4.2 --to=4.2 && copyfiles --up 1 ./src-4.2-types/**/*.d.ts ./ts4.0/ && copyfiles --up 1 ./src-4.2-types/**/*.d.ts ./ts4.2 && copyfiles --up 1 ./src-4.0-types/**/*.d.ts ./ts3.4/ && copyfiles --up 1 ./src-4.0-types/**/*.d.ts ./ts4.0 && copyfiles --up 1 ./src-legacy-types/**/*.d.ts ./ts3.4/", | ||
"dev": "yarn run build:lib -w", | ||
"prepare": "yarn run build:lib", | ||
"prepack": "yarn prepare", | ||
"prepublishOnly": "yarn run build:bundle && yarn run build:legacy:lib", | ||
"tsc:ci": "tsc --project tsconfig.test.json", | ||
"typecheck": "yarn run tsc:ci" | ||
"build:lib": "NODE_ENV=production BROWSERSLIST_ENV='2020' yarn g:babel --out-dir lib --ignore 'src/schemas-3.7'", | ||
"build:legacy:lib": "NODE_ENV=production BROWSERSLIST_ENV='2018' yarn g:babel --out-dir legacy --ignore 'src/schemas-3.7'", | ||
"build:js:node": "BROWSERSLIST_ENV=node12 yarn g:rollup && echo '{\"type\":\"commonjs\"}' > dist/package.json", | ||
"build:js:browser": "BROWSERSLIST_ENV=legacy yarn g:rollup", | ||
"build:bundle": "yarn g:runs build:js:\\*", | ||
"build:clean": "yarn g:clean ts4.0 ts4.2", | ||
"build": "run build:lib && run build:legacy:lib && run build:bundle", | ||
"build:legacy-types": "yarn g:downtypes lib ts3.4 && yarn g:downtypes lib ts4.0 --to=4.0 && yarn g:downtypes lib ts4.2 --to=4.2 && yarn g:copy --up 1 ./src-4.2-types/**/*.d.ts ./ts4.0/ && yarn g:copy --up 1 ./src-4.2-types/**/*.d.ts ./ts4.2 && yarn g:copy --up 1 ./src-4.0-types/**/*.d.ts ./ts3.4/ && yarn g:copy --up 1 ./src-4.0-types/**/*.d.ts ./ts4.0 && yarn g:copy --up 1 ./src-legacy-types/**/*.d.ts ./ts3.4/", | ||
"dev": "run build:lib -w", | ||
"prepare": "run build:lib", | ||
"prepack": "run prepare && run build:bundle && run build:legacy:lib", | ||
"tsc:ci": "yarn g:tsc --project tsconfig.test.json", | ||
"typecheck": "run tsc:ci" | ||
}, | ||
@@ -124,18 +123,5 @@ "keywords": [ | ||
"devDependencies": { | ||
"@babel/cli": "7.21.0", | ||
"@babel/core": "7.21.3", | ||
"@types/babel__core": "^7", | ||
"downlevel-dts": "^0.10.0", | ||
"npm-run-all": "^4.1.5", | ||
"rollup": "2.79.1", | ||
"rollup-plugin-babel": "^4.4.0", | ||
"rollup-plugin-commonjs": "^10.1.0", | ||
"rollup-plugin-filesize": "^9.1.2", | ||
"rollup-plugin-json": "^4.0.0", | ||
"rollup-plugin-node-resolve": "^5.2.0", | ||
"rollup-plugin-replace": "^2.2.0", | ||
"rollup-plugin-terser": "^7.0.2", | ||
"typescript": "5.0.2" | ||
}, | ||
"gitHead": "37f056da08be038bc1c6ffabcbad140cd42c6346" | ||
"@anansi/browserslist-config": "^1.4.2", | ||
"@types/node": "^18.15.10" | ||
} | ||
} |
@@ -17,28 +17,68 @@ # TypeScript Standard Endpoints | ||
### 1) Define the function | ||
## Usage | ||
### 1) Take any class and async functions | ||
```typescript | ||
import { Endpoint } from '@rest-hooks/endpoint'; | ||
export class Todo { | ||
id = 0; | ||
userId = 0; | ||
title = ''; | ||
completed = false; | ||
} | ||
const fetchUser = ({ id }) ⇒ fetch(`/users/${id}`).then(res => res.json()); | ||
const UserDetail = new Endpoint(fetchUser); | ||
export const getTodo = (id: string) => | ||
fetch(`https://jsonplaceholder.typicode.com/todos/${id}`).then(res => res.json()); | ||
export const getTodoList = () => | ||
fetch('https://jsonplaceholder.typicode.com/todos').then(res => res.json()); | ||
export const updateTodo = (id: string, body: Partial<Todo>) => | ||
fetch(`https://jsonplaceholder.typicode.com/todos/${id}`, { | ||
method: 'PUT', | ||
body: JSON.stringify(body), | ||
}).then(res => res.json()); | ||
``` | ||
### 2) Reuse with different hooks | ||
### 2) Turn them into Resources | ||
```typescript | ||
import { schema, Endpoint } from '@rest-hooks/endpoint'; | ||
import { Todo, getTodoList, updateTodo } from './existing'; | ||
export const TodoEntity = schema.Entity(Todo, { key: 'Todo' }); | ||
export const TodoResource = { | ||
get: new Endpoint(getTodo, { | ||
schema: TodoEntity, | ||
}), | ||
getList: new Endpoint(getTodoList, { | ||
schema: [TodoEntity], | ||
}), | ||
update: new Endpoint(updateTodo, { | ||
schema: TodoEntity, | ||
sideEffect: true, | ||
}), | ||
}; | ||
``` | ||
### 3) Reuse with different hooks | ||
```tsx | ||
function UserProfile() { | ||
const user = useSuspense(UserDetail, { id }); | ||
import { useSuspense, useController } from '@rest-hooks/react'; | ||
function TodoEdit() { | ||
const todo = useSuspense(TodoResource.get, '5'); | ||
const ctrl = useController(); | ||
const updateUser = (data) => ctrl.fetch(UserDetail, { id }, data); | ||
const updateTodo = (data) => ctrl.fetch(TodoResource.update, id, data); | ||
return <UserForm user={user} onSubmit={updateUser} /> | ||
return <TodoForm todo={todo} onSubmit={updateTodo} /> | ||
} | ||
``` | ||
### 3) Or call directly | ||
### 4) Or call directly in node | ||
```typescript | ||
const user = await UserDetail({ id: '5' }); | ||
console.log(user); | ||
const todo = await TodoResource.get('5') | ||
console.log(todo); | ||
``` | ||
@@ -45,0 +85,0 @@ |
@@ -20,4 +20,4 @@ Object.hasOwn = | ||
export { default as Entity } from './schemas/Entity.js'; | ||
export { default as validateRequired } from './schemas/validatRequired.js'; | ||
export { DELETED } from './special.js'; | ||
export { default as validateRequired } from './validateRequired.js'; | ||
export { DELETED, INVALID } from './special.js'; | ||
export type { | ||
@@ -24,0 +24,0 @@ Schema, |
@@ -28,2 +28,4 @@ import { AbstractInstanceType, Denormalize, EntityMap } from './normal.js'; | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args: any[], | ||
): any; | ||
@@ -35,2 +37,7 @@ denormalize( | ||
): [denormalized: T, found: boolean, suspend: boolean]; | ||
denormalizeOnly?( | ||
input: {}, | ||
args: any, | ||
unvisit: (input: any, schema: any) => any, | ||
): T; | ||
infer( | ||
@@ -54,3 +61,3 @@ args: readonly any[], | ||
createIfValid?(props: any): any; | ||
pk(params: any, parent?: any, key?: string): string | undefined; | ||
pk(params: any, parent?: any, key?: string, args?: any[]): string | undefined; | ||
readonly key: string; | ||
@@ -65,2 +72,8 @@ merge(existing: any, incoming: any): any; | ||
): any; | ||
mergeMetaWithStore?( | ||
existingMeta: any, | ||
incomingMeta: any, | ||
existing: any, | ||
incoming: any, | ||
): any; | ||
// TODO(breaking): deprecate this | ||
@@ -79,3 +92,3 @@ useIncoming?( | ||
export interface UnvisitFunction { | ||
(input: any, schema: any): [any, boolean, boolean]; | ||
(input: any, schema: any): [any, boolean, boolean] | any; | ||
og?: UnvisitFunction; | ||
@@ -82,0 +95,0 @@ setLocal?: (entity: any) => void; |
@@ -71,3 +71,5 @@ import type { | ||
? AbstractInstanceType<S> | ||
: S extends SchemaClass | ||
: S extends { denormalizeOnly: (...args: any) => any } | ||
? ReturnType<S['denormalizeOnly']> | ||
: S extends { denormalize: (...args: any) => any } | ||
? DenormalizeReturnType<S['denormalize']> | ||
@@ -86,3 +88,3 @@ : S extends Serializable<infer T> | ||
? DenormalizeNullableNestedSchema<S> | ||
: S extends SchemaClass | ||
: S extends { _denormalizeNullable: (...args: any) => any } | ||
? DenormalizeReturnType<S['_denormalizeNullable']> | ||
@@ -101,3 +103,3 @@ : S extends Serializable<infer T> | ||
? NormalizeObject<S['schema']> | ||
: S extends SchemaClass | ||
: S extends { normalize: (...args: any) => any } | ||
? NormalizeReturnType<S['normalize']> | ||
@@ -116,3 +118,3 @@ : S extends Serializable<infer T> | ||
? NormalizedNullableObject<S['schema']> | ||
: S extends SchemaClass | ||
: S extends { _normalizeNullable: (...args: any) => any } | ||
? NormalizeReturnType<S['_normalizeNullable']> | ||
@@ -119,0 +121,0 @@ : S extends Serializable<infer T> |
@@ -42,6 +42,18 @@ import type { | ||
) => { | ||
if (input === undefined) return [undefined, false, true]; | ||
if (input === undefined) return [undefined, false, false]; | ||
const [value, found, deleted] = schema.denormalize(input, unvisit); | ||
return [found ? this.process(value, ...args) : undefined, found, deleted]; | ||
}; | ||
if (schema.denormalizeOnly) | ||
query.denormalizeOnly = ( | ||
{ args, input }: { args: P; input: any }, | ||
_: P, | ||
unvisit: any, | ||
) => { | ||
if (input === undefined) return undefined; | ||
const value = (schema as any).denormalizeOnly(input, args, unvisit); | ||
return typeof value === 'symbol' | ||
? undefined | ||
: this.process(value, ...args); | ||
}; | ||
query.infer = ( | ||
@@ -76,2 +88,7 @@ args: any, | ||
): [denormalized: R | undefined, found: boolean, suspend: boolean]; | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): R; | ||
}; |
@@ -21,2 +21,3 @@ import type { | ||
} from './normal.js'; | ||
import { CollectionOptions } from './schemas/Collection.js'; | ||
import { default as Delete } from './schemas/Delete.js'; | ||
@@ -32,4 +33,5 @@ import { | ||
} from './schemas/EntitySchema.js'; | ||
import { default as Invalidate } from './schemas/Invalidate.js'; | ||
export { Delete, EntityMap }; | ||
export { Delete, EntityMap, Invalidate }; | ||
@@ -60,2 +62,4 @@ export { EntityInterface } from './interface.js'; | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
@@ -83,2 +87,8 @@ | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): (S extends EntityMap<infer T> ? T : Denormalize<S>)[]; | ||
infer( | ||
@@ -117,2 +127,4 @@ args: readonly any[], | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
@@ -140,2 +152,8 @@ | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): (S extends EntityMap<infer T> ? T : Denormalize<S>)[]; | ||
infer( | ||
@@ -166,2 +184,4 @@ args: readonly any[], | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): NormalizeObject<O>; | ||
@@ -179,2 +199,8 @@ | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): DenormalizeObject<O>; | ||
infer( | ||
@@ -210,2 +236,4 @@ args: readonly any[], | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): UnionResult<Choices>; | ||
@@ -231,2 +259,8 @@ | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): AbstractInstanceType<Choices[keyof Choices]>; | ||
infer( | ||
@@ -269,2 +303,4 @@ args: readonly any[], | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): Record< | ||
@@ -308,2 +344,11 @@ string, | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): Record< | ||
string, | ||
Choices extends EntityMap<infer T> ? T : Denormalize<Choices> | ||
>; | ||
infer( | ||
@@ -316,2 +361,134 @@ args: readonly any[], | ||
/** | ||
* Entities but for Arrays instead of classes | ||
* @see https://resthooks.io/rest/api/Collection | ||
*/ | ||
export class CollectionSchema< | ||
S extends Array<any> | Values<any> = any, | ||
Parent extends any[] = any, | ||
> { | ||
addWith<P extends any[] = Parent>( | ||
merge: (existing: any, incoming: any) => any, | ||
createCollectionFilter?: ( | ||
...args: P | ||
) => (collectionKey: Record<string, any>) => boolean, | ||
): CollectionSchema<S, P>; | ||
readonly schema: S; | ||
key: string; | ||
pk(value: any, parent: any, key: string, args: any[]): string; | ||
normalize( | ||
input: any, | ||
parent: Parent, | ||
key: string, | ||
visit: (...args: any) => any, | ||
addEntity: (...args: any) => any, | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args: any[], | ||
): string; | ||
merge(existing: any, incoming: any): any; | ||
shouldReorder( | ||
existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
existing: any, | ||
incoming: any, | ||
): boolean; | ||
mergeWithStore( | ||
existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
existing: any, | ||
incoming: any, | ||
): any; | ||
mergeMetaWithStore( | ||
existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
incomingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
existing: any, | ||
incoming: any, | ||
): { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}; | ||
infer( | ||
args: unknown, | ||
indexes: unknown, | ||
recurse: unknown, | ||
entities: unknown, | ||
): any; | ||
createIfValid: (value: any) => any | undefined; | ||
denormalizeOnly( | ||
input: any, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): ReturnType<S['denormalizeOnly']>; | ||
_denormalizeNullable(): ReturnType<S['_denormalizeNullable']>; | ||
_normalizeNullable(): ReturnType<S['_normalizeNullable']>; | ||
} | ||
export type CollectionType< | ||
S extends any[] | Array<any> | Values<any> = any, | ||
Parent extends any[] = [ | ||
urlParams: Record<string, any>, | ||
body?: Record<string, any>, | ||
], | ||
> = CollectionSchema<S extends any[] ? Array<S[number]> : S> & | ||
(S extends any[] | ||
? { | ||
push: CollectionSchema<Array<S[number]>, Parent>; | ||
unshift: CollectionSchema<Array<S[number]>, Parent>; | ||
} | ||
: S extends Values<any> | ||
? { assign: CollectionSchema<S, Parent> } | ||
: S extends Array<any> | ||
? { | ||
push: CollectionSchema<S, Parent>; | ||
unshift: CollectionSchema<S, Parent>; | ||
} | ||
: never); | ||
export interface CollectionConstructor { | ||
new < | ||
S extends SchemaSimple[] | Array<any> | Values<any> = any, | ||
Parent extends any[] = [ | ||
urlParams: Record<string, any>, | ||
body?: Record<string, any>, | ||
], | ||
>( | ||
schema: S, | ||
options: CollectionOptions, | ||
): CollectionType<S, Parent>; | ||
readonly prototype: CollectionSchema; | ||
} | ||
/** | ||
* Entities but for Arrays instead of classes | ||
* @see https://resthooks.io/rest/api/Collection | ||
*/ | ||
export declare let Collection: CollectionConstructor; | ||
export type StrategyFunction<T> = (value: any, parent: any, key: string) => T; | ||
@@ -342,2 +519,26 @@ export type SchemaFunction<K = string> = ( | ||
export interface SchemaSimpleNew<T = any> { | ||
normalize( | ||
input: any, | ||
parent: any, | ||
key: any, | ||
visit: (...args: any) => any, | ||
addEntity: (...args: any) => any, | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: any[], | ||
): any; | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): T; | ||
infer( | ||
args: readonly any[], | ||
indexes: NormalizedIndex, | ||
recurse: (...args: any) => any, | ||
entities: EntityTable, | ||
): any; | ||
} | ||
// id is in Instance, so we default to that as pk | ||
@@ -344,0 +545,0 @@ /** |
@@ -8,2 +8,4 @@ /* istanbul ignore file */ | ||
export { default as Delete } from './schemas/Delete.js'; | ||
export { default as Invalidate } from './schemas/Invalidate.js'; | ||
export { default as Collection } from './schemas/Collection.js'; | ||
export { default as Entity } from './schemas/EntitySchema.js'; |
@@ -159,12 +159,8 @@ // eslint-env jest | ||
const input = inferResults(catSchema, [], {}, entities); | ||
let [value, found] = denormalize(input, catSchema, createInput(entities)); | ||
let value = denormalize(input, catSchema, createInput(entities)); | ||
expect(value).not.toEqual(expect.any(Symbol)); | ||
if (typeof value === 'symbol') return; | ||
expect(createOutput(value.results)).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
[value, found] = denormalize( | ||
createInput(input), | ||
catSchema, | ||
createInput(entities), | ||
); | ||
value = denormalize(createInput(input), catSchema, createInput(entities)); | ||
expect(createOutput(value)).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
}); | ||
@@ -184,13 +180,9 @@ | ||
const input = inferResults(catSchema, [], {}, entities); | ||
let [value, found] = denormalize(input, catSchema, createInput(entities)); | ||
let value = denormalize(input, catSchema, createInput(entities)); | ||
expect(value).not.toEqual(expect.any(Symbol)); | ||
if (typeof value === 'symbol') return; | ||
expect(createOutput(value.results).length).toBe(2); | ||
expect(createOutput(value.results)).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
[value, found] = denormalize( | ||
createInput(input), | ||
catSchema, | ||
createInput(entities), | ||
); | ||
value = denormalize(createInput(input), catSchema, createInput(entities)); | ||
expect(createOutput(value)).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
}); | ||
@@ -211,3 +203,3 @@ | ||
const resultCache = new WeakEntityMap(); | ||
const [value, found] = denormalize( | ||
const value = denormalize( | ||
input, | ||
@@ -222,4 +214,3 @@ catSchema, | ||
expect(createOutput(value).results).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
const [value2, found2] = denormalize( | ||
const value2 = denormalize( | ||
input, | ||
@@ -235,3 +226,2 @@ catSchema, | ||
expect(value).toBe(value2); | ||
expect(found).toBe(found2); | ||
@@ -246,3 +236,3 @@ entities = { | ||
const input3 = createInput(inferResults(catSchema, [], {}, entities)); | ||
const [value3, found3] = denormalize( | ||
const value3 = denormalize( | ||
input3, | ||
@@ -265,3 +255,3 @@ catSchema, | ||
test('denormalizes should not be found when no entities are present', () => { | ||
test('denormalizes should be invalid when no entities are present', () => { | ||
class Cat extends IDEntity {} | ||
@@ -277,3 +267,3 @@ const catSchema = { results: new schema.All(Cat) }; | ||
const [value, found] = denormalize( | ||
const value = denormalize( | ||
createInput(input), | ||
@@ -283,5 +273,4 @@ catSchema, | ||
); | ||
expect(found).toBe(false); | ||
expect(createOutput(value)).toEqual({ results: undefined }); | ||
expect(createOutput(value)).toEqual(expect.any(Symbol)); | ||
}); | ||
@@ -315,3 +304,3 @@ | ||
const input = inferResults(listSchema, [], {}, entities); | ||
const [value, found] = denormalize( | ||
const value = denormalize( | ||
createInput(input), | ||
@@ -321,3 +310,2 @@ listSchema, | ||
); | ||
expect(found).toBe(false); | ||
@@ -382,9 +370,5 @@ expect(createOutput(value)).toEqual(undefined); | ||
const input = inferResults(listSchema, [], {}, entities); | ||
const [value, found, deleted] = denormalize( | ||
input, | ||
listSchema, | ||
createInput(entities), | ||
); | ||
expect(found).toBe(true); | ||
expect(deleted).toBe(false); | ||
const value = denormalize(input, listSchema, createInput(entities)); | ||
expect(value).not.toEqual(expect.any(Symbol)); | ||
if (typeof value === 'symbol') return; | ||
expect(value).toMatchSnapshot(); | ||
@@ -391,0 +375,0 @@ const first = value && value[0]; |
@@ -6,3 +6,3 @@ // eslint-env jest | ||
import denormalize from './denormalize'; | ||
import { denormalizeSimple, denormalizeLegacy } from './denormalize'; | ||
import { schema } from '../../'; | ||
@@ -34,7 +34,7 @@ | ||
['plain', sch => [sch]], | ||
])(`${schema.Array.name} normalization (%s)`, (_, createArray) => { | ||
])(`${schema.Array.name} normalization (%s)`, (_, createSchema) => { | ||
describe('Object', () => { | ||
test('should throw a custom error if data loads with string unexpected value', () => { | ||
class User extends IDEntity {} | ||
const sch = createArray(User); | ||
const sch = createSchema(User); | ||
function normalizeBad() { | ||
@@ -48,3 +48,3 @@ normalize('abc', sch); | ||
class User extends IDEntity {} | ||
const sch = createArray(User); | ||
const sch = createSchema(User); | ||
function normalizeBad() { | ||
@@ -73,3 +73,3 @@ normalize('[{"id":5}]', sch); | ||
static schema = { | ||
children: createArray(Child), | ||
children: createSchema(Child), | ||
}; | ||
@@ -93,3 +93,3 @@ } | ||
expect( | ||
normalize({ foo: { id: '1' }, bar: { id: '2' } }, createArray(User)), | ||
normalize({ foo: { id: '1' }, bar: { id: '2' } }, createSchema(User)), | ||
).toMatchSnapshot(); | ||
@@ -102,3 +102,3 @@ }); | ||
test('normalizes a single entity', () => { | ||
const listSchema = createArray(Cats); | ||
const listSchema = createSchema(Cats); | ||
expect( | ||
@@ -136,3 +136,3 @@ normalize([{ id: '1' }, { id: '2' }], listSchema), | ||
class User extends IDEntity {} | ||
const users = createArray(User); | ||
const users = createSchema(User); | ||
expect( | ||
@@ -145,3 +145,3 @@ normalize({ foo: { id: '1' }, bar: { id: '2' } }, users), | ||
class User extends IDEntity {} | ||
const users = createArray(User); | ||
const users = createSchema(User); | ||
expect( | ||
@@ -155,10 +155,39 @@ normalize([undefined, { id: '123' }, null], users), | ||
describe.each([ | ||
['class, direct', sch => new schema.Array(sch), data => data], | ||
['object, direct', sch => [sch], data => data], | ||
['class, immutable', sch => new schema.Array(sch), fromJS], | ||
['object, immutable', sch => [sch], fromJS], | ||
])( | ||
`${schema.Array.name} denormalization (%s)`, | ||
(_, createSchema, createInput) => { | ||
describe('Object', () => { | ||
['direct', data => data], | ||
['immutable', fromJS], | ||
])(`input (%s)`, (_, createInput) => { | ||
test('denormalizes plain arrays with nothing inside', () => { | ||
class User extends IDEntity {} | ||
const entities = { | ||
User: { | ||
1: { id: '1', name: 'Jane' }, | ||
}, | ||
}; | ||
const sch = new schema.Object({ user: User, tacos: [] }); | ||
expect( | ||
denormalizeSimple({ user: '1' }, sch, createInput(entities)), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalizeSimple(createInput({ user: '1' }), sch, createInput(entities)), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalizeSimple({ user: '1', tacos: [] }, sch, createInput(entities)), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalizeSimple( | ||
createInput({ user: '1', tacos: [] }), | ||
sch, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
describe.each([ | ||
['class', sch => new schema.Array(sch), denormalizeSimple], | ||
['class, legacy', sch => new schema.Array(sch), denormalizeLegacy], | ||
['object, direct', sch => [sch], denormalizeSimple], | ||
])( | ||
`${schema.Array.name} denormalization (%s)`, | ||
(_, createSchema, denormalize) => { | ||
test('denormalizes a single entity', () => { | ||
@@ -194,40 +223,2 @@ class Cat extends IDEntity {} | ||
test('denormalizes plain arrays with nothing inside', () => { | ||
class User extends IDEntity {} | ||
const entities = { | ||
User: { | ||
1: { id: '1', name: 'Jane' }, | ||
}, | ||
}; | ||
expect( | ||
denormalize( | ||
{ user: '1' }, | ||
{ user: User, tacos: [] }, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
createInput({ user: '1' }), | ||
{ user: User, tacos: [] }, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
{ user: '1', tacos: [] }, | ||
{ user: User, tacos: [] }, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
createInput({ user: '1', tacos: [] }), | ||
{ user: User, tacos: [] }, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
test('denormalizes plain arrays with plain object inside', () => { | ||
@@ -240,3 +231,6 @@ class User extends IDEntity {} | ||
}; | ||
const sch = { user: User, tacos: createSchema({ next: '' }) }; | ||
const sch = new schema.Object({ | ||
user: User, | ||
tacos: createSchema({ next: '' }), | ||
}); | ||
expect( | ||
@@ -263,3 +257,3 @@ denormalize({ user: '1' }, sch, createInput(entities)), | ||
class Cat extends IDEntity {} | ||
const catSchema = { results: createSchema(Cat) }; | ||
const catSchema = new schema.Object({ results: createSchema(Cat) }); | ||
const entities = { | ||
@@ -282,3 +276,6 @@ Cat: { | ||
class Cat extends IDEntity {} | ||
const catSchema = { results: createSchema(Cat), nextPage: '' }; | ||
const catSchema = new schema.Object({ | ||
results: createSchema(Cat), | ||
nextPage: '', | ||
}); | ||
const entities = { | ||
@@ -290,3 +287,3 @@ Cat: { | ||
}; | ||
let [value, found] = denormalize( | ||
let value = denormalize( | ||
{ results: ['1', '2'] }, | ||
@@ -297,4 +294,3 @@ catSchema, | ||
expect(value).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
[value, found] = denormalize( | ||
value = denormalize( | ||
createInput({ results: ['1', '2'] }), | ||
@@ -305,3 +301,2 @@ catSchema, | ||
expect(value).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
}); | ||
@@ -311,3 +306,6 @@ | ||
class Cat extends IDEntity {} | ||
const catSchema = { results: createSchema(Cat), nextPage: '' }; | ||
const catSchema = new schema.Object({ | ||
results: createSchema(Cat), | ||
nextPage: '', | ||
}); | ||
const entities = { | ||
@@ -319,3 +317,3 @@ Cat: { | ||
}; | ||
let [value, found] = denormalize( | ||
let value = denormalize( | ||
createInput({ results: ['1', undefined, '2'] }), | ||
@@ -326,4 +324,3 @@ catSchema, | ||
expect(value).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
[value, found] = denormalize( | ||
value = denormalize( | ||
{ results: ['1', '2'] }, | ||
@@ -334,3 +331,2 @@ catSchema, | ||
expect(value).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
}); | ||
@@ -340,3 +336,3 @@ | ||
class Cat extends IDEntity {} | ||
const catSchema = { results: createSchema(Cat) }; | ||
const catSchema = new schema.Object({ results: createSchema(Cat) }); | ||
const entities = { | ||
@@ -348,3 +344,3 @@ Cat: { | ||
}; | ||
let [value, found] = denormalize( | ||
let value = denormalize( | ||
createInput({ results: undefined }), | ||
@@ -355,3 +351,2 @@ catSchema, | ||
expect(value).toMatchSnapshot(); | ||
expect(found).toBe(false); | ||
}); | ||
@@ -367,9 +362,8 @@ | ||
}; | ||
let [value, foundEntities] = denormalize( | ||
let value = denormalize( | ||
createInput([{ data: '1' }, { data: '2' }, { data: '3' }]), | ||
createSchema({ data: Cat }), | ||
createSchema(new schema.Object({ data: Cat })), | ||
createInput(entities), | ||
); | ||
expect(value).toMatchSnapshot(); | ||
expect(foundEntities).toBe(true); | ||
}); | ||
@@ -406,3 +400,3 @@ | ||
Cat: Cat, | ||
dogs: {}, | ||
dogs: new schema.Object({}), | ||
people: Person, | ||
@@ -439,3 +433,3 @@ }, | ||
const [value, found, deleted] = denormalize( | ||
const value = denormalize( | ||
createInput(input), | ||
@@ -445,4 +439,2 @@ listSchema, | ||
); | ||
expect(found).toBe(true); | ||
expect(deleted).toBe(false); | ||
expect(value).toMatchSnapshot(); | ||
@@ -463,10 +455,8 @@ }); | ||
expect(output).toMatchSnapshot(); | ||
expect(denormalize(output.result, catList, output.entities)).toEqual([ | ||
expect(denormalize(output.result, catList, output.entities)).toEqual( | ||
input, | ||
true, | ||
false, | ||
]); | ||
); | ||
}); | ||
}); | ||
}, | ||
); | ||
}, | ||
); | ||
}); |
// eslint-env jest | ||
import { normalize } from '@rest-hooks/normalizr'; | ||
import { Schema, normalize } from '@rest-hooks/normalizr'; | ||
import { IDEntity } from '__tests__/new'; | ||
import { fromJS } from 'immutable'; | ||
import denormalize from './denormalize'; | ||
import { denormalizeSimple, denormalizeLegacy } from './denormalize'; | ||
import { schema } from '../../'; | ||
@@ -79,78 +79,106 @@ import { DELETED } from '../../special'; | ||
test('denormalizes an object in the same manner as the Entity', () => { | ||
const [user, ready, deleted] = denormalize( | ||
'1', | ||
new schema.Delete(User), | ||
entities, | ||
); | ||
const user = denormalizeSimple('1', new schema.Delete(User), entities); | ||
expect(user).not.toEqual(expect.any(Symbol)); | ||
if (typeof user === 'symbol') return; | ||
expect(user).toBeDefined(); | ||
expect(user).toBeInstanceOf(User); | ||
expect(user?.username).toBe('Janey'); | ||
expect(ready).toBe(true); | ||
expect(deleted).toBe(false); | ||
}); | ||
test.each([ | ||
['direct', (data: any) => data], | ||
describe.each([ | ||
['direct', <T>(data: T) => data], | ||
['immutable', fromJS], | ||
] as const)( | ||
`denormalizes deleted entities as undefined (%s)`, | ||
(_, createInput) => { | ||
const [user, ready, deleted] = denormalize('1', new schema.Delete(User), { | ||
User: { '1': DELETED }, | ||
}); | ||
expect(user).toBe(undefined); | ||
expect(ready).toBe(true); | ||
expect(deleted).toBe(true); | ||
])(`input (%s)`, (_, createInput) => { | ||
describe.each([ | ||
[ | ||
'class', | ||
<T extends Schema>(sch: T) => new schema.Array(sch), | ||
<T extends Record<string, any>>(sch: T) => new schema.Object(sch), | ||
denormalizeSimple, | ||
], | ||
[ | ||
'class, legacy', | ||
<T extends Schema>(sch: T) => new schema.Array(sch), | ||
<T extends Record<string, any>>(sch: T) => new schema.Object(sch), | ||
denormalizeLegacy, | ||
], | ||
[ | ||
'object, direct', | ||
<T extends Schema>(sch: T) => [sch], | ||
<T extends Record<string, any>>(sch: T) => sch, | ||
denormalizeSimple, | ||
], | ||
])( | ||
`schema construction (%s)`, | ||
(_, createArray, createObject, denormalize) => { | ||
test('denormalizes deleted entities as symbol', () => { | ||
const user = denormalize( | ||
'1', | ||
new schema.Delete(User), | ||
createInput({ | ||
User: { '1': DELETED }, | ||
}), | ||
); | ||
expect(user).toEqual(expect.any(Symbol)); | ||
expect( | ||
denormalize( | ||
createInput([{ data: '1' }]), | ||
new schema.Array( | ||
new schema.Object({ data: new schema.Delete(User) }), | ||
), | ||
createInput([{ User: { '1': DELETED } }]), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
createInput({ data: '1' }), | ||
createObject({ data: new schema.Delete(User) }), | ||
createInput({ | ||
User: { '1': DELETED }, | ||
}), | ||
), | ||
).toEqual(expect.any(Symbol)); | ||
}); | ||
expect( | ||
denormalize( | ||
createInput([{ data: '1' }]), | ||
[{ data: new schema.Delete(User) }], | ||
createInput([{ User: { '1': DELETED } }]), | ||
), | ||
).toMatchSnapshot(); | ||
test('denormalize removes deleted entries in array', () => { | ||
expect( | ||
denormalize( | ||
createInput([{ data: '1' }]), | ||
createArray(createObject({ data: new schema.Delete(User) })), | ||
createInput({ | ||
User: { '1': DELETED }, | ||
}), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
createInput([{ data: '1' }]), | ||
createArray(createObject({ data: User })), | ||
createInput({ | ||
User: { '1': DELETED }, | ||
}), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
expect( | ||
denormalize( | ||
createInput([{ data: '1' }]), | ||
new schema.Array(new schema.Object({ data: User })), | ||
createInput([{ User: { '1': DELETED } }]), | ||
), | ||
).toMatchSnapshot(); | ||
test('denormalize sets undefined entities that are not present', () => { | ||
expect( | ||
denormalize( | ||
createInput([{ data: '1' }]), | ||
createArray(createObject({ data: new schema.Delete(User) })), | ||
createInput([{}]), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
createInput([{ data: '1' }]), | ||
[{ data: User }], | ||
createInput([{ User: { '1': DELETED } }]), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
createInput([{ data: '1' }]), | ||
createArray(createObject({ data: User })), | ||
createInput([{}]), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
createInput({ data: '1' }), | ||
new schema.Object({ data: User }), | ||
createInput({ User: { '1': DELETED } }), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
createInput({ data: '1' }), | ||
{ data: User }, | ||
createInput({ User: { '1': DELETED } }), | ||
), | ||
).toMatchSnapshot(); | ||
}, | ||
); | ||
expect( | ||
denormalize( | ||
createInput({ data: '1' }), | ||
createObject({ data: User }), | ||
createInput({}), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
}, | ||
); | ||
}); | ||
}); |
import { | ||
denormalize as denormalizeCore, | ||
denormalizeCached as denormalizeCore, | ||
Schema, | ||
@@ -8,4 +8,9 @@ DenormalizeCache, | ||
DenormalizeNullable, | ||
INVALID, | ||
} from '@rest-hooks/normalizr'; | ||
import { denormalize as legacyDenormalize } from './legacy-compat/denormalize'; | ||
import { denormalize as legacyDenormalize10 } from './legacy-compat/denormalize-v10.1/denormalizeCached'; | ||
import WeakListMap from './legacy-compat/WeakListMap'; | ||
export const denormalizeSimple = <S extends Schema>( | ||
@@ -17,13 +22,45 @@ input: any, | ||
resultCache: DenormalizeCache['results'][string] = new WeakEntityMap(), | ||
): | ||
| [denormalized: Denormalize<S>, found: true, deleted: false] | ||
| [denormalized: DenormalizeNullable<S>, found: boolean, deleted: true] | ||
| [denormalized: DenormalizeNullable<S>, found: false, deleted: boolean] => | ||
denormalizeCore(input, schema, entities, entityCache, resultCache).slice( | ||
0, | ||
3, | ||
) as any; | ||
args: any[] = [], | ||
): Denormalize<S> | DenormalizeNullable<S> | symbol => | ||
denormalizeCore(input, schema, entities, entityCache, resultCache, args) | ||
.data as any; | ||
export default denormalizeSimple; | ||
it('should', () => {}); | ||
export const denormalizeLegacy = <S extends Schema>( | ||
input: unknown, | ||
schema: S | undefined, | ||
entities: any, | ||
entityCache: any = {}, | ||
resultCache: WeakListMap<object, any> = new WeakListMap(), | ||
) => { | ||
const [value, found, deleted] = legacyDenormalize( | ||
input, | ||
schema, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
if (deleted) return INVALID; | ||
return value; | ||
}; | ||
export const denormalize10 = <S extends Schema>( | ||
input: unknown, | ||
schema: S | undefined, | ||
entities: any, | ||
entityCache: any = {}, | ||
resultCache: WeakEntityMap<object, any> = new WeakEntityMap(), | ||
) => { | ||
const [value, found, deleted] = legacyDenormalize10( | ||
input, | ||
schema, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
if (deleted) return INVALID; | ||
return value; | ||
}; | ||
it('[helper file in test folder]', () => {}); |
// eslint-env jest | ||
import { normalize, WeakEntityMap } from '@rest-hooks/normalizr'; | ||
import { inferResults, normalize, WeakEntityMap } from '@rest-hooks/normalizr'; | ||
import { DELETED } from '@rest-hooks/normalizr'; | ||
@@ -7,3 +7,4 @@ import { IDEntity } from '__tests__/new'; | ||
import denormalize from './denormalize'; | ||
import { denormalizeSimple, denormalizeLegacy } from './denormalize'; | ||
import WeakListMap from './legacy-compat/WeakListMap'; | ||
import { AbstractInstanceType } from '../../'; | ||
@@ -104,2 +105,3 @@ import { schema } from '../../'; | ||
MyEntity, | ||
[], | ||
entities, | ||
@@ -659,3 +661,5 @@ {}, | ||
); | ||
const [final] = denormalize(result, ProcessTaco, entities); | ||
const final = denormalizeSimple(result, ProcessTaco, entities); | ||
expect(final).not.toEqual(expect.any(Symbol)); | ||
if (typeof final === 'symbol') return; | ||
expect(final?.slug).toEqual('thing-1'); | ||
@@ -694,3 +698,5 @@ expect(final).toMatchSnapshot(); | ||
); | ||
const [final] = denormalize(result, ParentEntity, entities); | ||
const final = denormalizeSimple(result, ParentEntity, entities); | ||
expect(final).not.toEqual(expect.any(Symbol)); | ||
if (typeof final === 'symbol') return; | ||
expect(final?.child?.parentId).toEqual('1'); | ||
@@ -721,3 +727,5 @@ expect(final).toMatchSnapshot(); | ||
); | ||
const [final] = denormalize(result, EntriesEntity, entities); | ||
const final = denormalizeSimple(result, EntriesEntity, entities); | ||
expect(final).not.toEqual(expect.any(Symbol)); | ||
if (typeof final === 'symbol') return; | ||
expect(final?.type).toEqual('message'); | ||
@@ -729,545 +737,504 @@ expect(final).toMatchSnapshot(); | ||
describe(`${Entity.name} denormalization`, () => { | ||
test('denormalizes an entity', () => { | ||
const entities = { | ||
Tacos: { | ||
'1': { id: '1', name: 'foo' }, | ||
}, | ||
}; | ||
expect(denormalize('1', Tacos, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Tacos, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
describe.each([ | ||
['current', denormalizeSimple, () => new WeakEntityMap()], | ||
['legacy', denormalizeLegacy, () => new WeakListMap()], | ||
] as const)( | ||
`${Entity.name} denormalization (%s)`, | ||
(_, denormalize, createResultCache) => { | ||
test('denormalizes an entity', () => { | ||
const entities = { | ||
Tacos: { | ||
'1': { id: '1', name: 'foo' }, | ||
}, | ||
}; | ||
expect(denormalize('1', Tacos, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Tacos, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
class Food extends IDEntity {} | ||
class Menu extends IDEntity { | ||
readonly food: Food = Food.fromJS(); | ||
class Food extends IDEntity {} | ||
class Menu extends IDEntity { | ||
readonly food: Food = Food.fromJS(); | ||
static schema = { food: Food }; | ||
} | ||
static schema = { food: Food }; | ||
} | ||
test('denormalizes deep entities', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '1' }, | ||
'2': { id: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
test('denormalizes deep entities', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '1' }, | ||
'2': { id: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
const de1 = denormalize('1', Menu, entities); | ||
expect(de1).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toEqual(de1); | ||
const de1 = denormalize('1', Menu, entities); | ||
expect(de1).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toEqual(de1); | ||
const de2 = denormalize('2', Menu, entities); | ||
expect(de2).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toEqual(de2); | ||
}); | ||
const de2 = denormalize('2', Menu, entities); | ||
expect(de2).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toEqual(de2); | ||
}); | ||
test('denormalizes deep entities while maintaining referential equality', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '1' }, | ||
'2': { id: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
const entityCache = {}; | ||
const resultCache = new WeakEntityMap(); | ||
test('denormalizes deep entities while maintaining referential equality', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '1' }, | ||
'2': { id: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
const entityCache = {}; | ||
const resultCache = createResultCache(); | ||
const [first] = denormalize('1', Menu, entities, entityCache, resultCache); | ||
const [second] = denormalize('1', Menu, entities, entityCache, resultCache); | ||
expect(first).toBe(second); | ||
expect(first?.food).toBe(second?.food); | ||
}); | ||
const first = denormalize('1', Menu, entities, entityCache, resultCache); | ||
const second = denormalize('1', Menu, entities, entityCache, resultCache); | ||
expect(first).not.toEqual(expect.any(Symbol)); | ||
if (typeof first === 'symbol') return; | ||
expect(second).not.toEqual(expect.any(Symbol)); | ||
if (typeof second === 'symbol') return; | ||
expect(first).toBe(second); | ||
expect(first?.food).toBe(second?.food); | ||
}); | ||
test('denormalizes to undefined when validate() returns string', () => { | ||
class MyTacos extends Tacos { | ||
static validate(entity) { | ||
if (!Object.hasOwn(entity, 'name')) return 'no name'; | ||
test('denormalizes to undefined when validate() returns string', () => { | ||
class MyTacos extends Tacos { | ||
static validate(entity) { | ||
if (!Object.hasOwn(entity, 'name')) return 'no name'; | ||
} | ||
} | ||
} | ||
const entities = { | ||
MyTacos: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
expect(denormalize('1', MyTacos, entities)).toStrictEqual([ | ||
undefined, | ||
false, | ||
true, | ||
]); | ||
expect(denormalize('1', MyTacos, fromJS(entities))).toStrictEqual([ | ||
undefined, | ||
false, | ||
true, | ||
]); | ||
}); | ||
const entities = { | ||
MyTacos: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
expect(denormalize('1', MyTacos, entities)).toEqual(expect.any(Symbol)); | ||
expect(denormalize('1', MyTacos, fromJS(entities))).toEqual( | ||
expect.any(Symbol), | ||
); | ||
}); | ||
test('denormalizes to undefined for missing data', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
test('denormalizes to undefined for missing data', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
it('should handle optional schema entries Entity', () => { | ||
class MyEntity extends Entity { | ||
readonly name: string = ''; | ||
readonly secondthing: string = ''; | ||
readonly blarb: Date | undefined = undefined; | ||
pk() { | ||
return this.name; | ||
it('should handle optional schema entries Entity', () => { | ||
class MyEntity extends Entity { | ||
readonly name: string = ''; | ||
readonly secondthing: string = ''; | ||
readonly blarb: Date | undefined = undefined; | ||
pk() { | ||
return this.name; | ||
} | ||
static schema = { | ||
blarb: Date, | ||
}; | ||
} | ||
const schema = MyEntity; | ||
static schema = { | ||
blarb: Date, | ||
}; | ||
} | ||
const schema = MyEntity; | ||
expect( | ||
denormalize('bob', schema, { | ||
MyEntity: { bob: { name: 'bob', secondthing: 'hi' } }, | ||
}), | ||
).toMatchInlineSnapshot(` | ||
[ | ||
MyEntity { | ||
"blarb": undefined, | ||
"name": "bob", | ||
"secondthing": "hi", | ||
}, | ||
true, | ||
false, | ||
] | ||
expect( | ||
denormalize('bob', schema, { | ||
MyEntity: { bob: { name: 'bob', secondthing: 'hi' } }, | ||
}), | ||
).toMatchInlineSnapshot(` | ||
MyEntity { | ||
"blarb": undefined, | ||
"name": "bob", | ||
"secondthing": "hi", | ||
} | ||
`); | ||
}); | ||
}); | ||
it('should handle null schema entries Entity', () => { | ||
class MyEntity extends Entity { | ||
readonly name: string = ''; | ||
readonly secondthing: string = ''; | ||
readonly blarb: Date | null = null; | ||
pk() { | ||
return this.name; | ||
it('should handle null schema entries Entity', () => { | ||
class MyEntity extends Entity { | ||
readonly name: string = ''; | ||
readonly secondthing: string = ''; | ||
readonly blarb: Date | null = null; | ||
pk() { | ||
return this.name; | ||
} | ||
static schema = { | ||
blarb: Date, | ||
}; | ||
} | ||
const schema = MyEntity; | ||
static schema = { | ||
blarb: Date, | ||
}; | ||
} | ||
const schema = MyEntity; | ||
expect( | ||
denormalize('bob', schema, { | ||
MyEntity: { bob: { name: 'bob', secondthing: 'hi', blarb: null } }, | ||
}), | ||
).toMatchInlineSnapshot(` | ||
MyEntity { | ||
"blarb": null, | ||
"name": "bob", | ||
"secondthing": "hi", | ||
} | ||
`); | ||
}); | ||
expect( | ||
denormalize('bob', schema, { | ||
MyEntity: { bob: { name: 'bob', secondthing: 'hi', blarb: null } }, | ||
}), | ||
).toMatchInlineSnapshot(` | ||
[ | ||
MyEntity { | ||
"blarb": null, | ||
"name": "bob", | ||
"secondthing": "hi", | ||
test('denormalizes to undefined for deleted data', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '2' }, | ||
'2': DELETED, | ||
}, | ||
true, | ||
false, | ||
] | ||
`); | ||
}); | ||
Food: { | ||
'1': { id: '1' }, | ||
'2': DELETED, | ||
}, | ||
}; | ||
test('denormalizes to undefined for deleted data', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '2' }, | ||
'2': DELETED, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
'2': DELETED, | ||
}, | ||
}; | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
test('denormalizes deep entities with records', () => { | ||
const Food = Record<{ id: null | string }>({ id: null }); | ||
const MenuR = Record<{ id: null | string; food: null | string }>({ | ||
id: null, | ||
food: null, | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
const entities = { | ||
Menu: { | ||
'1': new MenuR({ id: '1', food: '1' }), | ||
'2': new MenuR({ id: '2' }), | ||
}, | ||
Food: { | ||
'1': new Food({ id: '1' }), | ||
}, | ||
}; | ||
test('denormalizes deep entities with records', () => { | ||
const Food = Record<{ id: null | string }>({ id: null }); | ||
const MenuR = Record<{ id: null | string; food: null | string }>({ | ||
id: null, | ||
food: null, | ||
}); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
const entities = { | ||
Menu: { | ||
'1': new MenuR({ id: '1', food: '1' }), | ||
'2': new MenuR({ id: '2' }), | ||
}, | ||
Food: { | ||
'1': new Food({ id: '1' }), | ||
}, | ||
}; | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
test('can denormalize already partially denormalized data', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: { id: '1' } }, | ||
}, | ||
Food: { | ||
// TODO: BREAKING CHANGE: Update this to use main entity and only return nested as 'fallback' in case main entity is not set | ||
'1': { id: '1', extra: 'hi' }, | ||
}, | ||
}; | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
test('can denormalize already partially denormalized data', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: { id: '1' } }, | ||
}, | ||
Food: { | ||
// TODO: BREAKING CHANGE: Update this to use main entity and only return nested as 'fallback' in case main entity is not set | ||
'1': { id: '1', extra: 'hi' }, | ||
}, | ||
}; | ||
class User extends IDEntity { | ||
readonly role = ''; | ||
readonly reports: Report[] = []; | ||
} | ||
class Report extends IDEntity { | ||
readonly title: string = ''; | ||
readonly draftedBy: User = User.fromJS(); | ||
readonly publishedBy: User = User.fromJS(); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
static schema = { | ||
draftedBy: User, | ||
publishedBy: User, | ||
}; | ||
} | ||
User.schema = { | ||
reports: [Report], | ||
}; | ||
class Comment extends IDEntity { | ||
readonly body: string = ''; | ||
readonly author: User = User.fromJS(); | ||
class User extends IDEntity { | ||
readonly role = ''; | ||
readonly reports: Report[] = []; | ||
} | ||
class Report extends IDEntity { | ||
readonly title: string = ''; | ||
readonly draftedBy: User = User.fromJS(); | ||
readonly publishedBy: User = User.fromJS(); | ||
static schema = { | ||
author: User, | ||
static schema = { | ||
draftedBy: User, | ||
publishedBy: User, | ||
}; | ||
} | ||
User.schema = { | ||
reports: new schema.Array(Report), | ||
}; | ||
} | ||
class Comment extends IDEntity { | ||
readonly body: string = ''; | ||
readonly author: User = User.fromJS(); | ||
test('denormalizes recursive dependencies', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
static schema = { | ||
author: User, | ||
}; | ||
} | ||
test('denormalizes recursive dependencies', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
}, | ||
}, | ||
}, | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
}, | ||
}, | ||
}, | ||
}; | ||
}; | ||
expect(denormalize('123', Report, entities)[0]).toMatchSnapshot(); | ||
expect(denormalize('123', Report, fromJS(entities))[0]).toMatchSnapshot(); | ||
expect(denormalize('123', Report, entities)).toMatchSnapshot(); | ||
expect(denormalize('123', Report, fromJS(entities))).toMatchSnapshot(); | ||
expect(denormalize('456', User, entities)[0]).toMatchSnapshot(); | ||
expect(denormalize('456', User, fromJS(entities))[0]).toMatchSnapshot(); | ||
}); | ||
expect(denormalize('456', User, entities)).toMatchSnapshot(); | ||
expect(denormalize('456', User, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
test('denormalizes recursive entities with referential equality', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
test('denormalizes recursive entities with referential equality', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
}, | ||
}, | ||
}, | ||
Comment: { | ||
'999': { | ||
id: '999', | ||
body: 'Good morning', | ||
author: '456', | ||
Comment: { | ||
'999': { | ||
id: '999', | ||
body: 'Good morning', | ||
author: '456', | ||
}, | ||
}, | ||
}, | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
}, | ||
'457': { | ||
id: '457', | ||
role: 'servant', | ||
reports: ['123'], | ||
}, | ||
}, | ||
'457': { | ||
id: '457', | ||
role: 'servant', | ||
reports: ['123'], | ||
}, | ||
}, | ||
}; | ||
const entityCache: any = {}; | ||
const resultCache = new WeakEntityMap(); | ||
}; | ||
const entityCache: any = {}; | ||
const resultCache = createResultCache(); | ||
const [denormalizedReport] = denormalize( | ||
'123', | ||
Report, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
const denormalizedReport = denormalize( | ||
'123', | ||
Report, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
expect(denormalizedReport).not.toEqual(expect.any(Symbol)); | ||
if (typeof denormalizedReport === 'symbol') return; | ||
expect(denormalizedReport).toBeDefined(); | ||
// This is just for TypeScript, the above line actually determines this | ||
if (!denormalizedReport) throw new Error('expected to be defined'); | ||
expect(denormalizedReport).toBe(denormalizedReport.draftedBy?.reports[0]); | ||
expect(denormalizedReport.publishedBy).toBe(denormalizedReport.draftedBy); | ||
expect(denormalizedReport.draftedBy?.reports[0].draftedBy).toBe( | ||
denormalizedReport.draftedBy, | ||
); | ||
expect(denormalizedReport).toBeDefined(); | ||
// This is just for TypeScript, the above line actually determines this | ||
if (!denormalizedReport) throw new Error('expected to be defined'); | ||
expect(denormalizedReport).toBe(denormalizedReport.draftedBy?.reports[0]); | ||
expect(denormalizedReport.publishedBy).toBe(denormalizedReport.draftedBy); | ||
expect(denormalizedReport.draftedBy?.reports[0].draftedBy).toBe( | ||
denormalizedReport.draftedBy, | ||
); | ||
const [denormalizedReport2] = denormalize( | ||
'123', | ||
Report, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
const denormalizedReport2 = denormalize( | ||
'123', | ||
Report, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
expect(denormalizedReport2).toStrictEqual(denormalizedReport); | ||
expect(denormalizedReport2).toBe(denormalizedReport); | ||
// NOTE: Given how immutable data works, referential equality can't be | ||
// maintained with nested denormalization. | ||
}); | ||
expect(denormalizedReport2).toStrictEqual(denormalizedReport); | ||
expect(denormalizedReport2).toBe(denormalizedReport); | ||
// NOTE: Given how immutable data works, referential equality can't be | ||
// maintained with nested denormalization. | ||
}); | ||
test('denormalizes maintain referential equality when appropriate', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
test('denormalizes maintain referential equality when appropriate', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
}, | ||
}, | ||
}, | ||
Comment: { | ||
'999': { | ||
id: '999', | ||
body: 'Good morning', | ||
author: '456', | ||
Comment: { | ||
'999': { | ||
id: '999', | ||
body: 'Good morning', | ||
author: '456', | ||
}, | ||
}, | ||
}, | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
}, | ||
'457': { | ||
id: '457', | ||
role: 'servant', | ||
reports: ['123'], | ||
}, | ||
}, | ||
'457': { | ||
id: '457', | ||
role: 'servant', | ||
reports: ['123'], | ||
}, | ||
}, | ||
}; | ||
const entityCache: any = {}; | ||
const resultCache = new WeakEntityMap(); | ||
}; | ||
const entityCache: any = {}; | ||
const resultCache = createResultCache(); | ||
const input = { report: '123', comment: '999' }; | ||
const schema = { | ||
report: Report, | ||
comment: Comment, | ||
}; | ||
const input = { report: '123', comment: '999' }; | ||
const sch = new schema.Object({ | ||
report: Report, | ||
comment: Comment, | ||
}); | ||
const [denormalizedReport] = denormalize( | ||
input, | ||
schema, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
const denormalizedReport = denormalize( | ||
input, | ||
sch, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
expect(denormalizedReport).not.toEqual(expect.any(Symbol)); | ||
if (typeof denormalizedReport === 'symbol') return; | ||
expect(denormalizedReport.report).toBeDefined(); | ||
expect(denormalizedReport.comment).toBeDefined(); | ||
// This is just for TypeScript, the above line actually determines this | ||
if (!denormalizedReport.report || !denormalizedReport.comment) | ||
throw new Error('expected to be defined'); | ||
expect(denormalizedReport.report.publishedBy).toBe( | ||
denormalizedReport.comment.author, | ||
); | ||
expect(denormalizedReport.report).toBeDefined(); | ||
expect(denormalizedReport.comment).toBeDefined(); | ||
// This is just for TypeScript, the above line actually determines this | ||
if (!denormalizedReport.report || !denormalizedReport.comment) | ||
throw new Error('expected to be defined'); | ||
expect(denormalizedReport.report.publishedBy).toBe( | ||
denormalizedReport.comment.author, | ||
); | ||
const [denormalizedReport2] = denormalize( | ||
input, | ||
schema, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
const denormalizedReport2 = denormalize( | ||
input, | ||
sch, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
expect(denormalizedReport2).not.toEqual(expect.any(Symbol)); | ||
if (typeof denormalizedReport2 === 'symbol') return; | ||
expect(denormalizedReport2).toStrictEqual(denormalizedReport); | ||
expect(denormalizedReport2).toBe(denormalizedReport); | ||
expect(denormalizedReport2).toStrictEqual(denormalizedReport); | ||
expect(denormalizedReport2).toBe(denormalizedReport); | ||
// should update all uses of user | ||
const nextEntities = { | ||
...entities, | ||
User: { | ||
...entities.User, | ||
'456': { | ||
...entities.User[456], | ||
role: 'supervisor', | ||
// should update all uses of user | ||
const nextEntities = { | ||
...entities, | ||
User: { | ||
...entities.User, | ||
'456': { | ||
...entities.User[456], | ||
role: 'supervisor', | ||
}, | ||
}, | ||
}, | ||
}; | ||
}; | ||
const [denormalizedReport3] = denormalize( | ||
input, | ||
schema, | ||
nextEntities, | ||
entityCache, | ||
resultCache, | ||
); | ||
const denormalizedReport3 = denormalize( | ||
input, | ||
sch, | ||
nextEntities, | ||
entityCache, | ||
resultCache, | ||
); | ||
expect(denormalizedReport3).not.toEqual(expect.any(Symbol)); | ||
if (typeof denormalizedReport3 === 'symbol') return; | ||
expect(denormalizedReport3.comment?.author?.role).toBe('supervisor'); | ||
expect(denormalizedReport3.report?.draftedBy?.role).toBe('supervisor'); | ||
// NOTE: Given how immutable data works, referential equality can't be | ||
// maintained with nested denormalization. | ||
}); | ||
expect(denormalizedReport3.comment?.author?.role).toBe('supervisor'); | ||
expect(denormalizedReport3.report?.draftedBy?.role).toBe('supervisor'); | ||
// NOTE: Given how immutable data works, referential equality can't be | ||
// maintained with nested denormalization. | ||
}); | ||
describe('optional entities', () => { | ||
it('should be marked as found even when optional is not there', () => { | ||
const [denormalized, found] = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
abc: { | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
requiredArticle: '5' as any, | ||
nextPage: 'blob', | ||
describe('optional entities', () => { | ||
it('should be marked as found even when optional is not there', () => { | ||
const denormalized = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
abc: { | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
requiredArticle: '5' as any, | ||
nextPage: 'blob', | ||
}, | ||
}, | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: { id: '5' }, | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: { id: '5' }, | ||
}, | ||
}); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: null, | ||
requiredArticle: ArticleEntity.fromJS({ id: '5' }), | ||
nextPage: 'blob', | ||
}); | ||
}); | ||
expect(found).toBe(true); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: null, | ||
requiredArticle: ArticleEntity.fromJS({ id: '5' }), | ||
nextPage: 'blob', | ||
}); | ||
}); | ||
it('should be marked as found when nested entity is missing', () => { | ||
const [denormalized, found, deleted] = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
abc: WithOptional.fromJS({ | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
article: '5' as any, | ||
nextPage: 'blob', | ||
}), | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: ArticleEntity.fromJS({ id: '5' }), | ||
}, | ||
it('should be marked as found when nested entity is missing', () => { | ||
const denormalized = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
abc: WithOptional.fromJS({ | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
article: '5' as any, | ||
nextPage: 'blob', | ||
}), | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: ArticleEntity.fromJS({ id: '5' }), | ||
}, | ||
}); | ||
expect(denormalized).not.toEqual(expect.any(Symbol)); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: ArticleEntity.fromJS({ id: '5' }), | ||
requiredArticle: ArticleEntity.fromJS(), | ||
nextPage: 'blob', | ||
}); | ||
}); | ||
expect(found).toBe(true); | ||
expect(deleted).toBe(false); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: ArticleEntity.fromJS({ id: '5' }), | ||
requiredArticle: ArticleEntity.fromJS(), | ||
nextPage: 'blob', | ||
}); | ||
}); | ||
it('should be marked as deleted when required entity is deleted symbol', () => { | ||
const [denormalized, found, deleted] = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
abc: { | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
requiredArticle: '5' as any, | ||
nextPage: 'blob', | ||
it('should be marked as deleted when required entity is deleted symbol', () => { | ||
const denormalized = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
abc: { | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
requiredArticle: '5' as any, | ||
nextPage: 'blob', | ||
}, | ||
}, | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: DELETED, | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: DELETED, | ||
}, | ||
}); | ||
expect(denormalized).toEqual(expect.any(Symbol)); | ||
}); | ||
expect(found).toBe(true); | ||
expect(deleted).toBe(true); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: null, | ||
requiredArticle: undefined, | ||
nextPage: 'blob', | ||
}); | ||
}); | ||
it('should be non-required deleted members should not result in deleted indicator', () => { | ||
const [denormalized, found, deleted] = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
abc: WithOptional.fromJS({ | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
article: '5' as any, | ||
requiredArticle: '6' as any, | ||
nextPage: 'blob', | ||
}), | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: DELETED, | ||
['6']: ArticleEntity.fromJS({ id: '6' }), | ||
}, | ||
}); | ||
expect(found).toBe(true); | ||
expect(deleted).toBe(false); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: undefined, | ||
requiredArticle: ArticleEntity.fromJS({ id: '6' }), | ||
nextPage: 'blob', | ||
}); | ||
}); | ||
it('should be both deleted and not found when both are true in different parts of schema', () => { | ||
const [denormalized, found, deleted] = denormalize( | ||
{ data: 'abc' }, | ||
{ data: WithOptional, other: ArticleEntity }, | ||
{ | ||
it('should be non-required deleted members should not result in deleted indicator', () => { | ||
const denormalized = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
@@ -1277,4 +1244,4 @@ abc: WithOptional.fromJS({ | ||
// this is typed because we're actually sending wrong data to it | ||
article: '6' as any, | ||
requiredArticle: '5' as any, | ||
article: '5' as any, | ||
requiredArticle: '6' as any, | ||
nextPage: 'blob', | ||
@@ -1287,7 +1254,37 @@ }), | ||
}, | ||
}, | ||
); | ||
expect(found).toBe(false); | ||
expect(deleted).toBe(true); | ||
const response = denormalized; | ||
}); | ||
expect(denormalized).not.toEqual(expect.any(Symbol)); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: undefined, | ||
requiredArticle: ArticleEntity.fromJS({ id: '6' }), | ||
nextPage: 'blob', | ||
}); | ||
}); | ||
it('should be deleted when both are true in different parts of schema', () => { | ||
const denormalized = denormalize( | ||
{ data: 'abc' }, | ||
new schema.Object({ data: WithOptional, other: ArticleEntity }), | ||
{ | ||
[WithOptional.key]: { | ||
abc: WithOptional.fromJS({ | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
article: '6' as any, | ||
requiredArticle: '5' as any, | ||
nextPage: 'blob', | ||
}), | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: DELETED, | ||
['6']: ArticleEntity.fromJS({ id: '6' }), | ||
}, | ||
}, | ||
); | ||
expect(denormalized).toEqual(expect.any(Symbol)); | ||
/*const response = denormalized; | ||
expect(response).toBeDefined(); | ||
@@ -1302,5 +1299,8 @@ expect(response).toEqual({ | ||
}); | ||
deleted symbol replaces whole denorm value | ||
*/ | ||
}); | ||
}); | ||
}); | ||
}); | ||
}, | ||
); | ||
@@ -1307,0 +1307,0 @@ describe('Entity.defaults', () => { |
@@ -6,3 +6,4 @@ // eslint-env jest | ||
import denormalize from './denormalize'; | ||
import { denormalizeSimple, denormalize10 } from './denormalize'; | ||
import WeakListMap from './legacy-compat/WeakListMap'; | ||
import { schema } from '../..'; | ||
@@ -349,2 +350,3 @@ | ||
MyEntity, | ||
[], | ||
entities, | ||
@@ -679,3 +681,5 @@ {}, | ||
); | ||
const [final] = denormalize(result, ProcessTaco, entities); | ||
const final = denormalizeSimple(result, ProcessTaco, entities); | ||
expect(final).not.toEqual(expect.any(Symbol)); | ||
if (typeof final === 'symbol') return; | ||
expect(final?.slug).toEqual('thing-1'); | ||
@@ -718,3 +722,5 @@ expect(final).toMatchSnapshot(); | ||
); | ||
const [final] = denormalize(result, ParentEntity, entities); | ||
const final = denormalizeSimple(result, ParentEntity, entities); | ||
expect(final).not.toEqual(expect.any(Symbol)); | ||
if (typeof final === 'symbol') return; | ||
expect(final?.child?.parentId).toEqual('1'); | ||
@@ -767,3 +773,5 @@ expect(final).toMatchSnapshot(); | ||
); | ||
const [final] = denormalize(result, EntriesEntity, entities); | ||
const final = denormalizeSimple(result, EntriesEntity, entities); | ||
expect(final).not.toEqual(expect.any(Symbol)); | ||
if (typeof final === 'symbol') return; | ||
expect(final?.type).toEqual('message'); | ||
@@ -777,120 +785,122 @@ expect(final).toMatchSnapshot(); | ||
describe(`${schema.Entity.name} denormalization`, () => { | ||
test('denormalizes an entity', () => { | ||
const entities = { | ||
Tacos: { | ||
'1': { id: '1', name: 'foo' }, | ||
describe.each([ | ||
['current', denormalizeSimple, () => new WeakEntityMap()], | ||
['legacy', denormalize10, () => new WeakEntityMap()], | ||
] as const)( | ||
`${schema.Entity.name} denormalization (%s)`, | ||
(_, denormalize, createResultCache) => { | ||
test('denormalizes an entity', () => { | ||
const entities = { | ||
Tacos: { | ||
'1': { id: '1', name: 'foo' }, | ||
}, | ||
}; | ||
expect(denormalize('1', Tacos, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Tacos, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
class Food extends schema.Entity( | ||
class { | ||
id = ''; | ||
}, | ||
}; | ||
expect(denormalize('1', Tacos, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Tacos, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
class Food extends schema.Entity( | ||
class { | ||
) {} | ||
class MenuData { | ||
id = ''; | ||
}, | ||
) {} | ||
class MenuData { | ||
id = ''; | ||
readonly food: Food = Food.fromJS(); | ||
} | ||
class Menu extends schema.Entity(MenuData, { schema: { food: Food } }) {} | ||
readonly food: Food = Food.fromJS(); | ||
} | ||
class Menu extends schema.Entity(MenuData, { schema: { food: Food } }) {} | ||
test('denormalizes deep entities', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '1' }, | ||
'2': { id: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
test('denormalizes deep entities', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '1' }, | ||
'2': { id: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
const de1 = denormalize('1', Menu, entities); | ||
expect(de1).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toEqual(de1); | ||
const de1 = denormalize('1', Menu, entities); | ||
expect(de1).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toEqual(de1); | ||
const de2 = denormalize('2', Menu, entities); | ||
expect(de2).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toEqual(de2); | ||
}); | ||
const de2 = denormalize('2', Menu, entities); | ||
expect(de2).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toEqual(de2); | ||
}); | ||
test('denormalizes deep entities while maintaining referential equality', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '1' }, | ||
'2': { id: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
const entityCache = {}; | ||
const resultCache = new WeakEntityMap(); | ||
test('denormalizes deep entities while maintaining referential equality', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '1' }, | ||
'2': { id: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
const entityCache = {}; | ||
const resultCache = createResultCache(); | ||
const [first] = denormalize('1', Menu, entities, entityCache, resultCache); | ||
const [second] = denormalize('1', Menu, entities, entityCache, resultCache); | ||
expect(first).toBe(second); | ||
expect(first?.food).toBe(second?.food); | ||
}); | ||
const first = denormalize('1', Menu, entities, entityCache, resultCache); | ||
const second = denormalize('1', Menu, entities, entityCache, resultCache); | ||
expect(first).not.toEqual(expect.any(Symbol)); | ||
if (typeof first === 'symbol') return; | ||
expect(second).not.toEqual(expect.any(Symbol)); | ||
if (typeof second === 'symbol') return; | ||
expect(first).toBe(second); | ||
expect(first?.food).toBe(second?.food); | ||
}); | ||
test('denormalizes to undefined when validate() returns string', () => { | ||
class MyTacos extends Tacos { | ||
static validate(entity) { | ||
if (!Object.hasOwn(entity, 'name')) return 'no name'; | ||
test('denormalizes to undefined when validate() returns string', () => { | ||
class MyTacos extends Tacos { | ||
static validate(entity) { | ||
if (!Object.hasOwn(entity, 'name')) return 'no name'; | ||
} | ||
} | ||
} | ||
const entities = { | ||
MyTacos: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
expect(denormalize('1', MyTacos, entities)).toStrictEqual([ | ||
undefined, | ||
false, | ||
true, | ||
]); | ||
expect(denormalize('1', MyTacos, fromJS(entities))).toStrictEqual([ | ||
undefined, | ||
false, | ||
true, | ||
]); | ||
}); | ||
const entities = { | ||
MyTacos: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
expect(denormalize('1', MyTacos, entities)).toEqual(expect.any(Symbol)); | ||
expect(denormalize('1', MyTacos, fromJS(entities))).toEqual( | ||
expect.any(Symbol), | ||
); | ||
}); | ||
test('denormalizes to undefined for missing data', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
test('denormalizes to undefined for missing data', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '2' }, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
}, | ||
}; | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
it('should handle optional schema entries Entity', () => { | ||
class MyData { | ||
readonly name: string = ''; | ||
readonly secondthing: string = ''; | ||
readonly blarb: Date | undefined = undefined; | ||
} | ||
class MyEntity extends schema.Entity(MyData, { | ||
pk: 'name', | ||
schema: { blarb: Date }, | ||
}) {} | ||
it('should handle optional schema entries Entity', () => { | ||
class MyData { | ||
readonly name: string = ''; | ||
readonly secondthing: string = ''; | ||
readonly blarb: Date | undefined = undefined; | ||
} | ||
class MyEntity extends schema.Entity(MyData, { | ||
pk: 'name', | ||
schema: { blarb: Date }, | ||
}) {} | ||
expect( | ||
denormalize('bob', MyEntity, { | ||
MyEntity: { bob: { name: 'bob', secondthing: 'hi' } }, | ||
}), | ||
).toMatchInlineSnapshot(` | ||
[ | ||
expect( | ||
denormalize('bob', MyEntity, { | ||
MyEntity: { bob: { name: 'bob', secondthing: 'hi' } }, | ||
}), | ||
).toMatchInlineSnapshot(` | ||
MyEntity { | ||
@@ -900,26 +910,22 @@ "blarb": undefined, | ||
"secondthing": "hi", | ||
}, | ||
true, | ||
false, | ||
] | ||
`); | ||
}); | ||
} | ||
`); | ||
}); | ||
it('should handle null schema entries Entity', () => { | ||
class MyData { | ||
readonly name: string = ''; | ||
readonly secondthing: string = ''; | ||
readonly blarb: Date | null = null; | ||
} | ||
class MyEntity extends schema.Entity(MyData, { | ||
pk: 'name', | ||
schema: { blarb: Date }, | ||
}) {} | ||
it('should handle null schema entries Entity', () => { | ||
class MyData { | ||
readonly name: string = ''; | ||
readonly secondthing: string = ''; | ||
readonly blarb: Date | null = null; | ||
} | ||
class MyEntity extends schema.Entity(MyData, { | ||
pk: 'name', | ||
schema: { blarb: Date }, | ||
}) {} | ||
expect( | ||
denormalize('bob', MyEntity, { | ||
MyEntity: { bob: { name: 'bob', secondthing: 'hi', blarb: null } }, | ||
}), | ||
).toMatchInlineSnapshot(` | ||
[ | ||
expect( | ||
denormalize('bob', MyEntity, { | ||
MyEntity: { bob: { name: 'bob', secondthing: 'hi', blarb: null } }, | ||
}), | ||
).toMatchInlineSnapshot(` | ||
MyEntity { | ||
@@ -929,313 +935,320 @@ "blarb": null, | ||
"secondthing": "hi", | ||
} | ||
`); | ||
}); | ||
test('denormalizes to undefined for deleted data', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '2' }, | ||
'2': DELETED, | ||
}, | ||
true, | ||
false, | ||
] | ||
`); | ||
}); | ||
Food: { | ||
'1': { id: '1' }, | ||
'2': DELETED, | ||
}, | ||
}; | ||
test('denormalizes to undefined for deleted data', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: '2' }, | ||
'2': DELETED, | ||
}, | ||
Food: { | ||
'1': { id: '1' }, | ||
'2': DELETED, | ||
}, | ||
}; | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
test('denormalizes deep entities with records', () => { | ||
const Food = Record<{ id: null | string }>({ id: null }); | ||
const MenuR = Record<{ id: null | string; food: null | string }>({ | ||
id: null, | ||
food: null, | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
const entities = { | ||
Menu: { | ||
'1': new MenuR({ id: '1', food: '1' }), | ||
'2': new MenuR({ id: '2' }), | ||
}, | ||
Food: { | ||
'1': new Food({ id: '1' }), | ||
}, | ||
}; | ||
test('denormalizes deep entities with records', () => { | ||
const Food = Record<{ id: null | string }>({ id: null }); | ||
const MenuR = Record<{ id: null | string; food: null | string }>({ | ||
id: null, | ||
food: null, | ||
}); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
const entities = { | ||
Menu: { | ||
'1': new MenuR({ id: '1', food: '1' }), | ||
'2': new MenuR({ id: '2' }), | ||
}, | ||
Food: { | ||
'1': new Food({ id: '1' }), | ||
}, | ||
}; | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
test('can denormalize already partially denormalized data', () => { | ||
const entities = { | ||
Menu: { | ||
'1': { id: '1', food: { id: '1' } }, | ||
}, | ||
Food: { | ||
// TODO: BREAKING CHANGE: Update this to use main entity and only return nested as 'fallback' in case main entity is not set | ||
'1': { id: '1', extra: 'hi' }, | ||
}, | ||
}; | ||
expect(denormalize('2', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('2', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
describe('nesting', () => { | ||
class UserData { | ||
id = ''; | ||
readonly role = ''; | ||
readonly reports: Report[] = []; | ||
} | ||
class User extends schema.Entity(UserData) {} | ||
class ReportData { | ||
id = ''; | ||
readonly title: string = ''; | ||
readonly draftedBy: User = User.fromJS(); | ||
readonly publishedBy: User = User.fromJS(); | ||
} | ||
class Report extends schema.Entity(ReportData, { | ||
schema: { | ||
draftedBy: User, | ||
publishedBy: User, | ||
}, | ||
}) {} | ||
User.schema = { | ||
reports: [Report], | ||
}; | ||
class CommentData { | ||
id = ''; | ||
readonly body: string = ''; | ||
readonly author: User = User.fromJS(); | ||
} | ||
class Comment extends schema.Entity(CommentData, { | ||
schema: { author: User }, | ||
}) {} | ||
test('denormalizes recursive dependencies', () => { | ||
test('can denormalize already partially denormalized data', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
}, | ||
Menu: { | ||
'1': { id: '1', food: { id: '1' } }, | ||
}, | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
}, | ||
Food: { | ||
// TODO: BREAKING CHANGE: Update this to use main entity and only return nested as 'fallback' in case main entity is not set | ||
'1': { id: '1', extra: 'hi' }, | ||
}, | ||
}; | ||
expect(denormalize('123', Report, entities)[0]).toMatchSnapshot(); | ||
expect(denormalize('123', Report, fromJS(entities))[0]).toMatchSnapshot(); | ||
expect(denormalize('456', User, entities)[0]).toMatchSnapshot(); | ||
expect(denormalize('456', User, fromJS(entities))[0]).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', Menu, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
test('denormalizes recursive entities with referential equality', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
}, | ||
describe('nesting', () => { | ||
class UserData { | ||
id = ''; | ||
readonly role = ''; | ||
readonly reports: Report[] = []; | ||
} | ||
class User extends schema.Entity(UserData) {} | ||
class ReportData { | ||
id = ''; | ||
readonly title: string = ''; | ||
readonly draftedBy: User = User.fromJS(); | ||
readonly publishedBy: User = User.fromJS(); | ||
} | ||
class Report extends schema.Entity(ReportData, { | ||
schema: { | ||
draftedBy: User, | ||
publishedBy: User, | ||
}, | ||
Comment: { | ||
'999': { | ||
id: '999', | ||
body: 'Good morning', | ||
author: '456', | ||
}) {} | ||
User.schema = { | ||
reports: new schema.Array(Report), | ||
}; | ||
class CommentData { | ||
id = ''; | ||
readonly body: string = ''; | ||
readonly author: User = User.fromJS(); | ||
} | ||
class Comment extends schema.Entity(CommentData, { | ||
schema: { author: User }, | ||
}) {} | ||
test('denormalizes recursive dependencies', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
}, | ||
}, | ||
}, | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
}, | ||
}, | ||
'457': { | ||
id: '457', | ||
role: 'servant', | ||
reports: ['123'], | ||
}; | ||
expect(denormalize('123', Report, entities)).toMatchSnapshot(); | ||
expect(denormalize('123', Report, fromJS(entities))).toMatchSnapshot(); | ||
expect(denormalize('456', User, entities)).toMatchSnapshot(); | ||
expect(denormalize('456', User, fromJS(entities))).toMatchSnapshot(); | ||
}); | ||
test('denormalizes recursive entities with referential equality', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
}, | ||
}, | ||
}, | ||
}; | ||
const entityCache: any = {}; | ||
const resultCache = new WeakEntityMap(); | ||
Comment: { | ||
'999': { | ||
id: '999', | ||
body: 'Good morning', | ||
author: '456', | ||
}, | ||
}, | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
}, | ||
'457': { | ||
id: '457', | ||
role: 'servant', | ||
reports: ['123'], | ||
}, | ||
}, | ||
}; | ||
const entityCache: any = {}; | ||
const resultCache = createResultCache(); | ||
const [denormalizedReport] = denormalize( | ||
'123', | ||
Report, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
const denormalizedReport = denormalize( | ||
'123', | ||
Report, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
expect(denormalizedReport).not.toEqual(expect.any(Symbol)); | ||
if (typeof denormalizedReport === 'symbol') return; | ||
expect(denormalizedReport).toBeDefined(); | ||
// This is just for TypeScript, the above line actually determines this | ||
if (!denormalizedReport) throw new Error('expected to be defined'); | ||
expect(denormalizedReport).toBe(denormalizedReport.draftedBy?.reports[0]); | ||
expect(denormalizedReport.publishedBy).toBe(denormalizedReport.draftedBy); | ||
expect(denormalizedReport.draftedBy?.reports[0].draftedBy).toBe( | ||
denormalizedReport.draftedBy, | ||
); | ||
expect(denormalizedReport).toBeDefined(); | ||
// This is just for TypeScript, the above line actually determines this | ||
if (!denormalizedReport) throw new Error('expected to be defined'); | ||
expect(denormalizedReport).toBe( | ||
denormalizedReport.draftedBy?.reports[0], | ||
); | ||
expect(denormalizedReport.publishedBy).toBe( | ||
denormalizedReport.draftedBy, | ||
); | ||
expect(denormalizedReport.draftedBy?.reports[0].draftedBy).toBe( | ||
denormalizedReport.draftedBy, | ||
); | ||
const [denormalizedReport2] = denormalize( | ||
'123', | ||
Report, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
const denormalizedReport2 = denormalize( | ||
'123', | ||
Report, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
expect(denormalizedReport2).not.toEqual(expect.any(Symbol)); | ||
if (typeof denormalizedReport2 === 'symbol') return; | ||
expect(denormalizedReport2).toStrictEqual(denormalizedReport); | ||
expect(denormalizedReport2).toBe(denormalizedReport); | ||
// NOTE: Given how immutable data works, referential equality can't be | ||
// maintained with nested denormalization. | ||
}); | ||
expect(denormalizedReport2).toStrictEqual(denormalizedReport); | ||
expect(denormalizedReport2).toBe(denormalizedReport); | ||
// NOTE: Given how immutable data works, referential equality can't be | ||
// maintained with nested denormalization. | ||
}); | ||
test('denormalizes maintain referential equality when appropriate', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
test('denormalizes maintain referential equality when appropriate', () => { | ||
const entities = { | ||
Report: { | ||
'123': { | ||
id: '123', | ||
title: 'Weekly report', | ||
draftedBy: '456', | ||
publishedBy: '456', | ||
}, | ||
}, | ||
}, | ||
Comment: { | ||
'999': { | ||
id: '999', | ||
body: 'Good morning', | ||
author: '456', | ||
Comment: { | ||
'999': { | ||
id: '999', | ||
body: 'Good morning', | ||
author: '456', | ||
}, | ||
}, | ||
}, | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
User: { | ||
'456': { | ||
id: '456', | ||
role: 'manager', | ||
reports: ['123'], | ||
}, | ||
'457': { | ||
id: '457', | ||
role: 'servant', | ||
reports: ['123'], | ||
}, | ||
}, | ||
'457': { | ||
id: '457', | ||
role: 'servant', | ||
reports: ['123'], | ||
}, | ||
}, | ||
}; | ||
const entityCache: any = {}; | ||
const resultCache = new WeakEntityMap(); | ||
}; | ||
const entityCache: any = {}; | ||
const resultCache = createResultCache(); | ||
const input = { report: '123', comment: '999' }; | ||
const schema = { | ||
report: Report, | ||
comment: Comment, | ||
}; | ||
const input = { report: '123', comment: '999' }; | ||
const sch = new schema.Object({ | ||
report: Report, | ||
comment: Comment, | ||
}); | ||
const [denormalizedReport] = denormalize( | ||
input, | ||
schema, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
const denormalizedReport = denormalize( | ||
input, | ||
sch, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
expect(denormalizedReport).not.toEqual(expect.any(Symbol)); | ||
if (typeof denormalizedReport === 'symbol') return; | ||
expect(denormalizedReport.report).toBeDefined(); | ||
expect(denormalizedReport.comment).toBeDefined(); | ||
// This is just for TypeScript, the above line actually determines this | ||
if (!denormalizedReport.report || !denormalizedReport.comment) | ||
throw new Error('expected to be defined'); | ||
expect(denormalizedReport.report.publishedBy).toBe( | ||
denormalizedReport.comment.author, | ||
); | ||
expect(denormalizedReport.report).toBeDefined(); | ||
expect(denormalizedReport.comment).toBeDefined(); | ||
// This is just for TypeScript, the above line actually determines this | ||
if (!denormalizedReport.report || !denormalizedReport.comment) | ||
throw new Error('expected to be defined'); | ||
expect(denormalizedReport.report.publishedBy).toBe( | ||
denormalizedReport.comment.author, | ||
); | ||
const [denormalizedReport2] = denormalize( | ||
input, | ||
schema, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
const denormalizedReport2 = denormalize( | ||
input, | ||
sch, | ||
entities, | ||
entityCache, | ||
resultCache, | ||
); | ||
expect(denormalizedReport2).not.toEqual(expect.any(Symbol)); | ||
if (typeof denormalizedReport2 === 'symbol') return; | ||
expect(denormalizedReport2).toStrictEqual(denormalizedReport); | ||
expect(denormalizedReport2).toBe(denormalizedReport); | ||
expect(denormalizedReport2).toStrictEqual(denormalizedReport); | ||
expect(denormalizedReport2).toBe(denormalizedReport); | ||
// should update all uses of user | ||
const nextEntities = { | ||
...entities, | ||
User: { | ||
...entities.User, | ||
'456': { | ||
...entities.User[456], | ||
role: 'supervisor', | ||
// should update all uses of user | ||
const nextEntities = { | ||
...entities, | ||
User: { | ||
...entities.User, | ||
'456': { | ||
...entities.User[456], | ||
role: 'supervisor', | ||
}, | ||
}, | ||
}, | ||
}; | ||
}; | ||
const [denormalizedReport3] = denormalize( | ||
input, | ||
schema, | ||
nextEntities, | ||
entityCache, | ||
resultCache, | ||
); | ||
const denormalizedReport3 = denormalize( | ||
input, | ||
sch, | ||
nextEntities, | ||
entityCache, | ||
resultCache, | ||
); | ||
expect(denormalizedReport3).not.toEqual(expect.any(Symbol)); | ||
if (typeof denormalizedReport3 === 'symbol') return; | ||
expect(denormalizedReport3.comment?.author?.role).toBe('supervisor'); | ||
expect(denormalizedReport3.report?.draftedBy?.role).toBe('supervisor'); | ||
// NOTE: Given how immutable data works, referential equality can't be | ||
// maintained with nested denormalization. | ||
}); | ||
expect(denormalizedReport3.comment?.author?.role).toBe('supervisor'); | ||
expect(denormalizedReport3.report?.draftedBy?.role).toBe('supervisor'); | ||
// NOTE: Given how immutable data works, referential equality can't be | ||
// maintained with nested denormalization. | ||
}); | ||
describe('optional entities', () => { | ||
it('should be marked as found even when optional is not there', () => { | ||
const [denormalized, found] = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
abc: { | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
requiredArticle: '5' as any, | ||
nextPage: 'blob', | ||
describe('optional entities', () => { | ||
it('should be marked as found even when optional is not there', () => { | ||
const denormalized = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
abc: { | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
requiredArticle: '5' as any, | ||
nextPage: 'blob', | ||
}, | ||
}, | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: { id: '5' }, | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: { id: '5' }, | ||
}, | ||
}); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: null, | ||
requiredArticle: ArticleEntity.fromJS({ id: '5' }), | ||
nextPage: 'blob', | ||
}); | ||
}); | ||
expect(found).toBe(true); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: null, | ||
requiredArticle: ArticleEntity.fromJS({ id: '5' }), | ||
nextPage: 'blob', | ||
}); | ||
}); | ||
it('should be marked as found when nested entity is missing', () => { | ||
const [denormalized, found, deleted] = denormalize( | ||
'abc', | ||
WithOptional, | ||
{ | ||
it('should be marked as found when nested entity is missing', () => { | ||
const denormalized = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
@@ -1252,22 +1265,19 @@ abc: WithOptional.fromJS({ | ||
}, | ||
}, | ||
); | ||
expect(found).toBe(true); | ||
expect(deleted).toBe(false); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: ArticleEntity.fromJS({ id: '5' }), | ||
requiredArticle: ArticleEntity.fromJS(), | ||
nextPage: 'blob', | ||
}); | ||
expect(denormalized).not.toEqual(expect.any(Symbol)); | ||
if (typeof denormalized === 'symbol') return; | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: ArticleEntity.fromJS({ id: '5' }), | ||
requiredArticle: ArticleEntity.fromJS(), | ||
nextPage: 'blob', | ||
}); | ||
}); | ||
}); | ||
it('should be marked as deleted when required entity is deleted symbol', () => { | ||
const [denormalized, found, deleted] = denormalize( | ||
'abc', | ||
WithOptional, | ||
{ | ||
it('should be marked as deleted when required entity is deleted symbol', () => { | ||
const denormalized = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
@@ -1284,22 +1294,8 @@ abc: { | ||
}, | ||
}, | ||
); | ||
expect(found).toBe(true); | ||
expect(deleted).toBe(true); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: null, | ||
requiredArticle: undefined, | ||
nextPage: 'blob', | ||
}); | ||
expect(denormalized).toEqual(expect.any(Symbol)); | ||
}); | ||
}); | ||
it('should be non-required deleted members should not result in deleted indicator', () => { | ||
const [denormalized, found, deleted] = denormalize( | ||
'abc', | ||
WithOptional, | ||
{ | ||
it('should be non-required deleted members should not result in deleted indicator', () => { | ||
const denormalized = denormalize('abc', WithOptional, { | ||
[WithOptional.key]: { | ||
@@ -1318,53 +1314,42 @@ abc: WithOptional.fromJS({ | ||
}, | ||
}, | ||
); | ||
expect(found).toBe(true); | ||
expect(deleted).toBe(false); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: undefined, | ||
requiredArticle: ArticleEntity.fromJS({ id: '6' }), | ||
nextPage: 'blob', | ||
}); | ||
expect(denormalized).not.toEqual(expect.any(Symbol)); | ||
if (typeof denormalized === 'symbol') return; | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toBeInstanceOf(WithOptional); | ||
expect(response).toEqual({ | ||
id: 'abc', | ||
article: undefined, | ||
requiredArticle: ArticleEntity.fromJS({ id: '6' }), | ||
nextPage: 'blob', | ||
}); | ||
}); | ||
}); | ||
it('should be both deleted and not found when both are true in different parts of schema', () => { | ||
const [denormalized, found, deleted] = denormalize( | ||
{ data: 'abc' }, | ||
{ data: WithOptional, other: ArticleEntity }, | ||
{ | ||
[WithOptional.key]: { | ||
abc: WithOptional.fromJS({ | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
article: '6' as any, | ||
requiredArticle: '5' as any, | ||
nextPage: 'blob', | ||
}), | ||
it('should be both deleted and not found when both are true in different parts of schema', () => { | ||
const denormalized = denormalize( | ||
{ data: 'abc' }, | ||
new schema.Object({ data: WithOptional, other: ArticleEntity }), | ||
{ | ||
[WithOptional.key]: { | ||
abc: WithOptional.fromJS({ | ||
id: 'abc', | ||
// this is typed because we're actually sending wrong data to it | ||
article: '6' as any, | ||
requiredArticle: '5' as any, | ||
nextPage: 'blob', | ||
}), | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: DELETED, | ||
['6']: ArticleEntity.fromJS({ id: '6' }), | ||
}, | ||
}, | ||
[ArticleEntity.key]: { | ||
['5']: DELETED, | ||
['6']: ArticleEntity.fromJS({ id: '6' }), | ||
}, | ||
}, | ||
); | ||
expect(found).toBe(false); | ||
expect(deleted).toBe(true); | ||
const response = denormalized; | ||
expect(response).toBeDefined(); | ||
expect(response).toEqual({ | ||
data: { | ||
id: 'abc', | ||
article: ArticleEntity.fromJS({ id: '6' }), | ||
requiredArticle: undefined, | ||
nextPage: 'blob', | ||
}, | ||
); | ||
expect(denormalized).toEqual(expect.any(Symbol)); | ||
}); | ||
}); | ||
}); | ||
}); | ||
}); | ||
}, | ||
); | ||
@@ -1371,0 +1356,0 @@ describe('Entity.defaults', () => { |
@@ -77,3 +77,3 @@ /** | ||
// { [DRAFT] } means we are still processing - which if found indicates a cycle | ||
wrappedUnvisit.setLocal = entityCopy => | ||
(wrappedUnvisit as any).setLocal = (entityCopy: any) => | ||
(localCache[schema.key][pk] = { [DRAFT]: entityCopy, i: trackingIndex }); | ||
@@ -159,3 +159,4 @@ | ||
input, | ||
schema, | ||
// this casting is ok because the interface was never exposed to users | ||
schema as any, | ||
unvisit, | ||
@@ -300,3 +301,3 @@ getEntity, | ||
// this is due to only needed the next level of nested entities for lookup | ||
const originalUnvisit = unvisit.og || unvisit; | ||
const originalUnvisit = (unvisit as any).og || unvisit; | ||
const wrappedUnvisit = (input: any, schema: any) => | ||
@@ -307,2 +308,2 @@ originalUnvisit(input, schema); | ||
} | ||
it('should', () => {}); | ||
it('[helper file in test folder]', () => {}); |
@@ -71,2 +71,2 @@ /** Link in a chain */ | ||
} | ||
it('should', () => {}); | ||
it('[helper file in test folder]', () => {}); |
@@ -131,5 +131,5 @@ // eslint-env jest | ||
const object = new schema.Object({ | ||
item: { | ||
item: new schema.Object({ | ||
user: User, | ||
}, | ||
}), | ||
}); | ||
@@ -141,15 +141,8 @@ const entities = { | ||
}; | ||
let [value, found] = denormalize({ item: null }, object, entities); | ||
let value = denormalize({ item: null }, object, entities); | ||
expect(value).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
[value, found] = denormalize({ item: null }, object, fromJS(entities)); | ||
value = denormalize({ item: null }, object, fromJS(entities)); | ||
expect(value).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
[value, found] = denormalize( | ||
fromJS({ item: null }), | ||
object, | ||
fromJS(entities), | ||
); | ||
value = denormalize(fromJS({ item: null }), object, fromJS(entities)); | ||
expect(value).toMatchSnapshot(); | ||
expect(found).toBe(true); | ||
}); | ||
@@ -156,0 +149,0 @@ |
// eslint-env jest | ||
import { inferResults } from '@rest-hooks/normalizr'; | ||
import { WeakEntityMap, inferResults } from '@rest-hooks/normalizr'; | ||
import { IDEntity } from '__tests__/new'; | ||
import { fromJS } from 'immutable'; | ||
import denormalize from './denormalize'; | ||
import { denormalizeSimple, denormalize10 } from './denormalize'; | ||
import { schema, Query, Denormalize, DenormalizeNullable } from '../..'; | ||
@@ -27,100 +27,108 @@ | ||
], | ||
])( | ||
`${schema.Array.name} denormalization (%s)`, | ||
(_, createInput, createOutput) => { | ||
class User extends IDEntity { | ||
name = ''; | ||
isAdmin = false; | ||
} | ||
const sortedUsers = new Query( | ||
new schema.Object({ results: new schema.All(User) }), | ||
({ results }, { asc } = { asc: false }) => { | ||
const sorted = [...results].sort((a, b) => | ||
a.name.localeCompare(b.name), | ||
); | ||
if (asc) return sorted; | ||
return sorted.reverse(); | ||
}, | ||
); | ||
test('denormalize sorts', () => { | ||
const entities = { | ||
User: { | ||
1: { id: '1', name: 'Milo' }, | ||
2: { id: '2', name: 'Jake' }, | ||
3: { id: '3', name: 'Zeta' }, | ||
4: { id: '4', name: 'Alpha' }, | ||
])(`input (%s)`, (_, createInput, createOutput) => { | ||
describe.each([ | ||
['current', denormalizeSimple, () => new WeakEntityMap()], | ||
['legacy', denormalize10, () => new WeakEntityMap()], | ||
] as const)( | ||
`${Query.name} denormalization (%s)`, | ||
(_, denormalize, createResultCache) => { | ||
class User extends IDEntity { | ||
name = ''; | ||
isAdmin = false; | ||
} | ||
const sortedUsers = new Query( | ||
new schema.Object({ results: new schema.All(User) }), | ||
({ results }, { asc } = { asc: false }) => { | ||
const sorted = [...results].sort((a, b) => | ||
a.name.localeCompare(b.name), | ||
); | ||
if (asc) return sorted; | ||
return sorted.reverse(); | ||
}, | ||
}; | ||
const users: DenormalizeNullable<typeof sortedUsers.schema> = denormalize( | ||
inferResults(sortedUsers.schema, [], {}, entities), | ||
sortedUsers.schema, | ||
createInput(entities), | ||
)[0]; | ||
expect(users && users[0].name).toBe('Zeta'); | ||
expect(users).toMatchSnapshot(); | ||
}); | ||
); | ||
test('denormalize sorts with arg', () => { | ||
const entities = { | ||
User: { | ||
1: { id: '1', name: 'Milo' }, | ||
2: { id: '2', name: 'Jake' }, | ||
3: { id: '3', name: 'Zeta' }, | ||
4: { id: '4', name: 'Alpha' }, | ||
}, | ||
}; | ||
expect( | ||
denormalize( | ||
inferResults(sortedUsers.schema, [{ asc: true }], {}, entities), | ||
test('denormalize sorts', () => { | ||
const entities = { | ||
User: { | ||
1: { id: '1', name: 'Milo' }, | ||
2: { id: '2', name: 'Jake' }, | ||
3: { id: '3', name: 'Zeta' }, | ||
4: { id: '4', name: 'Alpha' }, | ||
}, | ||
}; | ||
const users: DenormalizeNullable<typeof sortedUsers.schema> | symbol = | ||
denormalize( | ||
inferResults(sortedUsers.schema, [], {}, entities), | ||
sortedUsers.schema, | ||
createInput(entities), | ||
); | ||
expect(users).not.toEqual(expect.any(Symbol)); | ||
if (typeof users === 'symbol') return; | ||
expect(users && users[0].name).toBe('Zeta'); | ||
expect(users).toMatchSnapshot(); | ||
}); | ||
test('denormalize sorts with arg', () => { | ||
const entities = { | ||
User: { | ||
1: { id: '1', name: 'Milo' }, | ||
2: { id: '2', name: 'Jake' }, | ||
3: { id: '3', name: 'Zeta' }, | ||
4: { id: '4', name: 'Alpha' }, | ||
}, | ||
}; | ||
expect( | ||
denormalize( | ||
inferResults(sortedUsers.schema, [{ asc: true }], {}, entities), | ||
sortedUsers.schema, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
test('denormalizes should not be found when no entities are present', () => { | ||
const entities = { | ||
DOG: { | ||
1: { id: '1', name: 'Milo' }, | ||
2: { id: '2', name: 'Jake' }, | ||
}, | ||
}; | ||
const input = inferResults(sortedUsers.schema, [], {}, entities); | ||
const value = denormalize( | ||
createInput(input), | ||
sortedUsers.schema, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
); | ||
test('denormalizes should not be found when no entities are present', () => { | ||
const entities = { | ||
DOG: { | ||
1: { id: '1', name: 'Milo' }, | ||
2: { id: '2', name: 'Jake' }, | ||
}, | ||
}; | ||
const input = inferResults(sortedUsers.schema, [], {}, entities); | ||
expect(createOutput(value)).toEqual(undefined); | ||
}); | ||
const [value, found] = denormalize( | ||
createInput(input), | ||
sortedUsers.schema, | ||
createInput(entities), | ||
); | ||
expect(found).toBe(false); | ||
expect(createOutput(value)).toEqual(undefined); | ||
}); | ||
test('denormalize aggregates', () => { | ||
const userCountByAdmin = new Query( | ||
new schema.Object({ results: new schema.All(User) }), | ||
({ results }, { isAdmin }: { isAdmin?: boolean } = {}) => { | ||
if (isAdmin === undefined) return results.length; | ||
return results.filter(user => user.isAdmin === isAdmin).length; | ||
}, | ||
); | ||
const entities = { | ||
User: { | ||
1: { id: '1', name: 'Milo' }, | ||
2: { id: '2', name: 'Jake', isAdmin: true }, | ||
3: { id: '3', name: 'Zeta' }, | ||
4: { id: '4', name: 'Alpha' }, | ||
}, | ||
}; | ||
const totalCount: DenormalizeNullable<typeof userCountByAdmin.schema> = | ||
denormalize( | ||
test('denormalize aggregates', () => { | ||
const userCountByAdmin = new Query( | ||
new schema.Object({ results: new schema.All(User) }), | ||
({ results }, { isAdmin }: { isAdmin?: boolean } = {}) => { | ||
if (isAdmin === undefined) return results.length; | ||
return results.filter(user => user.isAdmin === isAdmin).length; | ||
}, | ||
); | ||
const entities = { | ||
User: { | ||
1: { id: '1', name: 'Milo' }, | ||
2: { id: '2', name: 'Jake', isAdmin: true }, | ||
3: { id: '3', name: 'Zeta' }, | ||
4: { id: '4', name: 'Alpha' }, | ||
}, | ||
}; | ||
const totalCount: | ||
| DenormalizeNullable<typeof userCountByAdmin.schema> | ||
| symbol = denormalize( | ||
inferResults(userCountByAdmin.schema, [], {}, entities), | ||
userCountByAdmin.schema, | ||
createInput(entities), | ||
)[0]; | ||
expect(totalCount).toBe(4); | ||
const nonAdminCount: DenormalizeNullable<typeof userCountByAdmin.schema> = | ||
denormalize( | ||
); | ||
expect(totalCount).toBe(4); | ||
const nonAdminCount: | ||
| DenormalizeNullable<typeof userCountByAdmin.schema> | ||
| symbol = denormalize( | ||
inferResults( | ||
@@ -134,6 +142,7 @@ userCountByAdmin.schema, | ||
createInput(entities), | ||
)[0]; | ||
expect(nonAdminCount).toBe(3); | ||
const adminCount: DenormalizeNullable<typeof userCountByAdmin.schema> = | ||
denormalize( | ||
); | ||
expect(nonAdminCount).toBe(3); | ||
const adminCount: | ||
| DenormalizeNullable<typeof userCountByAdmin.schema> | ||
| symbol = denormalize( | ||
inferResults( | ||
@@ -147,11 +156,13 @@ userCountByAdmin.schema, | ||
createInput(entities), | ||
)[0]; | ||
expect(adminCount).toBe(1); | ||
); | ||
expect(adminCount).toBe(1); | ||
if (typeof totalCount === 'symbol') return; | ||
// typecheck | ||
totalCount !== undefined && totalCount + 5; | ||
// @ts-expect-error | ||
totalCount?.bob; | ||
}); | ||
}, | ||
); | ||
// typecheck | ||
totalCount !== undefined && totalCount + 5; | ||
// @ts-expect-error | ||
totalCount?.bob; | ||
}); | ||
}, | ||
); | ||
}); |
@@ -77,3 +77,3 @@ // eslint-env jest | ||
}; | ||
const [response, found] = denormalize( | ||
const response = denormalize( | ||
{ | ||
@@ -87,2 +87,4 @@ user: '1', | ||
); | ||
expect(response).not.toEqual(expect.any(Symbol)); | ||
if (typeof response === 'symbol') return; | ||
expect(response.anotherItem).toBeInstanceOf(Other); | ||
@@ -93,3 +95,2 @@ expect(response.time.getTime()).toBe(response.time.getTime()); | ||
); | ||
expect(found).toBe(true); | ||
expect(response).toMatchSnapshot(); | ||
@@ -108,3 +109,3 @@ }); | ||
}; | ||
const [response, found] = denormalize( | ||
const response = denormalize( | ||
{ | ||
@@ -118,2 +119,4 @@ user: '1', | ||
); | ||
expect(response).not.toEqual(expect.any(Symbol)); | ||
if (typeof response === 'symbol') return; | ||
expect(response.anotherItem).toBeInstanceOf(Other); | ||
@@ -124,5 +127,4 @@ expect(response.time.getTime()).toBe(response.time.getTime()); | ||
); | ||
expect(found).toBe(true); | ||
expect(response).toMatchSnapshot(); | ||
}); | ||
}); |
@@ -7,3 +7,3 @@ // eslint-env jest | ||
import denormalize from './denormalize'; | ||
import { denormalizeSimple, denormalizeLegacy } from './denormalize'; | ||
import { schema } from '../../'; | ||
@@ -241,3 +241,3 @@ | ||
expect( | ||
denormalize(denorm.result, waterfallSchema, denorm.entities), | ||
denormalizeSimple(denorm.result, waterfallSchema, denorm.entities), | ||
).toMatchSnapshot(); | ||
@@ -247,110 +247,104 @@ }); | ||
describe(`${schema.Union.name} denormalization`, () => { | ||
class User extends IDEntity {} | ||
class Group extends IDEntity {} | ||
const entities = { | ||
User: { | ||
1: { id: '1', username: 'Janey', type: 'users' }, | ||
}, | ||
Group: { | ||
2: { id: '2', groupname: 'People', type: 'groups' }, | ||
}, | ||
}; | ||
class User extends IDEntity {} | ||
class Group extends IDEntity {} | ||
const entities = { | ||
User: { | ||
1: { id: '1', username: 'Janey', type: 'users' }, | ||
}, | ||
Group: { | ||
2: { id: '2', groupname: 'People', type: 'groups' }, | ||
}, | ||
}; | ||
describe.each([ | ||
['direct', data => data], | ||
['immutable', fromJS], | ||
])(`input (%s)`, (_, createInput) => { | ||
describe.each([ | ||
['current', denormalizeSimple], | ||
['legacy', denormalizeLegacy], | ||
])(`${schema.Union.name} denormalization (%s)`, (_, denormalize) => { | ||
test('denormalizes an object using string schemaAttribute', () => { | ||
const union = new schema.Union( | ||
{ | ||
users: User, | ||
groups: Group, | ||
}, | ||
'type', | ||
); | ||
test('denormalizes an object using string schemaAttribute', () => { | ||
const union = new schema.Union( | ||
{ | ||
users: User, | ||
groups: Group, | ||
}, | ||
'type', | ||
); | ||
expect( | ||
denormalize( | ||
createInput({ id: '1', schema: 'users' }), | ||
union, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize({ id: '1', schema: 'users' }, union, entities), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
fromJS({ id: '1', schema: 'users' }), | ||
union, | ||
fromJS(entities), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
createInput({ id: '2', schema: 'groups' }), | ||
union, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
expect( | ||
denormalize({ id: '2', schema: 'groups' }, union, entities), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
fromJS({ id: '2', schema: 'groups' }), | ||
union, | ||
fromJS(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
test('denormalizes an array of multiple entities using a function to infer the schemaAttribute', () => { | ||
const union = new schema.Union( | ||
{ | ||
users: User, | ||
groups: Group, | ||
}, | ||
input => { | ||
return input.username ? 'users' : 'groups'; | ||
}, | ||
); | ||
test('denormalizes an array of multiple entities using a function to infer the schemaAttribute', () => { | ||
const union = new schema.Union( | ||
{ | ||
users: User, | ||
groups: Group, | ||
}, | ||
input => { | ||
return input.username ? 'users' : 'groups'; | ||
}, | ||
); | ||
expect( | ||
denormalize( | ||
createInput({ id: '1', schema: 'users' }), | ||
union, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize({ id: '1', schema: 'users' }, union, entities), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
fromJS({ id: '1', schema: 'users' }), | ||
union, | ||
fromJS(entities), | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
createInput({ id: '2', schema: 'groups' }), | ||
union, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
expect( | ||
denormalize({ id: '2', schema: 'groups' }, union, entities), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
fromJS({ id: '2', schema: 'groups' }), | ||
union, | ||
fromJS(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
test('returns the original value when no schema is given', () => { | ||
const union = new schema.Union( | ||
{ | ||
users: User, | ||
groups: Group, | ||
}, | ||
input => { | ||
return input.username ? 'users' : 'groups'; | ||
}, | ||
); | ||
test('returns the original value when no schema is given', () => { | ||
const union = new schema.Union( | ||
{ | ||
users: User, | ||
groups: Group, | ||
}, | ||
input => { | ||
return input.username ? 'users' : 'groups'; | ||
}, | ||
); | ||
expect( | ||
denormalize(createInput({ id: '1' }), union, createInput(entities)), | ||
).toMatchSnapshot(); | ||
}); | ||
expect(denormalize({ id: '1' }, union, entities)).toMatchSnapshot(); | ||
expect( | ||
denormalize(fromJS({ id: '1' }), union, fromJS(entities)), | ||
).toMatchSnapshot(); | ||
}); | ||
test('returns the original value when string is given', () => { | ||
const union = new schema.Union( | ||
{ | ||
users: User, | ||
groups: Group, | ||
}, | ||
input => { | ||
return input.username ? 'users' : 'groups'; | ||
}, | ||
); | ||
test('returns the original value when string is given', () => { | ||
const union = new schema.Union( | ||
{ | ||
users: User, | ||
groups: Group, | ||
}, | ||
input => { | ||
return input.username ? 'users' : 'groups'; | ||
}, | ||
); | ||
expect(denormalize('1', union, entities)).toMatchSnapshot(); | ||
expect(denormalize('1', union, createInput(entities))).toMatchSnapshot(); | ||
}); | ||
}); | ||
}); |
@@ -6,3 +6,3 @@ // eslint-env jest | ||
import denormalize from './denormalize'; | ||
import { denormalizeSimple, denormalizeLegacy } from './denormalize'; | ||
import { schema } from '../../'; | ||
@@ -202,233 +202,210 @@ import { DELETED } from '../../special'; | ||
describe(`${schema.Values.name} denormalization`, () => { | ||
test('denormalizes without schemaAttribute', () => { | ||
class MyEntity extends IDEntity { | ||
name = ''; | ||
} | ||
const valuesSchema = new schema.Values(MyEntity); | ||
describe.each([ | ||
['direct', data => data], | ||
['immutable', fromJS], | ||
])(`input (%s)`, (_, createInput) => { | ||
describe.each([ | ||
['current', denormalizeSimple], | ||
['legacy', denormalizeLegacy], | ||
])(`${schema.Values.name} denormalization (%s)`, (_, denormalize) => { | ||
test('denormalizes without schemaAttribute', () => { | ||
class MyEntity extends IDEntity { | ||
name = ''; | ||
} | ||
const valuesSchema = new schema.Values(MyEntity); | ||
const entities = { | ||
MyEntity: { | ||
1: { | ||
id: '1', | ||
name: 'first thing', | ||
const entities = { | ||
MyEntity: { | ||
1: { | ||
id: '1', | ||
name: 'first thing', | ||
}, | ||
2: { | ||
id: '2', | ||
name: 'second thing', | ||
}, | ||
}, | ||
2: { | ||
id: '2', | ||
name: 'second thing', | ||
}, | ||
}, | ||
}; | ||
}; | ||
expect( | ||
denormalize( | ||
expect( | ||
denormalize( | ||
{ | ||
first: '1', | ||
second: '2', | ||
}, | ||
valuesSchema, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
test('denormalizes the values of an object with the given schema', () => { | ||
const valuesSchema = new schema.Values( | ||
{ | ||
first: '1', | ||
second: '2', | ||
dogs: Dog, | ||
cats: Cat, | ||
}, | ||
valuesSchema, | ||
entities, | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
entity => entity.type, | ||
); | ||
test('denormalizes the values of an object with the given schema', () => { | ||
const valuesSchema = new schema.Values( | ||
{ | ||
dogs: Dog, | ||
cats: Cat, | ||
}, | ||
entity => entity.type, | ||
); | ||
const entities = { | ||
Cat: { 1: { id: '1', type: 'cats' } }, | ||
Dog: { 1: { id: '1', type: 'dogs' } }, | ||
}; | ||
const entities = { | ||
Cat: { 1: { id: '1', type: 'cats' } }, | ||
Dog: { 1: { id: '1', type: 'dogs' } }, | ||
}; | ||
expect( | ||
denormalize( | ||
{ | ||
fido: { id: '1', schema: 'dogs' }, | ||
fluffy: { id: '1', schema: 'cats' }, | ||
}, | ||
valuesSchema, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
expect( | ||
denormalize( | ||
test('denormalizes with missing entity should have false second value', () => { | ||
const valuesSchema = new schema.Values( | ||
{ | ||
fido: { id: '1', schema: 'dogs' }, | ||
fluffy: { id: '1', schema: 'cats' }, | ||
dogs: Dog, | ||
cats: Cat, | ||
}, | ||
valuesSchema, | ||
entities, | ||
), | ||
).toMatchSnapshot(); | ||
entity => entity.type, | ||
); | ||
expect( | ||
denormalize( | ||
{ | ||
fido: { id: '1', schema: 'dogs' }, | ||
fluffy: { id: '1', schema: 'cats' }, | ||
}, | ||
valuesSchema, | ||
fromJS(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
const entities = { | ||
Cat: { 1: { id: '1', type: 'cats' } }, | ||
Dog: { 1: { id: '1', type: 'dogs' } }, | ||
}; | ||
test('denormalizes with missing entity should have false second value', () => { | ||
const valuesSchema = new schema.Values( | ||
{ | ||
dogs: Dog, | ||
cats: Cat, | ||
}, | ||
entity => entity.type, | ||
); | ||
expect( | ||
denormalize( | ||
{ | ||
fido: { id: '1', schema: 'dogs' }, | ||
fluffy: { id: '1', schema: 'cats' }, | ||
prancy: { id: '5', schema: 'cats' }, | ||
}, | ||
valuesSchema, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
const entities = { | ||
Cat: { 1: { id: '1', type: 'cats' } }, | ||
Dog: { 1: { id: '1', type: 'dogs' } }, | ||
}; | ||
expect( | ||
denormalize( | ||
test('denormalizes with deleted entity should just remove them', () => { | ||
const valuesSchema = new schema.Values( | ||
{ | ||
fido: { id: '1', schema: 'dogs' }, | ||
fluffy: { id: '1', schema: 'cats' }, | ||
prancy: { id: '5', schema: 'cats' }, | ||
dogs: Dog, | ||
cats: Cat, | ||
}, | ||
valuesSchema, | ||
entities, | ||
), | ||
).toMatchSnapshot(); | ||
entity => entity.type, | ||
); | ||
expect( | ||
denormalize( | ||
{ | ||
fido: { id: '1', schema: 'dogs' }, | ||
fluffy: { id: '1', schema: 'cats' }, | ||
prancy: { id: '5', schema: 'cats' }, | ||
}, | ||
valuesSchema, | ||
fromJS(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
const entities = { | ||
Cat: { 1: { id: '1', type: 'cats' }, 5: DELETED }, | ||
Dog: { 1: { id: '1', type: 'dogs' } }, | ||
}; | ||
test('denormalizes with deleted entity should have false third value', () => { | ||
const valuesSchema = new schema.Values( | ||
{ | ||
dogs: Dog, | ||
cats: Cat, | ||
}, | ||
entity => entity.type, | ||
); | ||
expect( | ||
denormalize( | ||
{ | ||
fido: { id: '1', schema: 'dogs' }, | ||
fluffy: { id: '1', schema: 'cats' }, | ||
prancy: { id: '5', schema: 'cats' }, | ||
}, | ||
valuesSchema, | ||
createInput(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
const entities = { | ||
Cat: { 1: { id: '1', type: 'cats' }, 5: DELETED }, | ||
Dog: { 1: { id: '1', type: 'dogs' } }, | ||
}; | ||
expect( | ||
denormalize( | ||
{ | ||
fido: { id: '1', schema: 'dogs' }, | ||
fluffy: { id: '1', schema: 'cats' }, | ||
prancy: { id: '5', schema: 'cats' }, | ||
}, | ||
valuesSchema, | ||
entities, | ||
), | ||
).toMatchSnapshot(); | ||
expect( | ||
denormalize( | ||
{ | ||
fido: { id: '1', schema: 'dogs' }, | ||
fluffy: { id: '1', schema: 'cats' }, | ||
prancy: { id: '5', schema: 'cats' }, | ||
}, | ||
valuesSchema, | ||
fromJS(entities), | ||
), | ||
).toMatchSnapshot(); | ||
}); | ||
test('works on complex object', () => { | ||
class Estimate extends Entity { | ||
pk() { | ||
return this.fee.currency; | ||
test('works on complex object', () => { | ||
class Estimate extends Entity { | ||
pk() { | ||
return this.fee.currency; | ||
} | ||
} | ||
} | ||
const response = { | ||
data: { | ||
estimates: { | ||
BTC: { | ||
confirmation_duration: 900, | ||
exchange: { | ||
rate: '6820.07', | ||
local: 'USD', | ||
crypto: 'BTC', | ||
const response = { | ||
data: { | ||
estimates: { | ||
BTC: { | ||
confirmation_duration: 900, | ||
exchange: { | ||
rate: '6820.07', | ||
local: 'USD', | ||
crypto: 'BTC', | ||
}, | ||
fee_per_kb: { | ||
amount: '0.00016566', | ||
currency: 'BTC', | ||
}, | ||
fee: { | ||
amount: '0.00002270', | ||
currency: 'BTC', | ||
}, | ||
priority: 'fast', | ||
recipient_value: { | ||
amount: '0.00054147', | ||
currency: 'BTC', | ||
}, | ||
exchange_to_proceeds: { | ||
rate: '6820.07', | ||
local: 'EUR', | ||
crypto: 'BTC', | ||
}, | ||
min_order_size: { | ||
amount: '0.001', | ||
currency: 'BTC', | ||
}, | ||
coinbase_fees: { | ||
amount: '0.00002270', | ||
currency: 'BTC', | ||
}, | ||
}, | ||
fee_per_kb: { | ||
amount: '0.00016566', | ||
currency: 'BTC', | ||
ETH: { | ||
confirmation_duration: 900, | ||
exchange: { | ||
rate: '197.07', | ||
local: 'USD', | ||
crypto: 'ETH', | ||
}, | ||
fee_per_kb: { | ||
amount: '0.00086', | ||
currency: 'ETH', | ||
}, | ||
fee: { | ||
amount: '0.03795', | ||
currency: 'ETH', | ||
}, | ||
priority: 'fast', | ||
recipient_value: { | ||
amount: '2.53', | ||
currency: 'ETH', | ||
}, | ||
exchange_to_proceeds: { | ||
rate: '6820.07', | ||
local: 'EUR', | ||
crypto: 'BTC', | ||
}, | ||
min_order_size: { | ||
amount: '0.001', | ||
currency: 'BTC', | ||
}, | ||
coinbase_fees: { | ||
amount: '0.00002270', | ||
currency: 'BTC', | ||
}, | ||
}, | ||
fee: { | ||
amount: '0.00002270', | ||
currency: 'BTC', | ||
}, | ||
priority: 'fast', | ||
recipient_value: { | ||
amount: '0.00054147', | ||
currency: 'BTC', | ||
}, | ||
exchange_to_proceeds: { | ||
rate: '6820.07', | ||
local: 'EUR', | ||
crypto: 'BTC', | ||
}, | ||
min_order_size: { | ||
amount: '0.001', | ||
currency: 'BTC', | ||
}, | ||
coinbase_fees: { | ||
amount: '0.00002270', | ||
currency: 'BTC', | ||
}, | ||
}, | ||
ETH: { | ||
confirmation_duration: 900, | ||
exchange: { | ||
rate: '197.07', | ||
local: 'USD', | ||
crypto: 'ETH', | ||
}, | ||
fee_per_kb: { | ||
amount: '0.00086', | ||
currency: 'ETH', | ||
}, | ||
fee: { | ||
amount: '0.03795', | ||
currency: 'ETH', | ||
}, | ||
priority: 'fast', | ||
recipient_value: { | ||
amount: '2.53', | ||
currency: 'ETH', | ||
}, | ||
exchange_to_proceeds: { | ||
rate: '6820.07', | ||
local: 'EUR', | ||
crypto: 'BTC', | ||
}, | ||
min_order_size: { | ||
amount: '0.001', | ||
currency: 'BTC', | ||
}, | ||
coinbase_fees: { | ||
amount: '0.00002270', | ||
currency: 'BTC', | ||
}, | ||
}, | ||
}, | ||
}, | ||
}; | ||
const shape = { data: { estimates: new schema.Values(Estimate) } }; | ||
const { result, entities } = normalize(response, shape); | ||
expect(denormalize(result, shape, entities)[0]).toMatchSnapshot(); | ||
}; | ||
const shape = new schema.Object({ | ||
data: new schema.Object({ estimates: new schema.Values(Estimate) }), | ||
}); | ||
const { result, entities } = normalize(response, shape); | ||
expect( | ||
denormalize(result, shape, createInput(entities)), | ||
).toMatchSnapshot(); | ||
}); | ||
}); | ||
}); |
@@ -29,5 +29,16 @@ import ArraySchema from './Array.js'; | ||
visitedEntities: any, | ||
storeEntities: any, | ||
args?: any[], | ||
): any { | ||
// we return undefined | ||
super.normalize(input, parent, key, visit, addEntity, visitedEntities); | ||
super.normalize( | ||
input, | ||
parent, | ||
key, | ||
visit, | ||
addEntity, | ||
visitedEntities, | ||
storeEntities, | ||
args, | ||
); | ||
} | ||
@@ -34,0 +45,0 @@ |
@@ -16,2 +16,4 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
visitedEntities: any, | ||
storeEntities: any, | ||
args?: any[], | ||
): any { | ||
@@ -29,2 +31,4 @@ const values = getValues(input); | ||
visitedEntities, | ||
storeEntities, | ||
args, | ||
), | ||
@@ -39,16 +43,17 @@ ) | ||
): [denormalized: any, found: boolean, deleted: boolean] { | ||
return [ | ||
input.map | ||
? input | ||
.map((entityOrId: any) => | ||
this.denormalizeValue(entityOrId, unvisit), | ||
) | ||
.filter(filterEmpty) | ||
.map(([value]: any) => value) | ||
: input, | ||
true, | ||
false, | ||
]; | ||
return [this.denormalizeOnly(input, [], unvisit), true, false]; | ||
} | ||
denormalizeOnly( | ||
input: any, | ||
args: any[], | ||
unvisit: (input: any, schema: any) => any, | ||
) { | ||
return input.map | ||
? input | ||
.map((entityOrId: any) => this.denormalizeValue(entityOrId, unvisit)) | ||
.filter(filterEmpty) | ||
: input; | ||
} | ||
infer( | ||
@@ -55,0 +60,0 @@ args: unknown, |
/* eslint-disable @typescript-eslint/explicit-module-boundary-types */ | ||
import Invalidate from './Invalidate.js'; | ||
import type { EntityInterface } from '../interface.js'; | ||
import type { AbstractInstanceType } from '../normal.js'; | ||
import { SchemaClass, UnvisitFunction } from '../schema.js'; | ||
import { DELETED } from '../special.js'; | ||
// TODO(breaking): mark deprecated | ||
/** | ||
@@ -11,57 +12,10 @@ * Marks entity as deleted. | ||
*/ | ||
export default class Delete<E extends EntityInterface & { process: any }> | ||
export default class Delete< | ||
E extends EntityInterface & { | ||
process: any; | ||
}, | ||
> | ||
extends Invalidate<E> | ||
implements SchemaClass | ||
{ | ||
private declare _entity: E; | ||
constructor(entity: E) { | ||
if (process.env.NODE_ENV !== 'production' && !entity) { | ||
throw new Error('Expected option "entity" not found on DeleteSchema.'); | ||
} | ||
this._entity = entity; | ||
} | ||
get key() { | ||
return this._entity.key; | ||
} | ||
normalize( | ||
input: any, | ||
parent: any, | ||
key: string | undefined, | ||
visit: (...args: any) => any, | ||
addEntity: (...args: any) => any, | ||
visitedEntities: Record<string, any>, | ||
): string | undefined { | ||
// TODO: what's store needs to be a differing type from fromJS | ||
const processedEntity = this._entity.process(input, parent, key); | ||
const id = this._entity.pk(processedEntity, parent, key); | ||
if ( | ||
process.env.NODE_ENV !== 'production' && | ||
(id === undefined || id === '') | ||
) { | ||
const error = new Error( | ||
`Missing usable primary key when normalizing response. | ||
This is likely due to a malformed response. | ||
Try inspecting the network response or fetch() return value. | ||
Or use debugging tools: https://resthooks.io/docs/guides/debugging | ||
Learn more about schemas: https://resthooks.io/docs/api/schema | ||
Delete(Entity): Delete(${(this._entity as any).name ?? this._entity}) | ||
Value: ${input && JSON.stringify(input, null, 2)} | ||
`, | ||
); | ||
(error as any).status = 400; | ||
throw error; | ||
} | ||
addEntity(this, DELETED, id); | ||
return id; | ||
} | ||
infer(args: any, indexes: any, recurse: any): any { | ||
return undefined; | ||
} | ||
denormalize( | ||
@@ -73,30 +27,2 @@ id: string, | ||
} | ||
/* istanbul ignore next */ | ||
_denormalizeNullable(): [ | ||
AbstractInstanceType<E> | undefined, | ||
boolean, | ||
false, | ||
] { | ||
return [] as any; | ||
} | ||
/* istanbul ignore next */ | ||
_normalizeNullable(): string | undefined { | ||
return [] as any; | ||
} | ||
/* istanbul ignore next */ | ||
merge(existing: any, incoming: any) { | ||
return incoming; | ||
} | ||
useIncoming( | ||
existingMeta: { date: number; fetchedAt: number }, | ||
incomingMeta: { date: number; fetchedAt: number }, | ||
existing: any, | ||
incoming: any, | ||
) { | ||
return existingMeta.date <= incomingMeta.date; | ||
} | ||
} |
@@ -9,3 +9,3 @@ /* eslint-disable @typescript-eslint/explicit-module-boundary-types */ | ||
const EmptyBase = class {} as any as abstract new (...args: any[]) => { | ||
pk(parent?: any, key?: string): string | undefined; | ||
pk(parent?: any, key?: string, args?: readonly any[]): string | undefined; | ||
}; | ||
@@ -24,3 +24,7 @@ | ||
*/ | ||
abstract pk(parent?: any, key?: string): string | undefined; | ||
abstract pk( | ||
parent?: any, | ||
key?: string, | ||
args?: readonly any[], | ||
): string | undefined; | ||
@@ -79,2 +83,22 @@ /** Control how automatic schema validation is handled | ||
static mergeMetaWithStore( | ||
existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
incomingMeta: { expiresAt: number; date: number; fetchedAt: number }, | ||
existing: any, | ||
incoming: any, | ||
) { | ||
return { | ||
expiresAt: Math.max( | ||
(this as any).expiresAt(incomingMeta, incoming), | ||
existingMeta.expiresAt, | ||
), | ||
date: Math.max(incomingMeta.date, existingMeta.date), | ||
fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt), | ||
}; | ||
} | ||
/** Factory method to convert from Plain JS Objects. | ||
@@ -102,2 +126,3 @@ * | ||
key?: string, | ||
args?: any[], | ||
) => string | undefined; | ||
@@ -291,1 +316,9 @@ | ||
} | ||
// we're avoiding this on the type | ||
(Entity as any).expiresAt = function ( | ||
meta: { expiresAt: number; date: number; fetchedAt: number }, | ||
input: any, | ||
): number { | ||
return meta.expiresAt; | ||
}; |
@@ -10,3 +10,3 @@ /* eslint-disable @typescript-eslint/explicit-module-boundary-types */ | ||
export type PKClass = abstract new (...args: any[]) => { | ||
pk(parent?: any, key?: string): string | undefined; | ||
pk(parent?: any, key?: string, args?: readonly any[]): string | undefined; | ||
}; | ||
@@ -74,3 +74,7 @@ | ||
*/ | ||
abstract pk(parent?: any, key?: string): string | undefined; | ||
abstract pk( | ||
parent?: any, | ||
key?: string, | ||
args?: readonly any[], | ||
): string | undefined; | ||
@@ -87,2 +91,3 @@ /** Returns the globally unique identifier for the static Entity */ | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#pk | ||
* @param [value] POJO of the entity or subset used | ||
@@ -97,4 +102,5 @@ * @param [parent] When normalizing, the object which included the entity | ||
key?: string, | ||
args?: readonly any[], | ||
): string | undefined { | ||
return this.prototype.pk.call(value, parent, key); | ||
return this.prototype.pk.call(value, parent, key, args); | ||
} | ||
@@ -129,3 +135,6 @@ | ||
/** Creates new instance copying over defined values of arguments */ | ||
/** Creates new instance copying over defined values of arguments | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#merge | ||
*/ | ||
static merge(existing: any, incoming: any) { | ||
@@ -138,3 +147,6 @@ return { | ||
/** Run when an existing entity is found in the store */ | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeWithStore | ||
*/ | ||
static mergeWithStore( | ||
@@ -175,2 +187,21 @@ existingMeta: { | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeMetaWithStore | ||
*/ | ||
static mergeMetaWithStore( | ||
existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
incomingMeta: { expiresAt: number; date: number; fetchedAt: number }, | ||
existing: any, | ||
incoming: any, | ||
) { | ||
return this.shouldReorder(existingMeta, incomingMeta, existing, incoming) | ||
? existingMeta | ||
: incomingMeta; | ||
} | ||
/** Factory method to convert from Plain JS Objects. | ||
@@ -193,5 +224,6 @@ * | ||
/** Factory method to convert from Plain JS Objects. | ||
/** Called when denormalizing an entity to create an instance when 'valid' | ||
* | ||
* @param [props] Plain Object of properties to assign. | ||
* @see https://resthooks.io/docs/api/schema.Entity#createIfValid | ||
*/ | ||
@@ -209,3 +241,6 @@ static createIfValid<T extends typeof EntityMixin>( | ||
/** Do any transformations when first receiving input */ | ||
/** Do any transformations when first receiving input | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#process | ||
*/ | ||
static process(input: any, parent: any, key: string | undefined): any { | ||
@@ -222,5 +257,7 @@ return { ...input }; | ||
visitedEntities: Record<string, any>, | ||
storeEntities: any, | ||
args?: readonly any[], | ||
): any { | ||
const processedEntity = this.process(input, parent, key); | ||
const id = this.pk(processedEntity, parent, key); | ||
const id = this.pk(processedEntity, parent, key, args); | ||
if (id === undefined || id === '') { | ||
@@ -245,4 +282,4 @@ if (process.env.NODE_ENV !== 'production') { | ||
} else { | ||
// these make the keys get deleted | ||
return undefined; | ||
// these make the keys get deleted; return undefined | ||
return; | ||
} | ||
@@ -278,2 +315,4 @@ } | ||
visitedEntities, | ||
storeEntities, | ||
args, | ||
); | ||
@@ -311,30 +350,11 @@ } | ||
recurse: any, | ||
entities: any, | ||
): any { | ||
if (!args[0]) return undefined; | ||
if (['string', 'number'].includes(typeof args[0])) { | ||
return `${args[0]}`; | ||
} | ||
const id = this.pk(args[0], undefined, ''); | ||
// Was able to infer the entity's primary key from params | ||
if (id !== undefined && id !== '') return id; | ||
// now attempt lookup in indexes | ||
const indexName = indexFromParams(args[0], this.indexes); | ||
if (indexName && indexes[this.key]) { | ||
// 'as Record<string, any>': indexName can only be found if params is a string key'd object | ||
const id = | ||
indexes[this.key][indexName][ | ||
(args[0] as Record<string, any>)[indexName] | ||
]; | ||
return id; | ||
} | ||
const id = inferId(this, args, indexes); | ||
// no entity arg is back-compatibility | ||
if (!entities || entities[this.key]?.[id]) return id; | ||
return undefined; | ||
} | ||
static expiresAt( | ||
meta: { expiresAt: number; date: number; fetchedAt: number }, | ||
input: any, | ||
): number { | ||
return meta.expiresAt; | ||
} | ||
static denormalize<T extends typeof EntityMixin>( | ||
@@ -371,2 +391,30 @@ this: T, | ||
static denormalizeOnly<T extends typeof EntityMixin>( | ||
this: T, | ||
input: any, | ||
args: any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): AbstractInstanceType<T> { | ||
if (typeof input === 'symbol') { | ||
return input as any; | ||
} | ||
// note: iteration order must be stable | ||
for (const key of Object.keys(this.schema)) { | ||
const schema = this.schema[key]; | ||
const value = unvisit(input[key], schema); | ||
if (typeof value === 'symbol') { | ||
// if default is not 'fasly', then this is required, so propagate INVALID symbol | ||
if (this.defaults[key]) { | ||
return value as any; | ||
} | ||
input[key] = undefined; | ||
} else { | ||
input[key] = value; | ||
} | ||
} | ||
return input; | ||
} | ||
/** All instance defaults set */ | ||
@@ -491,9 +539,18 @@ static get defaults() { | ||
}; | ||
/** Defines nested entities */ | ||
/** Defines nested entities | ||
* | ||
* @see https://resthooks.io/rest/api/Entity#schema | ||
*/ | ||
schema: { | ||
[k: string]: Schema; | ||
}; | ||
/** Returns the globally unique identifier for the static Entity */ | ||
/** Returns the globally unique identifier for the static Entity | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#key | ||
*/ | ||
key: string; | ||
/** Defines indexes to enable lookup by */ | ||
/** Defines indexes to enable lookup by | ||
* | ||
* @see https://resthooks.io/rest/api/Entity#indexes | ||
*/ | ||
indexes?: readonly string[] | undefined; | ||
@@ -503,2 +560,3 @@ /** | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#pk | ||
* @param [value] POJO of the entity or subset used | ||
@@ -518,2 +576,3 @@ * @param [parent] When normalizing, the object which included the entity | ||
key?: string, | ||
args?: any[], | ||
): string | undefined; | ||
@@ -547,5 +606,11 @@ /** Return true to merge incoming data; false keeps existing entity | ||
): boolean; | ||
/** Creates new instance copying over defined values of arguments */ | ||
/** Creates new instance copying over defined values of arguments | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#merge | ||
*/ | ||
merge(existing: any, incoming: any): any; | ||
/** Run when an existing entity is found in the store */ | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeWithStore | ||
*/ | ||
mergeWithStore( | ||
@@ -563,2 +628,20 @@ existingMeta: { | ||
): any; | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeMetaWithStore | ||
*/ | ||
mergeMetaWithStore( | ||
existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
incomingMeta: { expiresAt: number; date: number; fetchedAt: number }, | ||
existing: any, | ||
incoming: any, | ||
): { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}; | ||
/** Factory method to convert from Plain JS Objects. | ||
@@ -577,5 +660,6 @@ * | ||
): AbstractInstanceType<T>; | ||
/** Factory method to convert from Plain JS Objects. | ||
/** Called when denormalizing an entity to create an instance when 'valid' | ||
* | ||
* @param [props] Plain Object of properties to assign. | ||
* @see https://resthooks.io/docs/api/Entity#createIfValid | ||
*/ | ||
@@ -591,3 +675,6 @@ createIfValid< | ||
): AbstractInstanceType<T> | undefined; | ||
/** Do any transformations when first receiving input */ | ||
/** Do any transformations when first receiving input | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#process | ||
*/ | ||
process(input: any, parent: any, key: string | undefined): any; | ||
@@ -602,12 +689,13 @@ normalize( | ||
): any; | ||
/** Do any transformations when first receiving input | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#validate | ||
*/ | ||
validate(processedEntity: any): string | undefined; | ||
/** Attempts to infer results | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#infer | ||
*/ | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: any): any; | ||
expiresAt( | ||
meta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, | ||
input: any, | ||
): number; | ||
denormalize< | ||
@@ -623,2 +711,12 @@ T extends (abstract new (...args: any[]) => IEntityInstance & | ||
): [denormalized: AbstractInstanceType<T>, found: boolean, suspend: boolean]; | ||
denormalizeOnly< | ||
T extends (abstract new (...args: any[]) => IEntityInstance & | ||
InstanceType<TBase>) & | ||
IEntityClass & | ||
TBase, | ||
>( | ||
this: T, | ||
input: any, | ||
unvisit: (input: any, schema: any) => any, | ||
): AbstractInstanceType<T>; | ||
/** All instance defaults set */ | ||
@@ -635,3 +733,22 @@ readonly defaults: any; | ||
*/ | ||
pk(parent?: any, key?: string): string | undefined; | ||
pk(parent?: any, key?: string, args?: readonly any[]): string | undefined; | ||
} | ||
function inferId(schema: any, args: readonly any[], indexes: NormalizedIndex) { | ||
if (['string', 'number'].includes(typeof args[0])) { | ||
return `${args[0]}`; | ||
} | ||
const id = schema.pk(args[0], undefined, '', args); | ||
// Was able to infer the entity's primary key from params | ||
if (id !== undefined && id !== '') return id; | ||
// now attempt lookup in indexes | ||
const indexName = indexFromParams(args[0], schema.indexes); | ||
if (indexName && indexes[schema.key]) { | ||
// 'as Record<string, any>': indexName can only be found if params is a string key'd object | ||
const id = | ||
indexes[schema.key][indexName][ | ||
(args[0] as Record<string, any>)[indexName] | ||
]; | ||
return id; | ||
} | ||
} |
@@ -68,1 +68,34 @@ /** | ||
} | ||
/** | ||
* Denormalize an immutable entity. | ||
* | ||
* @param {Schema} schema | ||
* @param {Immutable.Map|Immutable.Record} input | ||
* @param {function} unvisit | ||
* @param {function} getDenormalizedEntity | ||
* @return {Immutable.Map|Immutable.Record} | ||
*/ | ||
export function denormalizeOnlyImmutable( | ||
schema: any, | ||
input: any, | ||
unvisit: (input: any, schema: any) => any, | ||
): any { | ||
let deleted; | ||
const value = Object.keys(schema).reduce((object, key) => { | ||
// Immutable maps cast keys to strings on write so we need to ensure | ||
// we're accessing them using string keys. | ||
const stringKey = `${key}`; | ||
const item = unvisit(object.get(stringKey), schema[stringKey]); | ||
if (typeof item === 'symbol') { | ||
deleted = item; | ||
} | ||
if (object.has(stringKey)) { | ||
return object.set(stringKey, item); | ||
} else { | ||
return object; | ||
} | ||
}, input); | ||
return deleted ?? value; | ||
} |
@@ -1,2 +0,6 @@ | ||
import { isImmutable, denormalizeImmutable } from './ImmutableUtils.js'; | ||
import { | ||
isImmutable, | ||
denormalizeImmutable, | ||
denormalizeOnlyImmutable, | ||
} from './ImmutableUtils.js'; | ||
@@ -11,2 +15,4 @@ export const normalize = ( | ||
visitedEntities: any, | ||
storeEntities: any, | ||
args: any[], | ||
) => { | ||
@@ -23,2 +29,4 @@ const object = { ...input }; | ||
visitedEntities, | ||
storeEntities, | ||
args, | ||
); | ||
@@ -62,2 +70,26 @@ if (value === undefined || value === null) { | ||
export function denormalizeOnly( | ||
schema: any, | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): any { | ||
if (isImmutable(input)) { | ||
return denormalizeOnlyImmutable(schema, input, unvisit); | ||
} | ||
const object: Record<string, any> = { ...input }; | ||
for (const key of Object.keys(schema)) { | ||
const item = unvisit(object[key], schema[key]); | ||
if (object[key] !== undefined) { | ||
object[key] = item; | ||
} | ||
if (typeof item === 'symbol') { | ||
return item; | ||
} | ||
} | ||
return object; | ||
} | ||
export function infer( | ||
@@ -76,3 +108,2 @@ schema: any, | ||
} | ||
/** | ||
@@ -104,2 +135,4 @@ * Represents objects with statically known members | ||
visitedEntities: any, | ||
storeEntities: any, | ||
args: any[], | ||
] | ||
@@ -115,2 +148,10 @@ ) { | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): any { | ||
return denormalizeOnly(this.schema, input, args, unvisit); | ||
} | ||
infer(args: any, indexes: any, recurse: any, entities: any) { | ||
@@ -117,0 +158,0 @@ return infer(this.schema, args, indexes, recurse, entities); |
import { isImmutable } from './ImmutableUtils.js'; | ||
import { DELETED } from '../special.js'; | ||
@@ -25,3 +26,9 @@ export default class PolymorphicSchema { | ||
define(definition: any) { | ||
this.schema = definition; | ||
// sending Union into another Polymorphic gets hoisted | ||
if ('_schemaAttribute' in definition && !this._schemaAttribute) { | ||
this.schema = definition.schema; | ||
this._schemaAttribute = definition._schemaAttribute; | ||
} else { | ||
this.schema = definition; | ||
} | ||
} | ||
@@ -49,3 +56,6 @@ | ||
visitedEntities: any, | ||
storeEntities: any, | ||
args?: any[], | ||
) { | ||
if (!value) return value; | ||
const schema = this.inferSchema(value, parent, key); | ||
@@ -78,2 +88,4 @@ if (!schema) { | ||
visitedEntities, | ||
storeEntities, | ||
args, | ||
); | ||
@@ -103,3 +115,3 @@ return this.isSingleSchema || | ||
} | ||
return [value, true, false]; | ||
return value; | ||
} | ||
@@ -112,4 +124,9 @@ const id = this.isSingleSchema | ||
const schema = this.isSingleSchema ? this.schema : this.schema[schemaKey]; | ||
return unvisit(id || value, schema); | ||
const ret = unvisit(id || value, schema); | ||
if (Array.isArray(ret) && ret.length === 3) { | ||
if (ret[2] === true) return DELETED; | ||
return ret[0]; | ||
} | ||
return ret; | ||
} | ||
} |
@@ -24,2 +24,4 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
visitedEntities: any, | ||
storeEntities: any, | ||
args: any[], | ||
) { | ||
@@ -33,2 +35,4 @@ return this.normalizeValue( | ||
visitedEntities, | ||
storeEntities, | ||
args, | ||
); | ||
@@ -38,3 +42,12 @@ } | ||
// eslint-disable-next-line @typescript-eslint/ban-types | ||
denormalize(input: {}, unvisit: any) { | ||
denormalize(input: {}, unvisit: any): any { | ||
const value = this.denormalizeValue(input, unvisit); | ||
return [value, value !== undefined, typeof value === 'symbol']; | ||
} | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
) { | ||
return this.denormalizeValue(input, unvisit); | ||
@@ -41,0 +54,0 @@ } |
export const getValues = (input: any) => | ||
Array.isArray(input) ? input : Object.keys(input).map(key => input[key]); | ||
export const filterEmpty = ([item, , deletedItem]: any) => | ||
item !== undefined && !deletedItem; | ||
export const filterEmpty = (item: any) => | ||
item !== undefined && typeof item !== 'symbol'; |
@@ -15,2 +15,4 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
visitedEntities: any, | ||
storeEntities: any, | ||
args: any[], | ||
) { | ||
@@ -29,2 +31,4 @@ return Object.keys(input).reduce((output, key, index) => { | ||
visitedEntities, | ||
storeEntities, | ||
args, | ||
), | ||
@@ -38,18 +42,7 @@ } | ||
denormalize(input: {}, unvisit: any) { | ||
let found = true; | ||
let deleted = false; | ||
return [ | ||
Object.keys(input).reduce((output, key) => { | ||
const entityOrId = (input as any)[key]; | ||
const [value, foundItem, deletedItem] = this.denormalizeValue( | ||
entityOrId, | ||
unvisit, | ||
); | ||
if (!foundItem) { | ||
found = false; | ||
} | ||
if (deletedItem) { | ||
deleted = true; | ||
} | ||
if (!foundItem || deletedItem) return output; | ||
const value = this.denormalizeValue(entityOrId, unvisit); | ||
if (!value || typeof value === 'symbol') return output; | ||
return { | ||
@@ -60,7 +53,25 @@ ...output, | ||
}, {}), | ||
found, | ||
deleted, | ||
true, | ||
false, | ||
]; | ||
} | ||
denormalizeOnly( | ||
input: {}, | ||
args: readonly any[], | ||
unvisit: (input: any, schema: any) => any, | ||
): any { | ||
return Object.keys(input).reduce((output, key) => { | ||
const entityOrId = (input as any)[key]; | ||
const value = this.denormalizeValue(entityOrId, unvisit); | ||
// remove empty or deleted values | ||
if (!value || typeof value === 'symbol') return output; | ||
return { | ||
...output, | ||
[key]: value, | ||
}; | ||
}, {}); | ||
} | ||
infer(args: any, indexes: any, recurse: any) { | ||
@@ -67,0 +78,0 @@ return undefined; |
export const DELETED = Symbol('ENTITY WAS DELETED'); | ||
export const INVALID = DELETED; |
@@ -6,4 +6,4 @@ export { EndpointInterface, ReadEndpoint, MutateEndpoint, } from './interface.js'; | ||
export { default as Entity } from './schemas/Entity.js'; | ||
export { default as validateRequired } from './schemas/validatRequired.js'; | ||
export { DELETED } from './special.js'; | ||
export { default as validateRequired } from './validateRequired.js'; | ||
export { DELETED, INVALID } from './special.js'; | ||
export { Schema, SnapshotInterface, ExpiryStatusInterface, } from './interface.js'; | ||
@@ -10,0 +10,0 @@ export { AbstractInstanceType, Normalize, NormalizeNullable, Denormalize, DenormalizeNullable, } from './normal.js'; |
@@ -14,3 +14,3 @@ import { EndpointExtraOptions, FetchFunction } from './types.js'; | ||
export interface SchemaSimple<T = any> { | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): any; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args: any[]): any; | ||
denormalize(input: {}, unvisit: UnvisitFunction): [ | ||
@@ -21,2 +21,3 @@ /*denormalized*/ T, | ||
]; | ||
denormalizeOnly?(input: {}, args: any, unvisit: (input: any, schema: any) => any): T; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
@@ -34,3 +35,3 @@ } | ||
createIfValid?(props: any): any; | ||
pk(params: any, parent?: any, key?: string): string | undefined; | ||
pk(params: any, parent?: any, key?: string, args?: any[]): string | undefined; | ||
readonly key: string; | ||
@@ -40,2 +41,3 @@ merge(existing: any, incoming: any): any; | ||
mergeWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
mergeMetaWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
useIncoming?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): boolean; | ||
@@ -51,3 +53,3 @@ indexes?: any; | ||
boolean | ||
]; | ||
] | any; | ||
og?: UnvisitFunction; | ||
@@ -54,0 +56,0 @@ setLocal?: (entity: any) => void; |
@@ -1,2 +0,2 @@ | ||
import { Schema, Serializable, EntityInterface, NormalizedIndex, SchemaClass } from './interface.js'; | ||
import { Schema, Serializable, EntityInterface, NormalizedIndex } from './interface.js'; | ||
export type AbstractInstanceType<T> = T extends new (...args: any) => infer U ? U : T extends { | ||
@@ -41,12 +41,22 @@ prototype: infer U; | ||
export type NormalizeReturnType<T> = T extends (...args: any) => infer R ? R : never; | ||
export type Denormalize<S> = S extends EntityInterface<infer U> ? U : S extends RecordClass ? AbstractInstanceType<S> : S extends SchemaClass ? DenormalizeReturnType<S['denormalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] : S extends { | ||
export type Denormalize<S> = S extends EntityInterface<infer U> ? U : S extends RecordClass ? AbstractInstanceType<S> : S extends { | ||
denormalizeOnly: (...args: any) => any; | ||
} ? ReturnType<S['denormalizeOnly']> : S extends { | ||
denormalize: (...args: any) => any; | ||
} ? DenormalizeReturnType<S['denormalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] : S extends { | ||
[K: string]: any; | ||
} ? DenormalizeObject<S> : S; | ||
export type DenormalizeNullable<S> = S extends EntityInterface<any> ? DenormalizeNullableNestedSchema<S> | undefined : S extends RecordClass ? DenormalizeNullableNestedSchema<S> : S extends SchemaClass ? DenormalizeReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
export type DenormalizeNullable<S> = S extends EntityInterface<any> ? DenormalizeNullableNestedSchema<S> | undefined : S extends RecordClass ? DenormalizeNullableNestedSchema<S> : S extends { | ||
_denormalizeNullable: (...args: any) => any; | ||
} ? DenormalizeReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
[K: string]: any; | ||
} ? DenormalizeNullableObject<S> : S; | ||
export type Normalize<S> = S extends EntityInterface ? string : S extends RecordClass ? NormalizeObject<S['schema']> : S extends SchemaClass ? NormalizeReturnType<S['normalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] : S extends { | ||
export type Normalize<S> = S extends EntityInterface ? string : S extends RecordClass ? NormalizeObject<S['schema']> : S extends { | ||
normalize: (...args: any) => any; | ||
} ? NormalizeReturnType<S['normalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] : S extends { | ||
[K: string]: any; | ||
} ? NormalizeObject<S> : S; | ||
export type NormalizeNullable<S> = S extends EntityInterface ? string | undefined : S extends RecordClass ? NormalizedNullableObject<S['schema']> : S extends SchemaClass ? NormalizeReturnType<S['_normalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] | undefined : S extends { | ||
export type NormalizeNullable<S> = S extends EntityInterface ? string | undefined : S extends RecordClass ? NormalizedNullableObject<S['schema']> : S extends { | ||
_normalizeNullable: (...args: any) => any; | ||
} ? NormalizeReturnType<S['_normalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] | undefined : S extends { | ||
[K: string]: any; | ||
@@ -53,0 +63,0 @@ } ? NormalizedNullableObject<S> : S; |
@@ -27,4 +27,5 @@ import { SchemaSimple, UnvisitFunction } from './interface.js'; | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): R; | ||
}; | ||
export {}; | ||
//# sourceMappingURL=queryEndpoint.d.ts.map |
import { SchemaSimple, Schema, UnvisitFunction, NormalizedIndex, EntityTable, EntityInterface, } from './interface.js'; | ||
import { AbstractInstanceType, Normalize, NormalizeNullable, Denormalize, DenormalizeNullable, DenormalizeObject, DenormalizeNullableObject, NormalizeObject, NormalizedNullableObject, EntityMap, } from './normal.js'; | ||
import { CollectionOptions } from './schemas/Collection.js'; | ||
import { default as Delete } from './schemas/Delete.js'; | ||
import { EntityOptions, IEntityClass, IEntityInstance, RequiredPKOptions, IDClass, Constructor, PKClass, } from './schemas/EntitySchema.js'; | ||
export { Delete, EntityMap }; | ||
import { default as Invalidate } from './schemas/Invalidate.js'; | ||
export { Delete, EntityMap, Invalidate }; | ||
export { EntityInterface } from './interface.js'; | ||
@@ -16,3 +18,3 @@ /** | ||
readonly schema: S; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
_normalizeNullable(): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[] | undefined; | ||
@@ -31,2 +33,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): (S extends EntityMap<infer T> ? T : Denormalize<S>)[]; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
@@ -44,3 +47,3 @@ } | ||
readonly schema: S; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
_normalizeNullable(): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[] | undefined; | ||
@@ -59,2 +62,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): (S extends EntityMap<infer T> ? T : Denormalize<S>)[]; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
@@ -70,3 +74,3 @@ } | ||
readonly schema: O; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): NormalizeObject<O>; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): NormalizeObject<O>; | ||
_normalizeNullable(): NormalizedNullableObject<O>; | ||
@@ -85,2 +89,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): DenormalizeObject<O>; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
@@ -98,3 +103,3 @@ } | ||
readonly schema: Choices; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): UnionResult<Choices>; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): UnionResult<Choices>; | ||
_normalizeNullable(): UnionResult<Choices> | undefined; | ||
@@ -113,2 +118,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): AbstractInstanceType<Choices[keyof Choices]>; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
@@ -127,3 +133,3 @@ } | ||
readonly schema: Choices; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): Record<string, Choices extends EntityMap ? UnionResult<Choices> : Normalize<Choices>>; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): Record<string, Choices extends EntityMap ? UnionResult<Choices> : Normalize<Choices>>; | ||
_normalizeNullable(): Record<string, Choices extends EntityMap ? UnionResult<Choices> : NormalizeNullable<Choices>> | undefined; | ||
@@ -142,4 +148,73 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): Record<string, Choices extends EntityMap<infer T> ? T : Denormalize<Choices>>; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
} | ||
/** | ||
* Entities but for Arrays instead of classes | ||
* @see https://resthooks.io/rest/api/Collection | ||
*/ | ||
export class CollectionSchema<S extends Array<any> | Values<any> = any, Parent extends any[] = any> { | ||
addWith<P extends any[] = Parent>(merge: (existing: any, incoming: any) => any, createCollectionFilter?: (...args: P) => (collectionKey: Record<string, any>) => boolean): CollectionSchema<S, P>; | ||
readonly schema: S; | ||
key: string; | ||
pk(value: any, parent: any, key: string, args: any[]): string; | ||
normalize(input: any, parent: Parent, key: string, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args: any[]): string; | ||
merge(existing: any, incoming: any): any; | ||
shouldReorder(existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): boolean; | ||
mergeWithStore(existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): any; | ||
mergeMetaWithStore(existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}; | ||
infer(args: unknown, indexes: unknown, recurse: unknown, entities: unknown): any; | ||
createIfValid: (value: any) => any | undefined; | ||
denormalizeOnly(input: any, args: readonly any[], unvisit: (input: any, schema: any) => any): ReturnType<S['denormalizeOnly']>; | ||
_denormalizeNullable(): ReturnType<S['_denormalizeNullable']>; | ||
_normalizeNullable(): ReturnType<S['_normalizeNullable']>; | ||
} | ||
export type CollectionType<S extends any[] | Array<any> | Values<any> = any, Parent extends any[] = [ | ||
urlParams: Record<string, any>, | ||
body?: Record<string, any> | ||
]> = CollectionSchema<S extends any[] ? Array<S[number]> : S> & (S extends any[] ? { | ||
push: CollectionSchema<Array<S[number]>, Parent>; | ||
unshift: CollectionSchema<Array<S[number]>, Parent>; | ||
} : S extends Values<any> ? { | ||
assign: CollectionSchema<S, Parent>; | ||
} : S extends Array<any> ? { | ||
push: CollectionSchema<S, Parent>; | ||
unshift: CollectionSchema<S, Parent>; | ||
} : never); | ||
export interface CollectionConstructor { | ||
new <S extends SchemaSimple[] | Array<any> | Values<any> = any, Parent extends any[] = [ | ||
urlParams: Record<string, any>, | ||
body?: Record<string, any> | ||
]>(schema: S, options: CollectionOptions): CollectionType<S, Parent>; | ||
readonly prototype: CollectionSchema; | ||
} | ||
/** | ||
* Entities but for Arrays instead of classes | ||
* @see https://resthooks.io/rest/api/Collection | ||
*/ | ||
export declare let Collection: CollectionConstructor; | ||
export type StrategyFunction<T> = (value: any, parent: any, key: string) => T; | ||
@@ -164,2 +239,7 @@ export type SchemaFunction<K = string> = (value: any, parent: any, key: string) => K; | ||
} | ||
export interface SchemaSimpleNew<T = any> { | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): any; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): T; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
} | ||
// id is in Instance, so we default to that as pk | ||
@@ -166,0 +246,0 @@ /** |
@@ -11,5 +11,5 @@ import ArraySchema from './Array.js'; | ||
constructor(definition: S, schemaAttribute?: S extends EntityMap<infer T> ? keyof T | SchemaFunction<keyof S> : undefined); | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
infer(args: any, indexes: any, recurse: any, entities: EntityTable): any; | ||
} | ||
//# sourceMappingURL=All.d.ts.map |
@@ -7,3 +7,3 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ArraySchema extends PolymorphicSchema { | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
denormalize(input: any, unvisit: any): [ | ||
@@ -14,2 +14,3 @@ /*denormalized*/ any, | ||
]; | ||
denormalizeOnly(input: any, args: any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: unknown, indexes: unknown, recurse: unknown, entities: unknown): any; | ||
@@ -16,0 +17,0 @@ toJSON(): any[]; |
@@ -0,1 +1,2 @@ | ||
import Invalidate from './Invalidate.js'; | ||
import { EntityInterface } from '../interface.js'; | ||
@@ -10,8 +11,3 @@ import { AbstractInstanceType } from '../normal.js'; | ||
process: any; | ||
}> implements SchemaClass { | ||
private _entity; | ||
constructor(entity: E); | ||
readonly key: string; | ||
normalize(input: any, parent: any, key: string | undefined, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): string | undefined; | ||
infer(args: any, indexes: any, recurse: any): any; | ||
}> extends Invalidate<E> implements SchemaClass { | ||
denormalize(id: string, unvisit: UnvisitFunction): [ | ||
@@ -22,17 +18,3 @@ /*denormalized*/ AbstractInstanceType<E>, | ||
]; | ||
_denormalizeNullable(): [ | ||
AbstractInstanceType<E> | undefined, | ||
boolean, | ||
false | ||
]; | ||
_normalizeNullable(): string | undefined; | ||
merge(existing: any, incoming: any): any; | ||
useIncoming(existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): boolean; | ||
} | ||
//# sourceMappingURL=Delete.d.ts.map |
@@ -30,2 +30,12 @@ /** | ||
]; | ||
/** | ||
* Denormalize an immutable entity. | ||
* | ||
* @param {Schema} schema | ||
* @param {Immutable.Map|Immutable.Record} input | ||
* @param {function} unvisit | ||
* @param {function} getDenormalizedEntity | ||
* @return {Immutable.Map|Immutable.Record} | ||
*/ | ||
export declare function denormalizeOnlyImmutable(schema: any, input: any, unvisit: (input: any, schema: any) => any): any; | ||
//# sourceMappingURL=ImmutableUtils.d.ts.map |
@@ -1,2 +0,2 @@ | ||
export declare const normalize: (schema: any, input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any) => any; | ||
export declare const normalize: (schema: any, input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]) => any; | ||
export declare const denormalize: (schema: any, input: {}, unvisit: any) => [ | ||
@@ -7,2 +7,3 @@ /*denormalized*/ any, | ||
]; | ||
export declare function denormalizeOnly(schema: any, input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
export declare function infer(schema: any, args: readonly any[], indexes: any, recurse: any, entities: any): any; | ||
@@ -23,3 +24,5 @@ /** | ||
/*addEntity*/ any, | ||
/*visitedEntities*/ any | ||
/*visitedEntities*/ any, | ||
/*storeEntities*/ any, | ||
/*args*/ any[] | ||
]): any; | ||
@@ -34,4 +37,5 @@ denormalize(...args: readonly [ | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any, entities: any): any; | ||
} | ||
//# sourceMappingURL=Object.d.ts.map |
@@ -9,5 +9,5 @@ export default class PolymorphicSchema { | ||
inferSchema(input: any, parent: any, key: any): any; | ||
normalizeValue(value: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalizeValue(value: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
denormalizeValue(value: any, unvisit: any): any; | ||
} | ||
//# sourceMappingURL=Polymorphic.d.ts.map |
@@ -8,4 +8,5 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
constructor(definition: any, schemaAttribute: any); | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]): any; | ||
denormalize(input: {}, unvisit: any): any; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any, entities: any): { | ||
@@ -12,0 +13,0 @@ id: any; |
export declare const getValues: (input: any) => any[]; | ||
export declare const filterEmpty: ([item, , deletedItem]: any) => boolean; | ||
export declare const filterEmpty: (item: any) => boolean; | ||
//# sourceMappingURL=utils.d.ts.map |
@@ -7,6 +7,7 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ValuesSchema extends PolymorphicSchema { | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): {}; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]): {}; | ||
denormalize(input: {}, unvisit: any): {}[]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any): undefined; | ||
} | ||
//# sourceMappingURL=Values.d.ts.map |
export declare const DELETED: unique symbol; | ||
export declare const INVALID: symbol; | ||
//# sourceMappingURL=special.d.ts.map |
@@ -5,4 +5,4 @@ export type { EndpointInterface, ReadEndpoint, MutateEndpoint, } from './interface.js'; | ||
export { default as Entity } from './schemas/Entity.js'; | ||
export { default as validateRequired } from './schemas/validatRequired.js'; | ||
export { DELETED } from './special.js'; | ||
export { default as validateRequired } from './validateRequired.js'; | ||
export { DELETED, INVALID } from './special.js'; | ||
export type { Schema, SnapshotInterface, ExpiryStatusInterface, } from './interface.js'; | ||
@@ -9,0 +9,0 @@ export type { AbstractInstanceType, Normalize, NormalizeNullable, Denormalize, DenormalizeNullable, } from './normal.js'; |
@@ -14,3 +14,3 @@ import type { EndpointExtraOptions, FetchFunction } from './types.js'; | ||
export interface SchemaSimple<T = any> { | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): any; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args: any[]): any; | ||
denormalize(input: {}, unvisit: UnvisitFunction): [ | ||
@@ -21,2 +21,3 @@ denormalized: T, | ||
]; | ||
denormalizeOnly?(input: {}, args: any, unvisit: (input: any, schema: any) => any): T; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
@@ -34,3 +35,3 @@ } | ||
createIfValid?(props: any): any; | ||
pk(params: any, parent?: any, key?: string): string | undefined; | ||
pk(params: any, parent?: any, key?: string, args?: any[]): string | undefined; | ||
readonly key: string; | ||
@@ -40,2 +41,3 @@ merge(existing: any, incoming: any): any; | ||
mergeWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
mergeMetaWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
useIncoming?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): boolean; | ||
@@ -51,3 +53,3 @@ indexes?: any; | ||
boolean | ||
]; | ||
] | any; | ||
og?: UnvisitFunction; | ||
@@ -54,0 +56,0 @@ setLocal?: (entity: any) => void; |
@@ -1,2 +0,2 @@ | ||
import type { Schema, Serializable, EntityInterface, NormalizedIndex, SchemaClass } from './interface.js'; | ||
import type { Schema, Serializable, EntityInterface, NormalizedIndex } from './interface.js'; | ||
export type AbstractInstanceType<T> = T extends new (...args: any) => infer U ? U : T extends { | ||
@@ -41,12 +41,22 @@ prototype: infer U; | ||
export type NormalizeReturnType<T> = T extends (...args: any) => infer R ? R : never; | ||
export type Denormalize<S> = S extends EntityInterface<infer U> ? U : S extends RecordClass ? AbstractInstanceType<S> : S extends SchemaClass ? DenormalizeReturnType<S['denormalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] : S extends { | ||
export type Denormalize<S> = S extends EntityInterface<infer U> ? U : S extends RecordClass ? AbstractInstanceType<S> : S extends { | ||
denormalizeOnly: (...args: any) => any; | ||
} ? ReturnType<S['denormalizeOnly']> : S extends { | ||
denormalize: (...args: any) => any; | ||
} ? DenormalizeReturnType<S['denormalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] : S extends { | ||
[K: string]: any; | ||
} ? DenormalizeObject<S> : S; | ||
export type DenormalizeNullable<S> = S extends EntityInterface<any> ? DenormalizeNullableNestedSchema<S> | undefined : S extends RecordClass ? DenormalizeNullableNestedSchema<S> : S extends SchemaClass ? DenormalizeReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
export type DenormalizeNullable<S> = S extends EntityInterface<any> ? DenormalizeNullableNestedSchema<S> | undefined : S extends RecordClass ? DenormalizeNullableNestedSchema<S> : S extends { | ||
_denormalizeNullable: (...args: any) => any; | ||
} ? DenormalizeReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
[K: string]: any; | ||
} ? DenormalizeNullableObject<S> : S; | ||
export type Normalize<S> = S extends EntityInterface ? string : S extends RecordClass ? NormalizeObject<S['schema']> : S extends SchemaClass ? NormalizeReturnType<S['normalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] : S extends { | ||
export type Normalize<S> = S extends EntityInterface ? string : S extends RecordClass ? NormalizeObject<S['schema']> : S extends { | ||
normalize: (...args: any) => any; | ||
} ? NormalizeReturnType<S['normalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] : S extends { | ||
[K: string]: any; | ||
} ? NormalizeObject<S> : S; | ||
export type NormalizeNullable<S> = S extends EntityInterface ? string | undefined : S extends RecordClass ? NormalizedNullableObject<S['schema']> : S extends SchemaClass ? NormalizeReturnType<S['_normalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] | undefined : S extends { | ||
export type NormalizeNullable<S> = S extends EntityInterface ? string | undefined : S extends RecordClass ? NormalizedNullableObject<S['schema']> : S extends { | ||
_normalizeNullable: (...args: any) => any; | ||
} ? NormalizeReturnType<S['_normalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] | undefined : S extends { | ||
[K: string]: any; | ||
@@ -53,0 +63,0 @@ } ? NormalizedNullableObject<S> : S; |
@@ -27,4 +27,5 @@ import type { SchemaSimple, UnvisitFunction } from './interface.js'; | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): R; | ||
}; | ||
export {}; | ||
//# sourceMappingURL=queryEndpoint.d.ts.map |
import type { SchemaSimple, Schema, UnvisitFunction, NormalizedIndex, EntityTable, EntityInterface, } from './interface.js'; | ||
import type { AbstractInstanceType, Normalize, NormalizeNullable, Denormalize, DenormalizeNullable, DenormalizeObject, DenormalizeNullableObject, NormalizeObject, NormalizedNullableObject, EntityMap, } from './normal.js'; | ||
import { CollectionOptions } from './schemas/Collection.js'; | ||
import { default as Delete } from './schemas/Delete.js'; | ||
import { EntityOptions, IEntityClass, IEntityInstance, RequiredPKOptions, IDClass, Constructor, PKClass, } from './schemas/EntitySchema.js'; | ||
export { Delete, EntityMap }; | ||
import { default as Invalidate } from './schemas/Invalidate.js'; | ||
export { Delete, EntityMap, Invalidate }; | ||
export { EntityInterface } from './interface.js'; | ||
@@ -16,3 +18,3 @@ /** | ||
readonly schema: S; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
_normalizeNullable(): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[] | undefined; | ||
@@ -31,2 +33,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): (S extends EntityMap<infer T> ? T : Denormalize<S>)[]; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
@@ -44,3 +47,3 @@ } | ||
readonly schema: S; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
_normalizeNullable(): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[] | undefined; | ||
@@ -59,2 +62,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): (S extends EntityMap<infer T> ? T : Denormalize<S>)[]; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
@@ -70,3 +74,3 @@ } | ||
readonly schema: O; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): NormalizeObject<O>; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): NormalizeObject<O>; | ||
_normalizeNullable(): NormalizedNullableObject<O>; | ||
@@ -85,2 +89,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): DenormalizeObject<O>; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
@@ -98,3 +103,3 @@ } | ||
readonly schema: Choices; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): UnionResult<Choices>; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): UnionResult<Choices>; | ||
_normalizeNullable(): UnionResult<Choices> | undefined; | ||
@@ -113,2 +118,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): AbstractInstanceType<Choices[keyof Choices]>; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
@@ -127,3 +133,3 @@ } | ||
readonly schema: Choices; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): Record<string, Choices extends EntityMap ? UnionResult<Choices> : Normalize<Choices>>; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): Record<string, Choices extends EntityMap ? UnionResult<Choices> : Normalize<Choices>>; | ||
_normalizeNullable(): Record<string, Choices extends EntityMap ? UnionResult<Choices> : NormalizeNullable<Choices>> | undefined; | ||
@@ -142,4 +148,73 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): Record<string, Choices extends EntityMap<infer T> ? T : Denormalize<Choices>>; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
} | ||
/** | ||
* Entities but for Arrays instead of classes | ||
* @see https://resthooks.io/rest/api/Collection | ||
*/ | ||
export class CollectionSchema<S extends Array<any> | Values<any> = any, Parent extends any[] = any> { | ||
addWith<P extends any[] = Parent>(merge: (existing: any, incoming: any) => any, createCollectionFilter?: (...args: P) => (collectionKey: Record<string, any>) => boolean): CollectionSchema<S, P>; | ||
readonly schema: S; | ||
key: string; | ||
pk(value: any, parent: any, key: string, args: any[]): string; | ||
normalize(input: any, parent: Parent, key: string, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args: any[]): string; | ||
merge(existing: any, incoming: any): any; | ||
shouldReorder(existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): boolean; | ||
mergeWithStore(existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): any; | ||
mergeMetaWithStore(existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}; | ||
infer(args: unknown, indexes: unknown, recurse: unknown, entities: unknown): any; | ||
createIfValid: (value: any) => any | undefined; | ||
denormalizeOnly(input: any, args: readonly any[], unvisit: (input: any, schema: any) => any): ReturnType<S['denormalizeOnly']>; | ||
_denormalizeNullable(): ReturnType<S['_denormalizeNullable']>; | ||
_normalizeNullable(): ReturnType<S['_normalizeNullable']>; | ||
} | ||
export type CollectionType<S extends any[] | Array<any> | Values<any> = any, Parent extends any[] = [ | ||
urlParams: Record<string, any>, | ||
body?: Record<string, any> | ||
]> = CollectionSchema<S extends any[] ? Array<S[number]> : S> & (S extends any[] ? { | ||
push: CollectionSchema<Array<S[number]>, Parent>; | ||
unshift: CollectionSchema<Array<S[number]>, Parent>; | ||
} : S extends Values<any> ? { | ||
assign: CollectionSchema<S, Parent>; | ||
} : S extends Array<any> ? { | ||
push: CollectionSchema<S, Parent>; | ||
unshift: CollectionSchema<S, Parent>; | ||
} : never); | ||
export interface CollectionConstructor { | ||
new <S extends SchemaSimple[] | Array<any> | Values<any> = any, Parent extends any[] = [ | ||
urlParams: Record<string, any>, | ||
body?: Record<string, any> | ||
]>(schema: S, options: CollectionOptions): CollectionType<S, Parent>; | ||
readonly prototype: CollectionSchema; | ||
} | ||
/** | ||
* Entities but for Arrays instead of classes | ||
* @see https://resthooks.io/rest/api/Collection | ||
*/ | ||
export declare let Collection: CollectionConstructor; | ||
export type StrategyFunction<T> = (value: any, parent: any, key: string) => T; | ||
@@ -164,2 +239,7 @@ export type SchemaFunction<K = string> = (value: any, parent: any, key: string) => K; | ||
} | ||
export interface SchemaSimpleNew<T = any> { | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): any; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): T; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
} | ||
// id is in Instance, so we default to that as pk | ||
@@ -166,0 +246,0 @@ /** |
@@ -11,5 +11,5 @@ import ArraySchema from './Array.js'; | ||
constructor(definition: S, schemaAttribute?: S extends EntityMap<infer T> ? keyof T | SchemaFunction<keyof S> : undefined); | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
infer(args: any, indexes: any, recurse: any, entities: EntityTable): any; | ||
} | ||
//# sourceMappingURL=All.d.ts.map |
@@ -7,3 +7,3 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ArraySchema extends PolymorphicSchema { | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
denormalize(input: any, unvisit: any): [ | ||
@@ -14,2 +14,3 @@ denormalized: any, | ||
]; | ||
denormalizeOnly(input: any, args: any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: unknown, indexes: unknown, recurse: unknown, entities: unknown): any; | ||
@@ -16,0 +17,0 @@ toJSON(): any[]; |
@@ -0,1 +1,2 @@ | ||
import Invalidate from './Invalidate.js'; | ||
import type { EntityInterface } from '../interface.js'; | ||
@@ -10,8 +11,3 @@ import type { AbstractInstanceType } from '../normal.js'; | ||
process: any; | ||
}> implements SchemaClass { | ||
private _entity; | ||
constructor(entity: E); | ||
get key(): string; | ||
normalize(input: any, parent: any, key: string | undefined, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): string | undefined; | ||
infer(args: any, indexes: any, recurse: any): any; | ||
}> extends Invalidate<E> implements SchemaClass { | ||
denormalize(id: string, unvisit: UnvisitFunction): [ | ||
@@ -22,17 +18,3 @@ denormalized: AbstractInstanceType<E>, | ||
]; | ||
_denormalizeNullable(): [ | ||
AbstractInstanceType<E> | undefined, | ||
boolean, | ||
false | ||
]; | ||
_normalizeNullable(): string | undefined; | ||
merge(existing: any, incoming: any): any; | ||
useIncoming(existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): boolean; | ||
} | ||
//# sourceMappingURL=Delete.d.ts.map |
@@ -30,2 +30,12 @@ /** | ||
]; | ||
/** | ||
* Denormalize an immutable entity. | ||
* | ||
* @param {Schema} schema | ||
* @param {Immutable.Map|Immutable.Record} input | ||
* @param {function} unvisit | ||
* @param {function} getDenormalizedEntity | ||
* @return {Immutable.Map|Immutable.Record} | ||
*/ | ||
export declare function denormalizeOnlyImmutable(schema: any, input: any, unvisit: (input: any, schema: any) => any): any; | ||
//# sourceMappingURL=ImmutableUtils.d.ts.map |
@@ -1,2 +0,2 @@ | ||
export declare const normalize: (schema: any, input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any) => any; | ||
export declare const normalize: (schema: any, input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]) => any; | ||
export declare const denormalize: (schema: any, input: {}, unvisit: any) => [ | ||
@@ -7,2 +7,3 @@ denormalized: any, | ||
]; | ||
export declare function denormalizeOnly(schema: any, input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
export declare function infer(schema: any, args: readonly any[], indexes: any, recurse: any, entities: any): any; | ||
@@ -23,3 +24,5 @@ /** | ||
addEntity: any, | ||
visitedEntities: any | ||
visitedEntities: any, | ||
storeEntities: any, | ||
args: any[] | ||
]): any; | ||
@@ -34,4 +37,5 @@ denormalize(...args: readonly [ | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any, entities: any): any; | ||
} | ||
//# sourceMappingURL=Object.d.ts.map |
@@ -9,5 +9,5 @@ export default class PolymorphicSchema { | ||
inferSchema(input: any, parent: any, key: any): any; | ||
normalizeValue(value: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalizeValue(value: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
denormalizeValue(value: any, unvisit: any): any; | ||
} | ||
//# sourceMappingURL=Polymorphic.d.ts.map |
@@ -8,4 +8,5 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
constructor(definition: any, schemaAttribute: any); | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]): any; | ||
denormalize(input: {}, unvisit: any): any; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any, entities: any): { | ||
@@ -12,0 +13,0 @@ id: any; |
export declare const getValues: (input: any) => any[]; | ||
export declare const filterEmpty: ([item, , deletedItem]: any) => boolean; | ||
export declare const filterEmpty: (item: any) => boolean; | ||
//# sourceMappingURL=utils.d.ts.map |
@@ -7,6 +7,7 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ValuesSchema extends PolymorphicSchema { | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): {}; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]): {}; | ||
denormalize(input: {}, unvisit: any): {}[]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any): undefined; | ||
} | ||
//# sourceMappingURL=Values.d.ts.map |
export declare const DELETED: unique symbol; | ||
export declare const INVALID: symbol; | ||
//# sourceMappingURL=special.d.ts.map |
@@ -5,4 +5,4 @@ export type { EndpointInterface, ReadEndpoint, MutateEndpoint, } from './interface.js'; | ||
export { default as Entity } from './schemas/Entity.js'; | ||
export { default as validateRequired } from './schemas/validatRequired.js'; | ||
export { DELETED } from './special.js'; | ||
export { default as validateRequired } from './validateRequired.js'; | ||
export { DELETED, INVALID } from './special.js'; | ||
export type { Schema, SnapshotInterface, ExpiryStatusInterface, } from './interface.js'; | ||
@@ -9,0 +9,0 @@ export type { AbstractInstanceType, Normalize, NormalizeNullable, Denormalize, DenormalizeNullable, } from './normal.js'; |
@@ -14,3 +14,3 @@ import type { EndpointExtraOptions, FetchFunction } from './types.js'; | ||
export interface SchemaSimple<T = any> { | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): any; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args: any[]): any; | ||
denormalize(input: {}, unvisit: UnvisitFunction): [ | ||
@@ -21,2 +21,3 @@ denormalized: T, | ||
]; | ||
denormalizeOnly?(input: {}, args: any, unvisit: (input: any, schema: any) => any): T; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
@@ -34,3 +35,3 @@ } | ||
createIfValid?(props: any): any; | ||
pk(params: any, parent?: any, key?: string): string | undefined; | ||
pk(params: any, parent?: any, key?: string, args?: any[]): string | undefined; | ||
readonly key: string; | ||
@@ -40,2 +41,3 @@ merge(existing: any, incoming: any): any; | ||
mergeWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
mergeMetaWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
useIncoming?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): boolean; | ||
@@ -51,3 +53,3 @@ indexes?: any; | ||
boolean | ||
]; | ||
] | any; | ||
og?: UnvisitFunction; | ||
@@ -54,0 +56,0 @@ setLocal?: (entity: any) => void; |
@@ -1,2 +0,2 @@ | ||
import type { Schema, Serializable, EntityInterface, NormalizedIndex, SchemaClass } from './interface.js'; | ||
import type { Schema, Serializable, EntityInterface, NormalizedIndex } from './interface.js'; | ||
export type AbstractInstanceType<T> = T extends new (...args: any) => infer U ? U : T extends { | ||
@@ -41,12 +41,22 @@ prototype: infer U; | ||
export type NormalizeReturnType<T> = T extends (...args: any) => infer R ? R : never; | ||
export type Denormalize<S> = S extends EntityInterface<infer U> ? U : S extends RecordClass ? AbstractInstanceType<S> : S extends SchemaClass ? DenormalizeReturnType<S['denormalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] : S extends { | ||
export type Denormalize<S> = S extends EntityInterface<infer U> ? U : S extends RecordClass ? AbstractInstanceType<S> : S extends { | ||
denormalizeOnly: (...args: any) => any; | ||
} ? ReturnType<S['denormalizeOnly']> : S extends { | ||
denormalize: (...args: any) => any; | ||
} ? DenormalizeReturnType<S['denormalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] : S extends { | ||
[K: string]: any; | ||
} ? DenormalizeObject<S> : S; | ||
export type DenormalizeNullable<S> = S extends EntityInterface<any> ? DenormalizeNullableNestedSchema<S> | undefined : S extends RecordClass ? DenormalizeNullableNestedSchema<S> : S extends SchemaClass ? DenormalizeReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
export type DenormalizeNullable<S> = S extends EntityInterface<any> ? DenormalizeNullableNestedSchema<S> | undefined : S extends RecordClass ? DenormalizeNullableNestedSchema<S> : S extends { | ||
_denormalizeNullable: (...args: any) => any; | ||
} ? DenormalizeReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
[K: string]: any; | ||
} ? DenormalizeNullableObject<S> : S; | ||
export type Normalize<S> = S extends EntityInterface ? string : S extends RecordClass ? NormalizeObject<S['schema']> : S extends SchemaClass ? NormalizeReturnType<S['normalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] : S extends { | ||
export type Normalize<S> = S extends EntityInterface ? string : S extends RecordClass ? NormalizeObject<S['schema']> : S extends { | ||
normalize: (...args: any) => any; | ||
} ? NormalizeReturnType<S['normalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] : S extends { | ||
[K: string]: any; | ||
} ? NormalizeObject<S> : S; | ||
export type NormalizeNullable<S> = S extends EntityInterface ? string | undefined : S extends RecordClass ? NormalizedNullableObject<S['schema']> : S extends SchemaClass ? NormalizeReturnType<S['_normalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] | undefined : S extends { | ||
export type NormalizeNullable<S> = S extends EntityInterface ? string | undefined : S extends RecordClass ? NormalizedNullableObject<S['schema']> : S extends { | ||
_normalizeNullable: (...args: any) => any; | ||
} ? NormalizeReturnType<S['_normalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Normalize<F>[] | undefined : S extends { | ||
[K: string]: any; | ||
@@ -53,0 +63,0 @@ } ? NormalizedNullableObject<S> : S; |
@@ -27,4 +27,5 @@ import type { SchemaSimple, UnvisitFunction } from './interface.js'; | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): R; | ||
}; | ||
export {}; | ||
//# sourceMappingURL=queryEndpoint.d.ts.map |
import type { SchemaSimple, Schema, UnvisitFunction, NormalizedIndex, EntityTable, EntityInterface, } from './interface.js'; | ||
import type { AbstractInstanceType, Normalize, NormalizeNullable, Denormalize, DenormalizeNullable, DenormalizeObject, DenormalizeNullableObject, NormalizeObject, NormalizedNullableObject, EntityMap, } from './normal.js'; | ||
import { CollectionOptions } from './schemas/Collection.js'; | ||
import { default as Delete } from './schemas/Delete.js'; | ||
import { EntityOptions, IEntityClass, IEntityInstance, RequiredPKOptions, IDClass, Constructor, PKClass, } from './schemas/EntitySchema.js'; | ||
export { Delete, EntityMap }; | ||
import { default as Invalidate } from './schemas/Invalidate.js'; | ||
export { Delete, EntityMap, Invalidate }; | ||
export { EntityInterface } from './interface.js'; | ||
@@ -16,3 +18,3 @@ /** | ||
readonly schema: S; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
_normalizeNullable(): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[] | undefined; | ||
@@ -31,2 +33,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): (S extends EntityMap<infer T> ? T : Denormalize<S>)[]; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
@@ -44,3 +47,3 @@ } | ||
readonly schema: S; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[]; | ||
_normalizeNullable(): (S extends EntityMap ? UnionResult<S> : Normalize<S>)[] | undefined; | ||
@@ -59,2 +62,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): (S extends EntityMap<infer T> ? T : Denormalize<S>)[]; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
@@ -70,3 +74,3 @@ } | ||
readonly schema: O; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): NormalizeObject<O>; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): NormalizeObject<O>; | ||
_normalizeNullable(): NormalizedNullableObject<O>; | ||
@@ -85,2 +89,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): DenormalizeObject<O>; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
@@ -98,3 +103,3 @@ } | ||
readonly schema: Choices; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): UnionResult<Choices>; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): UnionResult<Choices>; | ||
_normalizeNullable(): UnionResult<Choices> | undefined; | ||
@@ -113,2 +118,3 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): AbstractInstanceType<Choices[keyof Choices]>; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
@@ -127,3 +133,3 @@ } | ||
readonly schema: Choices; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): Record<string, Choices extends EntityMap ? UnionResult<Choices> : Normalize<Choices>>; | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): Record<string, Choices extends EntityMap ? UnionResult<Choices> : Normalize<Choices>>; | ||
_normalizeNullable(): Record<string, Choices extends EntityMap ? UnionResult<Choices> : NormalizeNullable<Choices>> | undefined; | ||
@@ -142,4 +148,73 @@ denormalize( | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): Record<string, Choices extends EntityMap<infer T> ? T : Denormalize<Choices>>; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any): any; | ||
} | ||
/** | ||
* Entities but for Arrays instead of classes | ||
* @see https://resthooks.io/rest/api/Collection | ||
*/ | ||
export class CollectionSchema<S extends Array<any> | Values<any> = any, Parent extends any[] = any> { | ||
addWith<P extends any[] = Parent>(merge: (existing: any, incoming: any) => any, createCollectionFilter?: (...args: P) => (collectionKey: Record<string, any>) => boolean): CollectionSchema<S, P>; | ||
readonly schema: S; | ||
key: string; | ||
pk(value: any, parent: any, key: string, args: any[]): string; | ||
normalize(input: any, parent: Parent, key: string, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args: any[]): string; | ||
merge(existing: any, incoming: any): any; | ||
shouldReorder(existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): boolean; | ||
mergeWithStore(existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): any; | ||
mergeMetaWithStore(existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}; | ||
infer(args: unknown, indexes: unknown, recurse: unknown, entities: unknown): any; | ||
createIfValid: (value: any) => any | undefined; | ||
denormalizeOnly(input: any, args: readonly any[], unvisit: (input: any, schema: any) => any): ReturnType<S['denormalizeOnly']>; | ||
_denormalizeNullable(): ReturnType<S['_denormalizeNullable']>; | ||
_normalizeNullable(): ReturnType<S['_normalizeNullable']>; | ||
} | ||
export type CollectionType<S extends any[] | Array<any> | Values<any> = any, Parent extends any[] = [ | ||
urlParams: Record<string, any>, | ||
body?: Record<string, any> | ||
]> = CollectionSchema<S extends any[] ? Array<S[number]> : S> & (S extends any[] ? { | ||
push: CollectionSchema<Array<S[number]>, Parent>; | ||
unshift: CollectionSchema<Array<S[number]>, Parent>; | ||
} : S extends Values<any> ? { | ||
assign: CollectionSchema<S, Parent>; | ||
} : S extends Array<any> ? { | ||
push: CollectionSchema<S, Parent>; | ||
unshift: CollectionSchema<S, Parent>; | ||
} : never); | ||
export interface CollectionConstructor { | ||
new <S extends SchemaSimple[] | Array<any> | Values<any> = any, Parent extends any[] = [ | ||
urlParams: Record<string, any>, | ||
body?: Record<string, any> | ||
]>(schema: S, options: CollectionOptions): CollectionType<S, Parent>; | ||
readonly prototype: CollectionSchema; | ||
} | ||
/** | ||
* Entities but for Arrays instead of classes | ||
* @see https://resthooks.io/rest/api/Collection | ||
*/ | ||
export declare let Collection: CollectionConstructor; | ||
export type StrategyFunction<T> = (value: any, parent: any, key: string) => T; | ||
@@ -164,2 +239,7 @@ export type SchemaFunction<K = string> = (value: any, parent: any, key: string) => K; | ||
} | ||
export interface SchemaSimpleNew<T = any> { | ||
normalize(input: any, parent: any, key: any, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>, storeEntities: any, args?: any[]): any; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): T; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
} | ||
// id is in Instance, so we default to that as pk | ||
@@ -166,0 +246,0 @@ /** |
@@ -11,5 +11,5 @@ import ArraySchema from './Array.js'; | ||
constructor(definition: S, schemaAttribute?: S extends EntityMap<infer T> ? keyof T | SchemaFunction<keyof S> : undefined); | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
infer(args: any, indexes: any, recurse: any, entities: EntityTable): any; | ||
} | ||
//# sourceMappingURL=All.d.ts.map |
@@ -7,3 +7,3 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ArraySchema extends PolymorphicSchema { | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
denormalize(input: any, unvisit: any): [ | ||
@@ -14,2 +14,3 @@ denormalized: any, | ||
]; | ||
denormalizeOnly(input: any, args: any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: unknown, indexes: unknown, recurse: unknown, entities: unknown): any; | ||
@@ -16,0 +17,0 @@ toJSON(): any[]; |
@@ -0,1 +1,2 @@ | ||
import Invalidate from './Invalidate.js'; | ||
import type { EntityInterface } from '../interface.js'; | ||
@@ -10,8 +11,3 @@ import type { AbstractInstanceType } from '../normal.js'; | ||
process: any; | ||
}> implements SchemaClass { | ||
private _entity; | ||
constructor(entity: E); | ||
get key(): string; | ||
normalize(input: any, parent: any, key: string | undefined, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): string | undefined; | ||
infer(args: any, indexes: any, recurse: any): any; | ||
}> extends Invalidate<E> implements SchemaClass { | ||
denormalize(id: string, unvisit: UnvisitFunction): [ | ||
@@ -22,17 +18,3 @@ denormalized: AbstractInstanceType<E>, | ||
]; | ||
_denormalizeNullable(): [ | ||
AbstractInstanceType<E> | undefined, | ||
boolean, | ||
false | ||
]; | ||
_normalizeNullable(): string | undefined; | ||
merge(existing: any, incoming: any): any; | ||
useIncoming(existingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): boolean; | ||
} | ||
//# sourceMappingURL=Delete.d.ts.map |
import type { UnvisitFunction } from '../interface.js'; | ||
import { AbstractInstanceType } from '../normal.js'; | ||
declare const Entity_base: import("./EntitySchema.js").IEntityClass<abstract new (...args: any[]) => { | ||
pk(parent?: any, key?: string | undefined): string | undefined; | ||
pk(parent?: any, key?: string | undefined, args?: readonly any[] | undefined): string | undefined; | ||
}> & (abstract new (...args: any[]) => { | ||
pk(parent?: any, key?: string | undefined): string | undefined; | ||
pk(parent?: any, key?: string | undefined, args?: readonly any[] | undefined): string | undefined; | ||
}); | ||
@@ -19,3 +19,3 @@ /** | ||
*/ | ||
abstract pk(parent?: any, key?: string): string | undefined; | ||
abstract pk(parent?: any, key?: string, args?: readonly any[]): string | undefined; | ||
/** Control how automatic schema validation is handled | ||
@@ -49,2 +49,15 @@ * | ||
}, existing: any, incoming: any): any; | ||
static mergeMetaWithStore(existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}; | ||
/** Factory method to convert from Plain JS Objects. | ||
@@ -62,3 +75,3 @@ * | ||
*/ | ||
static pk: <T extends typeof Entity>(this: T, value: Partial<AbstractInstanceType<T>>, parent?: any, key?: string) => string | undefined; | ||
static pk: <T extends typeof Entity>(this: T, value: Partial<AbstractInstanceType<T>>, parent?: any, key?: string, args?: any[]) => string | undefined; | ||
/** Do any transformations when first receiving input */ | ||
@@ -65,0 +78,0 @@ static process(input: any, parent: any, key: string | undefined): any; |
@@ -8,3 +8,3 @@ import type { Schema, NormalizedIndex, UnvisitFunction } from '../interface.js'; | ||
export type PKClass = abstract new (...args: any[]) => { | ||
pk(parent?: any, key?: string): string | undefined; | ||
pk(parent?: any, key?: string, args?: readonly any[]): string | undefined; | ||
}; | ||
@@ -33,9 +33,18 @@ type ValidSchemas<TInstance> = { | ||
}; | ||
/** Defines nested entities */ | ||
/** Defines nested entities | ||
* | ||
* @see https://resthooks.io/rest/api/Entity#schema | ||
*/ | ||
schema: { | ||
[k: string]: Schema; | ||
}; | ||
/** Returns the globally unique identifier for the static Entity */ | ||
/** Returns the globally unique identifier for the static Entity | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#key | ||
*/ | ||
key: string; | ||
/** Defines indexes to enable lookup by */ | ||
/** Defines indexes to enable lookup by | ||
* | ||
* @see https://resthooks.io/rest/api/Entity#indexes | ||
*/ | ||
indexes?: readonly string[] | undefined; | ||
@@ -45,2 +54,3 @@ /** | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#pk | ||
* @param [value] POJO of the entity or subset used | ||
@@ -50,3 +60,3 @@ * @param [parent] When normalizing, the object which included the entity | ||
*/ | ||
pk<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, value: Partial<AbstractInstanceType<T>>, parent?: any, key?: string): string | undefined; | ||
pk<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, value: Partial<AbstractInstanceType<T>>, parent?: any, key?: string, args?: any[]): string | undefined; | ||
/** Return true to merge incoming data; false keeps existing entity | ||
@@ -75,5 +85,11 @@ * | ||
}, existing: any, incoming: any): boolean; | ||
/** Creates new instance copying over defined values of arguments */ | ||
/** Creates new instance copying over defined values of arguments | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#merge | ||
*/ | ||
merge(existing: any, incoming: any): any; | ||
/** Run when an existing entity is found in the store */ | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeWithStore | ||
*/ | ||
mergeWithStore(existingMeta: { | ||
@@ -86,2 +102,19 @@ date: number; | ||
}, existing: any, incoming: any): any; | ||
/** Run when an existing entity is found in the store | ||
* | ||
* @see https://resthooks.io/docs/api/schema.Entity#mergeMetaWithStore | ||
*/ | ||
mergeMetaWithStore(existingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, incomingMeta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, existing: any, incoming: any): { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}; | ||
/** Factory method to convert from Plain JS Objects. | ||
@@ -92,17 +125,24 @@ * | ||
fromJS<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, props?: Partial<AbstractInstanceType<T>>): AbstractInstanceType<T>; | ||
/** Factory method to convert from Plain JS Objects. | ||
/** Called when denormalizing an entity to create an instance when 'valid' | ||
* | ||
* @param [props] Plain Object of properties to assign. | ||
* @see https://resthooks.io/docs/api/Entity#createIfValid | ||
*/ | ||
createIfValid<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, props: Partial<AbstractInstanceType<T>>): AbstractInstanceType<T> | undefined; | ||
/** Do any transformations when first receiving input */ | ||
/** Do any transformations when first receiving input | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#process | ||
*/ | ||
process(input: any, parent: any, key: string | undefined): any; | ||
normalize(input: any, parent: any, key: string | undefined, visit: (...args: any) => any, addEntity: (...args: any) => any, visitedEntities: Record<string, any>): any; | ||
/** Do any transformations when first receiving input | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#validate | ||
*/ | ||
validate(processedEntity: any): string | undefined; | ||
/** Attempts to infer results | ||
* | ||
* @see https://resthooks.io/docs/api/Entity#infer | ||
*/ | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: any): any; | ||
expiresAt(meta: { | ||
expiresAt: number; | ||
date: number; | ||
fetchedAt: number; | ||
}, input: any): number; | ||
denormalize<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, input: any, unvisit: UnvisitFunction): [ | ||
@@ -113,2 +153,3 @@ denormalized: AbstractInstanceType<T>, | ||
]; | ||
denormalizeOnly<T extends (abstract new (...args: any[]) => IEntityInstance & InstanceType<TBase>) & IEntityClass & TBase>(this: T, input: any, unvisit: (input: any, schema: any) => any): AbstractInstanceType<T>; | ||
/** All instance defaults set */ | ||
@@ -124,5 +165,5 @@ readonly defaults: any; | ||
*/ | ||
pk(parent?: any, key?: string): string | undefined; | ||
pk(parent?: any, key?: string, args?: readonly any[]): string | undefined; | ||
} | ||
export {}; | ||
//# sourceMappingURL=EntitySchema.d.ts.map |
@@ -30,2 +30,12 @@ /** | ||
]; | ||
/** | ||
* Denormalize an immutable entity. | ||
* | ||
* @param {Schema} schema | ||
* @param {Immutable.Map|Immutable.Record} input | ||
* @param {function} unvisit | ||
* @param {function} getDenormalizedEntity | ||
* @return {Immutable.Map|Immutable.Record} | ||
*/ | ||
export declare function denormalizeOnlyImmutable(schema: any, input: any, unvisit: (input: any, schema: any) => any): any; | ||
//# sourceMappingURL=ImmutableUtils.d.ts.map |
@@ -1,2 +0,2 @@ | ||
export declare const normalize: (schema: any, input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any) => any; | ||
export declare const normalize: (schema: any, input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]) => any; | ||
export declare const denormalize: (schema: any, input: {}, unvisit: any) => [ | ||
@@ -7,2 +7,3 @@ denormalized: any, | ||
]; | ||
export declare function denormalizeOnly(schema: any, input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
export declare function infer(schema: any, args: readonly any[], indexes: any, recurse: any, entities: any): any; | ||
@@ -23,3 +24,5 @@ /** | ||
addEntity: any, | ||
visitedEntities: any | ||
visitedEntities: any, | ||
storeEntities: any, | ||
args: any[] | ||
]): any; | ||
@@ -34,4 +37,5 @@ denormalize(...args: readonly [ | ||
]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any, entities: any): any; | ||
} | ||
//# sourceMappingURL=Object.d.ts.map |
@@ -9,5 +9,5 @@ export default class PolymorphicSchema { | ||
inferSchema(input: any, parent: any, key: any): any; | ||
normalizeValue(value: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalizeValue(value: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args?: any[]): any; | ||
denormalizeValue(value: any, unvisit: any): any; | ||
} | ||
//# sourceMappingURL=Polymorphic.d.ts.map |
@@ -8,4 +8,5 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
constructor(definition: any, schemaAttribute: any); | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): any; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]): any; | ||
denormalize(input: {}, unvisit: any): any; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any, entities: any): { | ||
@@ -12,0 +13,0 @@ id: any; |
export declare const getValues: (input: any) => any[]; | ||
export declare const filterEmpty: ([item, , deletedItem]: any) => boolean; | ||
export declare const filterEmpty: (item: any) => boolean; | ||
//# sourceMappingURL=utils.d.ts.map |
@@ -7,6 +7,7 @@ import PolymorphicSchema from './Polymorphic.js'; | ||
export default class ValuesSchema extends PolymorphicSchema { | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any): {}; | ||
normalize(input: any, parent: any, key: any, visit: any, addEntity: any, visitedEntities: any, storeEntities: any, args: any[]): {}; | ||
denormalize(input: {}, unvisit: any): {}[]; | ||
denormalizeOnly(input: {}, args: readonly any[], unvisit: (input: any, schema: any) => any): any; | ||
infer(args: any, indexes: any, recurse: any): undefined; | ||
} | ||
//# sourceMappingURL=Values.d.ts.map |
export declare const DELETED: unique symbol; | ||
export declare const INVALID: symbol; | ||
//# sourceMappingURL=special.d.ts.map |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
1700644
2
368
29131
234
1
30