@data-client/normalizr
Advanced tools
Comparing version 0.2.2 to 0.8.0
@@ -150,9 +150,4 @@ define(['exports'], (function (exports) { 'use strict'; | ||
}); | ||
if (typeof entity === 'symbol') { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
return schema.denormalizeOnly(entity, args, unvisit); | ||
// TODO(breaking): Change to this as breaking change once we only support newer entities | ||
} else if (entity.toString().includes('DELETED')) { | ||
return INVALID; | ||
} | ||
if (typeof entity === 'symbol' && typeof schema.denormalize === 'function') { | ||
return schema.denormalize(entity, args, unvisit); | ||
} | ||
@@ -182,12 +177,3 @@ if (typeof entity !== 'object' || entity === null) { | ||
function unvisitEntityObject(entity, schema, unvisit, pk, localCacheKey, args) { | ||
let entityCopy, _, deleted; | ||
/* istanbul ignore else */ | ||
if (schema.createIfValid) { | ||
entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
// TODO(breaking): remove once old verions no longer supported | ||
} /* istanbul ignore next */else { | ||
entityCopy = entity; | ||
unvisit = withTrackedEntities(unvisit); | ||
unvisit.setLocal = entityCopy => localCacheKey[pk] = entityCopy; | ||
} | ||
const entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
if (entityCopy === undefined) { | ||
@@ -197,24 +183,8 @@ // undefined indicates we should suspense (perhaps failed validation) | ||
} else { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
localCacheKey[pk] = schema.denormalizeOnly(entityCopy, args, unvisit); | ||
} else { | ||
[localCacheKey[pk], _, deleted] = schema.denormalize(entityCopy, unvisit); | ||
if (deleted) localCacheKey[pk] = INVALID; | ||
if (typeof schema.denormalize === 'function') { | ||
localCacheKey[pk] = schema.denormalize(entityCopy, args, unvisit); | ||
} | ||
} | ||
} | ||
// TODO(breaking): remove once unused | ||
/* istanbul ignore next */ | ||
function withTrackedEntities(unvisit) { | ||
// every time we nest, we want to unwrap back to the top. | ||
// this is due to only needed the next level of nested entities for lookup | ||
const originalUnvisit = unvisit.og || unvisit; | ||
const wrappedUnvisit = (input, schema) => originalUnvisit(input, schema); | ||
wrappedUnvisit.og = unvisit; | ||
return wrappedUnvisit; | ||
} | ||
const getUnvisit = (getEntity, cache, args) => { | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
const unvisitAdapter = getUnvisitAdapter(unvisit); | ||
function unvisit(input, schema) { | ||
@@ -225,14 +195,11 @@ if (!schema) return input; | ||
} | ||
const hasDenormalize = typeof schema.denormalize === 'function' || typeof schema.denormalizeOnly === 'function'; | ||
const hasDenormalize = typeof schema.denormalize === 'function'; | ||
// deserialize fields (like Date) | ||
// deserialize fields (like Temporal.Instant) | ||
if (!hasDenormalize && typeof schema === 'function') { | ||
if (input instanceof schema) return input; | ||
if (input === undefined) return input; | ||
return new schema(input); | ||
return schema(input); | ||
} | ||
if (input === undefined) { | ||
var _schema$constructor; | ||
// TODO(breaking): Drop support for initial All version | ||
const isAll = ((_schema$constructor = schema.constructor) == null ? void 0 : _schema$constructor.name) === 'AllSchema'; | ||
const isAll = schema.constructor.name === 'AllSchema'; | ||
return isAll ? INVALID : undefined; | ||
@@ -245,10 +212,6 @@ } | ||
if (isEntity(schema)) { | ||
return unvisitEntity(input, schema, args, schema.denormalizeOnly ? unvisit : unvisitAdapter, getEntity, cache); | ||
return unvisitEntity(input, schema, args, unvisit, getEntity, cache); | ||
} | ||
if (hasDenormalize) { | ||
if (schema.denormalizeOnly) { | ||
return schema.denormalizeOnly(input, args, unvisit); | ||
} else { | ||
return denormalizeLegacySchema(schema, input, unvisitAdapter); | ||
} | ||
return schema.denormalize(input, args, unvisit); | ||
} | ||
@@ -265,27 +228,3 @@ return input; | ||
var getUnvisit$1 = getUnvisit; | ||
function denormalizeLegacySchema(schema, input, unvisitAdapter) { | ||
const [data, _, suspend] = schema.denormalize(input, unvisitAdapter); | ||
// TODO(breaking): Drop support for initial Query version | ||
// queryEndpoint schema only overrides 'denormalize' and 'infer' | ||
const isQuery = !Object.hasOwn(schema, 'normalize') && Object.hasOwn(schema, 'denormalize') && Object.hasOwn(schema, 'infer'); | ||
return suspend && !isQuery ? INVALID : data; | ||
} | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
function getUnvisitAdapter(unvisit) { | ||
return function (input, schema) { | ||
var _schema$constructor2; | ||
const isAll = (schema == null ? void 0 : (_schema$constructor2 = schema.constructor) == null ? void 0 : _schema$constructor2.name) === 'AllSchema'; | ||
const value = unvisit(input, schema); | ||
// TODO(breaking): Drop support for initial All version | ||
if (isAll) { | ||
// we swap 'found' and 'suspend' because the initial Query version used 'found' to determine whether | ||
// it should 'process' | ||
return [typeof value === 'symbol' ? undefined : value, typeof value !== 'symbol', false]; | ||
} | ||
return [typeof value === 'symbol' ? undefined : value, true, typeof value === 'symbol']; | ||
}; | ||
} | ||
/** Maps entity dependencies to a value (usually their denormalized form) | ||
@@ -544,5 +483,2 @@ * | ||
const DELETED = Symbol('ENTITY WAS DELETED'); | ||
var _s = $RefreshSig$(); | ||
const visit = (value, parent, key, schema, addEntity, visitedEntities, storeEntities, args) => { | ||
@@ -556,7 +492,2 @@ if (!value || !schema) { | ||
} | ||
// serializable | ||
if (typeof schema === 'function') { | ||
return new schema(value); | ||
} | ||
if (typeof value !== 'object' || typeof schema !== 'object') return value; | ||
@@ -581,9 +512,8 @@ const method = Array.isArray(schema) ? normalize$2 : normalize$1; | ||
if (inStoreEntity && (inStoreMeta = storeEntityMeta[schemaKey][id])) { | ||
entities[schemaKey][id] = schema.mergeWithStore ? schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore ? schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeMetaWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
entities[schemaKey][id] = schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
} else { | ||
entities[schemaKey][id] = processedEntity; | ||
storeEntityMeta[schemaKey][id] = { | ||
// TODO(breaking): Remove schema.expiresat | ||
expiresAt: schema.expiresAt ? schema.expiresAt(meta, processedEntity) : meta.expiresAt, | ||
expiresAt: meta.expiresAt, | ||
date: meta.date, | ||
@@ -617,3 +547,3 @@ fetchedAt: meta.fetchedAt | ||
if (storeEntities && storeEntities[id] && storeEntities[id][index] !== entity[index]) { | ||
indexMap[storeEntities[id][index]] = DELETED; | ||
indexMap[storeEntities[id][index]] = INVALID; | ||
} | ||
@@ -631,33 +561,2 @@ if (index in entity) { | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeStore() instead */ | ||
function mergeWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
_s(); | ||
const useIncoming = | ||
// useIncoming should not be used with legacy optimistic | ||
schema.useIncoming && incomingMeta.fetchedAt ? schema.useIncoming(existingMeta, incomingMeta, existing, incoming) : existingMeta.date <= incomingMeta.date; | ||
if (useIncoming) { | ||
if (typeof incoming !== typeof existing) { | ||
return incoming; | ||
} else { | ||
return schema.merge(existing, incoming); | ||
} | ||
} else { | ||
return existing; | ||
} | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeMetaWithStore() instead */ | ||
_s(mergeWithStore, "RSHyr3aBwsmLX8s7SwDQGEQTEhQ=", false, function () { | ||
return [schema.useIncoming]; | ||
}); | ||
function mergeMetaWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
return { | ||
expiresAt: Math.max(schema.expiresAt ? schema.expiresAt(incomingMeta, incoming) : incomingMeta.expiresAt, existingMeta.expiresAt), | ||
date: Math.max(incomingMeta.date, existingMeta.date), | ||
fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt) | ||
}; | ||
} | ||
function expectedSchemaType(schema) { | ||
@@ -698,3 +597,3 @@ return ['object', 'function'].includes(typeof schema) ? 'object' : typeof schema; | ||
the JSON. By default, this only happens if "content-type" header includes "json". | ||
See https://resthooks.io/rest/api/RestEndpoint#parseResponse for more information | ||
See https://dataclient.io/rest/api/RestEndpoint#parseResponse for more information | ||
@@ -736,9 +635,3 @@ Schema: ${JSON.stringify(schema, undefined, 2)} | ||
if (canInfer(schema)) { | ||
var _entities$schema$key; | ||
const ret = schema.infer(args, indexes, inferResults, entities); | ||
// TODO(breaking): back compatibility with endpoint@3.7 and less | ||
if (isEntity(schema) && ret !== undefined && !((_entities$schema$key = entities[schema.key]) != null && _entities$schema$key[ret])) { | ||
return undefined; | ||
} | ||
return ret; | ||
return schema.infer(args, indexes, inferResults, entities); | ||
} | ||
@@ -779,3 +672,2 @@ | ||
exports.DELETED = DELETED; | ||
exports.ExpiryStatus = ExpiryStatus; | ||
@@ -782,0 +674,0 @@ exports.INVALID = INVALID; |
@@ -151,9 +151,4 @@ var data_client_normalizr = (function (exports) { | ||
}); | ||
if (typeof entity === 'symbol') { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
return schema.denormalizeOnly(entity, args, unvisit); | ||
// TODO(breaking): Change to this as breaking change once we only support newer entities | ||
} else if (entity.toString().includes('DELETED')) { | ||
return INVALID; | ||
} | ||
if (typeof entity === 'symbol' && typeof schema.denormalize === 'function') { | ||
return schema.denormalize(entity, args, unvisit); | ||
} | ||
@@ -183,12 +178,3 @@ if (typeof entity !== 'object' || entity === null) { | ||
function unvisitEntityObject(entity, schema, unvisit, pk, localCacheKey, args) { | ||
let entityCopy, _, deleted; | ||
/* istanbul ignore else */ | ||
if (schema.createIfValid) { | ||
entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
// TODO(breaking): remove once old verions no longer supported | ||
} /* istanbul ignore next */else { | ||
entityCopy = entity; | ||
unvisit = withTrackedEntities(unvisit); | ||
unvisit.setLocal = entityCopy => localCacheKey[pk] = entityCopy; | ||
} | ||
const entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
if (entityCopy === undefined) { | ||
@@ -198,24 +184,8 @@ // undefined indicates we should suspense (perhaps failed validation) | ||
} else { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
localCacheKey[pk] = schema.denormalizeOnly(entityCopy, args, unvisit); | ||
} else { | ||
[localCacheKey[pk], _, deleted] = schema.denormalize(entityCopy, unvisit); | ||
if (deleted) localCacheKey[pk] = INVALID; | ||
if (typeof schema.denormalize === 'function') { | ||
localCacheKey[pk] = schema.denormalize(entityCopy, args, unvisit); | ||
} | ||
} | ||
} | ||
// TODO(breaking): remove once unused | ||
/* istanbul ignore next */ | ||
function withTrackedEntities(unvisit) { | ||
// every time we nest, we want to unwrap back to the top. | ||
// this is due to only needed the next level of nested entities for lookup | ||
const originalUnvisit = unvisit.og || unvisit; | ||
const wrappedUnvisit = (input, schema) => originalUnvisit(input, schema); | ||
wrappedUnvisit.og = unvisit; | ||
return wrappedUnvisit; | ||
} | ||
const getUnvisit = (getEntity, cache, args) => { | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
const unvisitAdapter = getUnvisitAdapter(unvisit); | ||
function unvisit(input, schema) { | ||
@@ -226,14 +196,11 @@ if (!schema) return input; | ||
} | ||
const hasDenormalize = typeof schema.denormalize === 'function' || typeof schema.denormalizeOnly === 'function'; | ||
const hasDenormalize = typeof schema.denormalize === 'function'; | ||
// deserialize fields (like Date) | ||
// deserialize fields (like Temporal.Instant) | ||
if (!hasDenormalize && typeof schema === 'function') { | ||
if (input instanceof schema) return input; | ||
if (input === undefined) return input; | ||
return new schema(input); | ||
return schema(input); | ||
} | ||
if (input === undefined) { | ||
var _schema$constructor; | ||
// TODO(breaking): Drop support for initial All version | ||
const isAll = ((_schema$constructor = schema.constructor) == null ? void 0 : _schema$constructor.name) === 'AllSchema'; | ||
const isAll = schema.constructor.name === 'AllSchema'; | ||
return isAll ? INVALID : undefined; | ||
@@ -246,10 +213,6 @@ } | ||
if (isEntity(schema)) { | ||
return unvisitEntity(input, schema, args, schema.denormalizeOnly ? unvisit : unvisitAdapter, getEntity, cache); | ||
return unvisitEntity(input, schema, args, unvisit, getEntity, cache); | ||
} | ||
if (hasDenormalize) { | ||
if (schema.denormalizeOnly) { | ||
return schema.denormalizeOnly(input, args, unvisit); | ||
} else { | ||
return denormalizeLegacySchema(schema, input, unvisitAdapter); | ||
} | ||
return schema.denormalize(input, args, unvisit); | ||
} | ||
@@ -266,27 +229,3 @@ return input; | ||
var getUnvisit$1 = getUnvisit; | ||
function denormalizeLegacySchema(schema, input, unvisitAdapter) { | ||
const [data, _, suspend] = schema.denormalize(input, unvisitAdapter); | ||
// TODO(breaking): Drop support for initial Query version | ||
// queryEndpoint schema only overrides 'denormalize' and 'infer' | ||
const isQuery = !Object.hasOwn(schema, 'normalize') && Object.hasOwn(schema, 'denormalize') && Object.hasOwn(schema, 'infer'); | ||
return suspend && !isQuery ? INVALID : data; | ||
} | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
function getUnvisitAdapter(unvisit) { | ||
return function (input, schema) { | ||
var _schema$constructor2; | ||
const isAll = (schema == null ? void 0 : (_schema$constructor2 = schema.constructor) == null ? void 0 : _schema$constructor2.name) === 'AllSchema'; | ||
const value = unvisit(input, schema); | ||
// TODO(breaking): Drop support for initial All version | ||
if (isAll) { | ||
// we swap 'found' and 'suspend' because the initial Query version used 'found' to determine whether | ||
// it should 'process' | ||
return [typeof value === 'symbol' ? undefined : value, typeof value !== 'symbol', false]; | ||
} | ||
return [typeof value === 'symbol' ? undefined : value, true, typeof value === 'symbol']; | ||
}; | ||
} | ||
/** Maps entity dependencies to a value (usually their denormalized form) | ||
@@ -545,5 +484,2 @@ * | ||
const DELETED = Symbol('ENTITY WAS DELETED'); | ||
var _s = $RefreshSig$(); | ||
const visit = (value, parent, key, schema, addEntity, visitedEntities, storeEntities, args) => { | ||
@@ -557,7 +493,2 @@ if (!value || !schema) { | ||
} | ||
// serializable | ||
if (typeof schema === 'function') { | ||
return new schema(value); | ||
} | ||
if (typeof value !== 'object' || typeof schema !== 'object') return value; | ||
@@ -582,9 +513,8 @@ const method = Array.isArray(schema) ? normalize$2 : normalize$1; | ||
if (inStoreEntity && (inStoreMeta = storeEntityMeta[schemaKey][id])) { | ||
entities[schemaKey][id] = schema.mergeWithStore ? schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore ? schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeMetaWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
entities[schemaKey][id] = schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
} else { | ||
entities[schemaKey][id] = processedEntity; | ||
storeEntityMeta[schemaKey][id] = { | ||
// TODO(breaking): Remove schema.expiresat | ||
expiresAt: schema.expiresAt ? schema.expiresAt(meta, processedEntity) : meta.expiresAt, | ||
expiresAt: meta.expiresAt, | ||
date: meta.date, | ||
@@ -618,3 +548,3 @@ fetchedAt: meta.fetchedAt | ||
if (storeEntities && storeEntities[id] && storeEntities[id][index] !== entity[index]) { | ||
indexMap[storeEntities[id][index]] = DELETED; | ||
indexMap[storeEntities[id][index]] = INVALID; | ||
} | ||
@@ -632,33 +562,2 @@ if (index in entity) { | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeStore() instead */ | ||
function mergeWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
_s(); | ||
const useIncoming = | ||
// useIncoming should not be used with legacy optimistic | ||
schema.useIncoming && incomingMeta.fetchedAt ? schema.useIncoming(existingMeta, incomingMeta, existing, incoming) : existingMeta.date <= incomingMeta.date; | ||
if (useIncoming) { | ||
if (typeof incoming !== typeof existing) { | ||
return incoming; | ||
} else { | ||
return schema.merge(existing, incoming); | ||
} | ||
} else { | ||
return existing; | ||
} | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeMetaWithStore() instead */ | ||
_s(mergeWithStore, "RSHyr3aBwsmLX8s7SwDQGEQTEhQ=", false, function () { | ||
return [schema.useIncoming]; | ||
}); | ||
function mergeMetaWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
return { | ||
expiresAt: Math.max(schema.expiresAt ? schema.expiresAt(incomingMeta, incoming) : incomingMeta.expiresAt, existingMeta.expiresAt), | ||
date: Math.max(incomingMeta.date, existingMeta.date), | ||
fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt) | ||
}; | ||
} | ||
function expectedSchemaType(schema) { | ||
@@ -699,3 +598,3 @@ return ['object', 'function'].includes(typeof schema) ? 'object' : typeof schema; | ||
the JSON. By default, this only happens if "content-type" header includes "json". | ||
See https://resthooks.io/rest/api/RestEndpoint#parseResponse for more information | ||
See https://dataclient.io/rest/api/RestEndpoint#parseResponse for more information | ||
@@ -737,9 +636,3 @@ Schema: ${JSON.stringify(schema, undefined, 2)} | ||
if (canInfer(schema)) { | ||
var _entities$schema$key; | ||
const ret = schema.infer(args, indexes, inferResults, entities); | ||
// TODO(breaking): back compatibility with endpoint@3.7 and less | ||
if (isEntity(schema) && ret !== undefined && !((_entities$schema$key = entities[schema.key]) != null && _entities$schema$key[ret])) { | ||
return undefined; | ||
} | ||
return ret; | ||
return schema.infer(args, indexes, inferResults, entities); | ||
} | ||
@@ -780,3 +673,2 @@ | ||
exports.DELETED = DELETED; | ||
exports.ExpiryStatus = ExpiryStatus; | ||
@@ -783,0 +675,0 @@ exports.INVALID = INVALID; |
@@ -1,1 +0,1 @@ | ||
class e{constructor(){this.localCache={}}getEntity(e,t,n,r){const i=t.key;i in this.localCache||(this.localCache[i]=Object.create(null));const o=this.localCache[i];return o[e]||r(o),o[e]}getResults(e,t,n){return{data:n(),paths:[]}}}const t=Symbol("INVALID");function n(e){return null!==e&&void 0!==e.pk}const r=e=>{if("production"!==process.env.NODE_ENV){if(Array.isArray(e)&&e.length>1)throw new Error(`Expected schema definition to be a single schema, but found ${e.length}.`)}return e[0]},i=e=>void 0!==e&&"symbol"!=typeof e,o=(e,t,n,i,o,s,c,a,l)=>{e=r(e);const u=(e=>Array.isArray(e)?e:Object.keys(e).map((t=>e[t])))(t);return u.map(((t,r)=>o(t,n,i,e,s,c,a,l)))},s=(e,t,n,o)=>(e=r(e),t.map?t.map((t=>o(t,e))).filter(i):t);function c(e,t,n,r){}function a(e){return!("function"!=typeof e.hasOwnProperty||!(Object.hasOwnProperty.call(e,"__ownerID")||e._map&&Object.hasOwnProperty.call(e._map,"__ownerID")))}const l=(e,t,n,r,i,o,s,c,a)=>{const l=Object.assign({},t);return Object.keys(e).forEach((n=>{const r=e[n],u=i(t[n],t,n,r,o,s,c,a);null==u?delete l[n]:l[n]=u})),l},u=(e,n,r,i)=>{if(a(n))return function(e,n,r,i){let o=!1;const s=Object.keys(e).reduce(((t,n)=>{const r=`${n}`,s=i(t.get(r),e[r]);return"symbol"==typeof s&&(o=!0),t.has(r)?t.set(r,s):t}),n);return o?t:s}(e,n,0,i);const o=Object.assign({},n);let s=!1;return Object.keys(e).forEach((t=>{const n=i(o[t],e[t]);void 0!==o[t]&&(o[t]=n),"symbol"==typeof n&&(s=!0)})),s?t:o};function h(e,t,n,r,i){const o={};for(const s of Object.keys(e))o[s]=r(e[s],t,n,i);return o}function d(e,n,r,i,o,s){let c,l,u;n.createIfValid?c=o[i]=a(e)?n.createIfValid(e.toObject()):n.createIfValid(e):(c=e,r=function(e){const t=e.og||e,n=(e,n)=>t(e,n);return n.og=e,n}(r),r.setLocal=e=>o[i]=e),void 0===c?o[i]=t:"function"==typeof n.denormalizeOnly?o[i]=n.denormalizeOnly(c,s,r):([o[i],l,u]=n.denormalize(c,r),u&&(o[i]=t))}var f=(e,r,i)=>{const o=function(e){return function(t,n){var r;const i="AllSchema"===(null==n||null==(r=n.constructor)?void 0:r.name),o=e(t,n);return i?["symbol"==typeof o?void 0:o,"symbol"!=typeof o,!1]:["symbol"==typeof o?void 0:o,!0,"symbol"==typeof o]}}(c);function c(l,h){if(!h)return l;if(null===l)return l;const f="function"==typeof h.denormalize||"function"==typeof h.denormalizeOnly;if(!f&&"function"==typeof h)return l instanceof h||void 0===l?l:new h(l);if(void 0===l){var y;return"AllSchema"===(null==(y=h.constructor)?void 0:y.name)?t:void 0}if(!f&&"object"==typeof h){return(Array.isArray(h)?s:u)(h,l,i,c)}return n(h)?function(e,n,r,i,o,s){const c="object"==typeof e?e:o({key:n.key,pk:e});if("symbol"==typeof c){if("function"==typeof n.denormalizeOnly)return n.denormalizeOnly(c,r,i);if(c.toString().includes("DELETED"))return t}if("object"!=typeof c||null===c)return c;const l="string"==typeof e?e:n.pk(a(c)?c.toJS():c,void 0,void 0,r);return void 0===l||""===l||"undefined"===l?function(e){const t={};return e(t),t[""]}((e=>d(c,n,i,"",e,r))):s.getEntity(l,n,c,(e=>d(c,n,i,l,e,r)))}(l,h,i,h.denormalizeOnly?c:o,e,r):f?h.denormalizeOnly?h.denormalizeOnly(l,i,c):function(e,n,r){const[i,o,s]=e.denormalize(n,r),c=!Object.hasOwn(e,"normalize")&&Object.hasOwn(e,"denormalize")&&Object.hasOwn(e,"infer");return s&&!c?t:i}(h,l,o):l}return(e,t)=>{const n=Object(e)===e&&Object(t)===t;return r.getResults(e,n,(()=>c(e,t)))}};class y{constructor(){this.next=new WeakMap,this.nextPath=void 0}get(e,t){let n=this.next.get(e);if(!n)return p;for(;n.nextPath;){const e=t(n.nextPath);if(n=n.next.get(e),!n)return p}return[n.value,n.journey]}set(e,t){if(e.length<1)throw new b;let n=this;for(const{entity:t,path:r}of e){let e=n.next.get(t);e||(e=new v,n.next.set(t,e)),n.nextPath=r,n=e}n.nextPath=void 0,n.value=t,n.journey=g(e)}}const p=[void 0,void 0];function m(e){return a(e)?({key:t,pk:n})=>e.getIn([t,n]):({key:t,pk:n})=>{var r;return null==(r=e[t])?void 0:r[n]}}function g(e){var t;const n=e.map((e=>e.path));return""===(null==(t=n[0])?void 0:t.pk)&&n.shift(),n}class v{constructor(){this.next=new WeakMap,this.value=void 0,this.journey=[],this.nextPath=void 0}}class b extends Error{constructor(...e){super(...e),this.message="Keys must include at least one member"}}function O(t,n,r,i=[]){return void 0===n||void 0===t?t:f(m(r),new e,i)(t,n).data}class x{constructor(e,t,n){this.dependencies=[],this.cycleCache={},this.cycleIndex=-1,this.localCache={},this._getEntity=e,this.getCache=j(t),this.resultCache=n}getEntity(e,t,n,r){const i=t.key,{localCacheKey:o,cycleCacheKey:s}=this.getCacheKey(i);if(o[e])e in s?this.cycleIndex=s[e]:this.dependencies.push({entity:n,path:{key:i,pk:e}});else{const c=this.getCache(e,t),[a,l]=c.get(n,this._getEntity);if(l)return o[e]=a.value,this.dependencies.push(...a.dependencies),a.value;{const t=this.dependencies.length;s[e]=t,this.dependencies.push({entity:n,path:{key:i,pk:e}}),r(o),delete s[e];const a=this.dependencies.slice(-1===this.cycleIndex?t:this.cycleIndex),l={dependencies:a,value:o[e]};c.set(a,l),this.cycleIndex===t&&(this.cycleIndex=-1)}}return o[e]}getCacheKey(e){e in this.localCache||(this.localCache[e]=Object.create(null)),e in this.cycleCache||(this.cycleCache[e]=Object.create(null));return{localCacheKey:this.localCache[e],cycleCacheKey:this.cycleCache[e]}}getResults(e,t,n){if(!t)return{data:n(),paths:this.paths()};let[r,i]=this.resultCache.get(e,this._getEntity);return void 0===i&&(r=n(),i=this.paths(),this.dependencies.unshift({entity:e,path:{key:"",pk:""}}),this.resultCache.set(this.dependencies,r)),{data:r,paths:i}}paths(){return g(this.dependencies)}}const j=e=>(t,n)=>{var r;const i=n.key,o=null!=(r=n.cacheWith)?r:n;i in e||(e[i]=Object.create(null));const s=e[i];s[t]||(s[t]=new WeakMap);let c=s[t].get(o);return c||(c=new y,s[t].set(o,c)),c};function k(e,t,n,r={},i=new y,o=[]){if(void 0===t)return{data:e,paths:[]};if(void 0===e)return{data:void 0,paths:[]};const s=m(n);return f(s,new x(s,r,i),o)(e,t)}const w=Symbol("ENTITY WAS DELETED"),A=(e,t,n,r,i,s,c,a)=>{if(!e||!r)return e;if(r.normalize&&"function"==typeof r.normalize)return"object"!=typeof e?e:r.normalize(e,t,n,A,i,s,c,a);if("function"==typeof r)return new r(e);if("object"!=typeof e||"object"!=typeof r)return e;return(Array.isArray(r)?o:l)(r,e,t,n,A,i,s,c,a)},E=(e,t,n,r,i,o)=>(s,c,a)=>{const l=s.key;l in e||(e[l]={},n[l]=Object.assign({},n[l]),i[l]=Object.assign({},i[l]));const u=e[l][a];if(u)e[l][a]=s.merge(u,c);else{const t=n[l][a];let r;t&&(r=i[l][a])?(e[l][a]=s.mergeWithStore?s.mergeWithStore(r,o,t,c):function(e,t,n,r,i){const o=e.useIncoming&&n.fetchedAt?e.useIncoming(t,n,r,i):t.date<=n.date;return o?typeof i!=typeof r?i:e.merge(r,i):r}(s,r,o,t,c),i[l][a]=s.mergeMetaWithStore?s.mergeMetaWithStore(r,o,t,c):function(e,t,n,r,i){return{expiresAt:Math.max(e.expiresAt?e.expiresAt(n,i):n.expiresAt,t.expiresAt),date:Math.max(n.date,t.date),fetchedAt:Math.max(n.fetchedAt,t.fetchedAt)}}(s,r,o,0,c)):(e[l][a]=c,i[l][a]={expiresAt:s.expiresAt?s.expiresAt(o,c):o.expiresAt,date:o.date,fetchedAt:o.fetchedAt})}s.indexes&&(l in t||(t[l]={},r[l]=Object.assign({},r[l])),function(e,t,n,r,i,o){for(const s of t){s in n||(r[s]=n[s]={});const t=n[s];o[e]&&delete t[o[e][s]],o&&o[e]&&o[e][s]!==i[s]&&(t[o[e][s]]=w),s in i?t[i[s]]=e:"production"!==process.env.NODE_ENV&&console.warn(`Index not found in entity. Indexes must be top-level members of your entity.\nIndex: ${s}\nEntity: ${JSON.stringify(i,void 0,2)}`)}}(a,s.indexes,t[l],r[l],e[l][a],n[l])),n[l][a]=e[l][a]};const I=(e,t,n=[],r={},i={},o={},s={date:Date.now(),expiresAt:1/0,fetchedAt:0})=>{if(null==t)return{entities:r,indexes:i,result:e,entityMeta:o};const c=function(e){return["object","function"].includes(typeof e)?"object":typeof e}(t);if(null===e||typeof e!==c&&(void 0===t.key||void 0!==t.pk||"string"!=typeof e)){if("production"!==process.env.NODE_ENV){const n=e=>{try{return"string"!=typeof JSON.parse(e)}catch(e){return!1}};throw"string"==typeof e&&n(e)?new Error(`Normalizing a string, but this does match schema.\n\nParsing this input string as JSON worked. This likely indicates fetch function did not parse\nthe JSON. By default, this only happens if "content-type" header includes "json".\nSee https://resthooks.io/rest/api/RestEndpoint#parseResponse for more information\n\n Schema: ${JSON.stringify(t,void 0,2)}\n Input: "${e}"`):new Error(`Unexpected input given to normalize. Expected type to be "${c}", found "${null===e?"null":typeof e}".\n\n Schema: ${JSON.stringify(t,void 0,2)}\n Input: "${e}"`)}throw new Error(`Unexpected input given to normalize. Expected type to be "${c}", found "${null===e?"null":typeof e}".`)}const a=Object.assign({},r),l=Object.assign({},i),u=Object.assign({},o),h=E({},{},a,l,u,s);return{entities:a,indexes:l,result:A(e,e,void 0,t,h,{},r,n),entityMeta:u}};function C(e,t,r,i){if(function(e){return!!e&&"function"==typeof e.infer}(e)){var o;const s=e.infer(t,r,C,i);if(n(e)&&void 0!==s&&(null==(o=i[e.key])||!o[s]))return;return s}if("object"==typeof e&&e){return(Array.isArray(e)?c:h)(e,t,r,C,i)}return e}function z(e){return void 0!==e&&(!(e&&"object"==typeof e&&!Array.isArray(e))||Object.values(e).every(z))}var S={Invalid:1,InvalidIfStale:2,Valid:3};Object.hasOwn=Object.hasOwn||function(e,t){return Object.prototype.hasOwnProperty.call(e,t)};export{w as DELETED,S as ExpiryStatus,t as INVALID,y as WeakEntityMap,O as denormalize,k as denormalizeCached,C as inferResults,n as isEntity,I as normalize,z as validateInference}; | ||
class e{constructor(){this.localCache={}}getEntity(e,t,n,i){const r=t.key;r in this.localCache||(this.localCache[r]=Object.create(null));const o=this.localCache[r];return o[e]||i(o),o[e]}getResults(e,t,n){return{data:n(),paths:[]}}}const t=Symbol("INVALID");function n(e){return null!==e&&void 0!==e.pk}const i=e=>{if("production"!==process.env.NODE_ENV){if(Array.isArray(e)&&e.length>1)throw new Error(`Expected schema definition to be a single schema, but found ${e.length}.`)}return e[0]},r=e=>void 0!==e&&"symbol"!=typeof e,o=(e,t,n,r,o,s,c,a,u)=>{e=i(e);const l=(e=>Array.isArray(e)?e:Object.keys(e).map((t=>e[t])))(t);return l.map(((t,i)=>o(t,n,r,e,s,c,a,u)))},s=(e,t,n,o)=>(e=i(e),t.map?t.map((t=>o(t,e))).filter(r):t);function c(e,t,n,i){}function a(e){return!("function"!=typeof e.hasOwnProperty||!(Object.hasOwnProperty.call(e,"__ownerID")||e._map&&Object.hasOwnProperty.call(e._map,"__ownerID")))}const u=(e,t,n,i,r,o,s,c,a)=>{const u=Object.assign({},t);return Object.keys(e).forEach((n=>{const i=e[n],l=r(t[n],t,n,i,o,s,c,a);null==l?delete u[n]:u[n]=l})),u},l=(e,n,i,r)=>{if(a(n))return function(e,n,i,r){let o=!1;const s=Object.keys(e).reduce(((t,n)=>{const i=`${n}`,s=r(t.get(i),e[i]);return"symbol"==typeof s&&(o=!0),t.has(i)?t.set(i,s):t}),n);return o?t:s}(e,n,0,r);const o=Object.assign({},n);let s=!1;return Object.keys(e).forEach((t=>{const n=r(o[t],e[t]);void 0!==o[t]&&(o[t]=n),"symbol"==typeof n&&(s=!0)})),s?t:o};function h(e,t,n,i,r){const o={};for(const s of Object.keys(e))o[s]=i(e[s],t,n,r);return o}function d(e,n,i,r,o,s){const c=o[r]=a(e)?n.createIfValid(e.toObject()):n.createIfValid(e);void 0===c?o[r]=t:"function"==typeof n.denormalize&&(o[r]=n.denormalize(c,s,i))}var f=(e,i,r)=>{function o(c,u){if(!u)return c;if(null===c)return c;const h="function"==typeof u.denormalize;if(!h&&"function"==typeof u)return void 0===c?c:u(c);if(void 0===c){return"AllSchema"===u.constructor.name?t:void 0}if(!h&&"object"==typeof u){return(Array.isArray(u)?s:l)(u,c,r,o)}return n(u)?function(e,t,n,i,r,o){const s="object"==typeof e?e:r({key:t.key,pk:e});if("symbol"==typeof s&&"function"==typeof t.denormalize)return t.denormalize(s,n,i);if("object"!=typeof s||null===s)return s;const c="string"==typeof e?e:t.pk(a(s)?s.toJS():s,void 0,void 0,n);return void 0===c||""===c||"undefined"===c?function(e){const t={};return e(t),t[""]}((e=>d(s,t,i,"",e,n))):o.getEntity(c,t,s,(e=>d(s,t,i,c,e,n)))}(c,u,r,o,e,i):h?u.denormalize(c,r,o):c}return(e,t)=>{const n=Object(e)===e&&Object(t)===t;return i.getResults(e,n,(()=>o(e,t)))}};class y{constructor(){this.next=new WeakMap,this.nextPath=void 0}get(e,t){let n=this.next.get(e);if(!n)return p;for(;n.nextPath;){const e=t(n.nextPath);if(n=n.next.get(e),!n)return p}return[n.value,n.journey]}set(e,t){if(e.length<1)throw new m;let n=this;for(const{entity:t,path:i}of e){let e=n.next.get(t);e||(e=new b,n.next.set(t,e)),n.nextPath=i,n=e}n.nextPath=void 0,n.value=t,n.journey=v(e)}}const p=[void 0,void 0];function g(e){return a(e)?({key:t,pk:n})=>e.getIn([t,n]):({key:t,pk:n})=>{var i;return null==(i=e[t])?void 0:i[n]}}function v(e){var t;const n=e.map((e=>e.path));return""===(null==(t=n[0])?void 0:t.pk)&&n.shift(),n}class b{constructor(){this.next=new WeakMap,this.value=void 0,this.journey=[],this.nextPath=void 0}}class m extends Error{constructor(...e){super(...e),this.message="Keys must include at least one member"}}function O(t,n,i,r=[]){return void 0===n||void 0===t?t:f(g(i),new e,r)(t,n).data}class j{constructor(e,t,n){this.dependencies=[],this.cycleCache={},this.cycleIndex=-1,this.localCache={},this._getEntity=e,this.getCache=x(t),this.resultCache=n}getEntity(e,t,n,i){const r=t.key,{localCacheKey:o,cycleCacheKey:s}=this.getCacheKey(r);if(o[e])e in s?this.cycleIndex=s[e]:this.dependencies.push({entity:n,path:{key:r,pk:e}});else{const c=this.getCache(e,t),[a,u]=c.get(n,this._getEntity);if(u)return o[e]=a.value,this.dependencies.push(...a.dependencies),a.value;{const t=this.dependencies.length;s[e]=t,this.dependencies.push({entity:n,path:{key:r,pk:e}}),i(o),delete s[e];const a=this.dependencies.slice(-1===this.cycleIndex?t:this.cycleIndex),u={dependencies:a,value:o[e]};c.set(a,u),this.cycleIndex===t&&(this.cycleIndex=-1)}}return o[e]}getCacheKey(e){e in this.localCache||(this.localCache[e]=Object.create(null)),e in this.cycleCache||(this.cycleCache[e]=Object.create(null));return{localCacheKey:this.localCache[e],cycleCacheKey:this.cycleCache[e]}}getResults(e,t,n){if(!t)return{data:n(),paths:this.paths()};let[i,r]=this.resultCache.get(e,this._getEntity);return void 0===r&&(i=n(),r=this.paths(),this.dependencies.unshift({entity:e,path:{key:"",pk:""}}),this.resultCache.set(this.dependencies,i)),{data:i,paths:r}}paths(){return v(this.dependencies)}}const x=e=>(t,n)=>{var i;const r=n.key,o=null!=(i=n.cacheWith)?i:n;r in e||(e[r]=Object.create(null));const s=e[r];s[t]||(s[t]=new WeakMap);let c=s[t].get(o);return c||(c=new y,s[t].set(o,c)),c};function k(e,t,n,i={},r=new y,o=[]){if(void 0===t)return{data:e,paths:[]};if(void 0===e)return{data:void 0,paths:[]};const s=g(n);return f(s,new j(s,i,r),o)(e,t)}const w=(e,t,n,i,r,s,c,a)=>{if(!e||!i)return e;if(i.normalize&&"function"==typeof i.normalize)return"object"!=typeof e?e:i.normalize(e,t,n,w,r,s,c,a);if("object"!=typeof e||"object"!=typeof i)return e;return(Array.isArray(i)?o:u)(i,e,t,n,w,r,s,c,a)},C=(e,n,i,r,o,s)=>(c,a,u)=>{const l=c.key;l in e||(e[l]={},i[l]=Object.assign({},i[l]),o[l]=Object.assign({},o[l]));const h=e[l][u];if(h)e[l][u]=c.merge(h,a);else{const t=i[l][u];let n;t&&(n=o[l][u])?(e[l][u]=c.mergeWithStore(n,s,t,a),o[l][u]=c.mergeMetaWithStore(n,s,t,a)):(e[l][u]=a,o[l][u]={expiresAt:s.expiresAt,date:s.date,fetchedAt:s.fetchedAt})}c.indexes&&(l in n||(n[l]={},r[l]=Object.assign({},r[l])),function(e,n,i,r,o,s){for(const c of n){c in i||(r[c]=i[c]={});const n=i[c];s[e]&&delete n[s[e][c]],s&&s[e]&&s[e][c]!==o[c]&&(n[s[e][c]]=t),c in o?n[o[c]]=e:"production"!==process.env.NODE_ENV&&console.warn(`Index not found in entity. Indexes must be top-level members of your entity.\nIndex: ${c}\nEntity: ${JSON.stringify(o,void 0,2)}`)}}(u,c.indexes,n[l],r[l],e[l][u],i[l])),i[l][u]=e[l][u]};const E=(e,t,n=[],i={},r={},o={},s={date:Date.now(),expiresAt:1/0,fetchedAt:0})=>{if(null==t)return{entities:i,indexes:r,result:e,entityMeta:o};const c=function(e){return["object","function"].includes(typeof e)?"object":typeof e}(t);if(null===e||typeof e!==c&&(void 0===t.key||void 0!==t.pk||"string"!=typeof e)){if("production"!==process.env.NODE_ENV){const n=e=>{try{return"string"!=typeof JSON.parse(e)}catch(e){return!1}};throw"string"==typeof e&&n(e)?new Error(`Normalizing a string, but this does match schema.\n\nParsing this input string as JSON worked. This likely indicates fetch function did not parse\nthe JSON. By default, this only happens if "content-type" header includes "json".\nSee https://dataclient.io/rest/api/RestEndpoint#parseResponse for more information\n\n Schema: ${JSON.stringify(t,void 0,2)}\n Input: "${e}"`):new Error(`Unexpected input given to normalize. Expected type to be "${c}", found "${null===e?"null":typeof e}".\n\n Schema: ${JSON.stringify(t,void 0,2)}\n Input: "${e}"`)}throw new Error(`Unexpected input given to normalize. Expected type to be "${c}", found "${null===e?"null":typeof e}".`)}const a=Object.assign({},i),u=Object.assign({},r),l=Object.assign({},o),h=C({},{},a,u,l,s);return{entities:a,indexes:u,result:w(e,e,void 0,t,h,{},i,n),entityMeta:l}};function I(e,t,n,i){if(function(e){return!!e&&"function"==typeof e.infer}(e))return e.infer(t,n,I,i);if("object"==typeof e&&e){return(Array.isArray(e)?c:h)(e,t,n,I,i)}return e}function A(e){return void 0!==e&&(!(e&&"object"==typeof e&&!Array.isArray(e))||Object.values(e).every(A))}var S={Invalid:1,InvalidIfStale:2,Valid:3};Object.hasOwn=Object.hasOwn||function(e,t){return Object.prototype.hasOwnProperty.call(e,t)};export{S as ExpiryStatus,t as INVALID,y as WeakEntityMap,O as denormalize,k as denormalizeCached,I as inferResults,n as isEntity,E as normalize,A as validateInference}; |
@@ -156,9 +156,4 @@ 'use strict'; | ||
}); | ||
if (typeof entity === 'symbol') { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
return schema.denormalizeOnly(entity, args, unvisit); | ||
// TODO(breaking): Change to this as breaking change once we only support newer entities | ||
} else if (entity.toString().includes('DELETED')) { | ||
return INVALID; | ||
} | ||
if (typeof entity === 'symbol' && typeof schema.denormalize === 'function') { | ||
return schema.denormalize(entity, args, unvisit); | ||
} | ||
@@ -188,12 +183,3 @@ if (typeof entity !== 'object' || entity === null) { | ||
function unvisitEntityObject(entity, schema, unvisit, pk, localCacheKey, args) { | ||
let entityCopy, _, deleted; | ||
/* istanbul ignore else */ | ||
if (schema.createIfValid) { | ||
entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
// TODO(breaking): remove once old verions no longer supported | ||
} /* istanbul ignore next */else { | ||
entityCopy = entity; | ||
unvisit = withTrackedEntities(unvisit); | ||
unvisit.setLocal = entityCopy => localCacheKey[pk] = entityCopy; | ||
} | ||
const entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
if (entityCopy === undefined) { | ||
@@ -203,24 +189,8 @@ // undefined indicates we should suspense (perhaps failed validation) | ||
} else { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
localCacheKey[pk] = schema.denormalizeOnly(entityCopy, args, unvisit); | ||
} else { | ||
[localCacheKey[pk], _, deleted] = schema.denormalize(entityCopy, unvisit); | ||
if (deleted) localCacheKey[pk] = INVALID; | ||
if (typeof schema.denormalize === 'function') { | ||
localCacheKey[pk] = schema.denormalize(entityCopy, args, unvisit); | ||
} | ||
} | ||
} | ||
// TODO(breaking): remove once unused | ||
/* istanbul ignore next */ | ||
function withTrackedEntities(unvisit) { | ||
// every time we nest, we want to unwrap back to the top. | ||
// this is due to only needed the next level of nested entities for lookup | ||
const originalUnvisit = unvisit.og || unvisit; | ||
const wrappedUnvisit = (input, schema) => originalUnvisit(input, schema); | ||
wrappedUnvisit.og = unvisit; | ||
return wrappedUnvisit; | ||
} | ||
const getUnvisit = (getEntity, cache, args) => { | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
const unvisitAdapter = getUnvisitAdapter(unvisit); | ||
function unvisit(input, schema) { | ||
@@ -231,14 +201,11 @@ if (!schema) return input; | ||
} | ||
const hasDenormalize = typeof schema.denormalize === 'function' || typeof schema.denormalizeOnly === 'function'; | ||
const hasDenormalize = typeof schema.denormalize === 'function'; | ||
// deserialize fields (like Date) | ||
// deserialize fields (like Temporal.Instant) | ||
if (!hasDenormalize && typeof schema === 'function') { | ||
if (input instanceof schema) return input; | ||
if (input === undefined) return input; | ||
return new schema(input); | ||
return schema(input); | ||
} | ||
if (input === undefined) { | ||
var _schema$constructor; | ||
// TODO(breaking): Drop support for initial All version | ||
const isAll = ((_schema$constructor = schema.constructor) == null ? void 0 : _schema$constructor.name) === 'AllSchema'; | ||
const isAll = schema.constructor.name === 'AllSchema'; | ||
return isAll ? INVALID : undefined; | ||
@@ -251,10 +218,6 @@ } | ||
if (isEntity(schema)) { | ||
return unvisitEntity(input, schema, args, schema.denormalizeOnly ? unvisit : unvisitAdapter, getEntity, cache); | ||
return unvisitEntity(input, schema, args, unvisit, getEntity, cache); | ||
} | ||
if (hasDenormalize) { | ||
if (schema.denormalizeOnly) { | ||
return schema.denormalizeOnly(input, args, unvisit); | ||
} else { | ||
return denormalizeLegacySchema(schema, input, unvisitAdapter); | ||
} | ||
return schema.denormalize(input, args, unvisit); | ||
} | ||
@@ -271,27 +234,3 @@ return input; | ||
var getUnvisit$1 = getUnvisit; | ||
function denormalizeLegacySchema(schema, input, unvisitAdapter) { | ||
const [data, _, suspend] = schema.denormalize(input, unvisitAdapter); | ||
// TODO(breaking): Drop support for initial Query version | ||
// queryEndpoint schema only overrides 'denormalize' and 'infer' | ||
const isQuery = !Object.hasOwn(schema, 'normalize') && Object.hasOwn(schema, 'denormalize') && Object.hasOwn(schema, 'infer'); | ||
return suspend && !isQuery ? INVALID : data; | ||
} | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
function getUnvisitAdapter(unvisit) { | ||
return function (input, schema) { | ||
var _schema$constructor2; | ||
const isAll = (schema == null ? void 0 : (_schema$constructor2 = schema.constructor) == null ? void 0 : _schema$constructor2.name) === 'AllSchema'; | ||
const value = unvisit(input, schema); | ||
// TODO(breaking): Drop support for initial All version | ||
if (isAll) { | ||
// we swap 'found' and 'suspend' because the initial Query version used 'found' to determine whether | ||
// it should 'process' | ||
return [typeof value === 'symbol' ? undefined : value, typeof value !== 'symbol', false]; | ||
} | ||
return [typeof value === 'symbol' ? undefined : value, true, typeof value === 'symbol']; | ||
}; | ||
} | ||
/** Maps entity dependencies to a value (usually their denormalized form) | ||
@@ -550,4 +489,2 @@ * | ||
const DELETED = Symbol('ENTITY WAS DELETED'); | ||
const visit = (value, parent, key, schema, addEntity, visitedEntities, storeEntities, args) => { | ||
@@ -561,7 +498,2 @@ if (!value || !schema) { | ||
} | ||
// serializable | ||
if (typeof schema === 'function') { | ||
return new schema(value); | ||
} | ||
if (typeof value !== 'object' || typeof schema !== 'object') return value; | ||
@@ -590,9 +522,8 @@ const method = Array.isArray(schema) ? normalize$2 : normalize$1; | ||
if (inStoreEntity && (inStoreMeta = storeEntityMeta[schemaKey][id])) { | ||
entities[schemaKey][id] = schema.mergeWithStore ? schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore ? schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeMetaWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
entities[schemaKey][id] = schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
} else { | ||
entities[schemaKey][id] = processedEntity; | ||
storeEntityMeta[schemaKey][id] = { | ||
// TODO(breaking): Remove schema.expiresat | ||
expiresAt: schema.expiresAt ? schema.expiresAt(meta, processedEntity) : meta.expiresAt, | ||
expiresAt: meta.expiresAt, | ||
date: meta.date, | ||
@@ -628,3 +559,3 @@ fetchedAt: meta.fetchedAt | ||
if (storeEntities && storeEntities[id] && storeEntities[id][index] !== entity[index]) { | ||
indexMap[storeEntities[id][index]] = DELETED; | ||
indexMap[storeEntities[id][index]] = INVALID; | ||
} | ||
@@ -642,29 +573,2 @@ if (index in entity) { | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeStore() instead */ | ||
function mergeWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
const useIncoming = | ||
// useIncoming should not be used with legacy optimistic | ||
schema.useIncoming && incomingMeta.fetchedAt ? schema.useIncoming(existingMeta, incomingMeta, existing, incoming) : existingMeta.date <= incomingMeta.date; | ||
if (useIncoming) { | ||
if (typeof incoming !== typeof existing) { | ||
return incoming; | ||
} else { | ||
return schema.merge(existing, incoming); | ||
} | ||
} else { | ||
return existing; | ||
} | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeMetaWithStore() instead */ | ||
function mergeMetaWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
return { | ||
expiresAt: Math.max(schema.expiresAt ? schema.expiresAt(incomingMeta, incoming) : incomingMeta.expiresAt, existingMeta.expiresAt), | ||
date: Math.max(incomingMeta.date, existingMeta.date), | ||
fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt) | ||
}; | ||
} | ||
function expectedSchemaType(schema) { | ||
@@ -705,3 +609,3 @@ return ['object', 'function'].includes(typeof schema) ? 'object' : typeof schema; | ||
the JSON. By default, this only happens if "content-type" header includes "json". | ||
See https://resthooks.io/rest/api/RestEndpoint#parseResponse for more information | ||
See https://dataclient.io/rest/api/RestEndpoint#parseResponse for more information | ||
@@ -749,9 +653,3 @@ Schema: ${JSON.stringify(schema, undefined, 2)} | ||
if (canInfer(schema)) { | ||
var _entities$schema$key; | ||
const ret = schema.infer(args, indexes, inferResults, entities); | ||
// TODO(breaking): back compatibility with endpoint@3.7 and less | ||
if (isEntity(schema) && ret !== undefined && !((_entities$schema$key = entities[schema.key]) != null && _entities$schema$key[ret])) { | ||
return undefined; | ||
} | ||
return ret; | ||
return schema.infer(args, indexes, inferResults, entities); | ||
} | ||
@@ -792,3 +690,2 @@ | ||
exports.DELETED = DELETED; | ||
exports.ExpiryStatus = ExpiryStatus; | ||
@@ -795,0 +692,0 @@ exports.INVALID = INVALID; |
@@ -154,9 +154,4 @@ (function (global, factory) { | ||
}); | ||
if (typeof entity === 'symbol') { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
return schema.denormalizeOnly(entity, args, unvisit); | ||
// TODO(breaking): Change to this as breaking change once we only support newer entities | ||
} else if (entity.toString().includes('DELETED')) { | ||
return INVALID; | ||
} | ||
if (typeof entity === 'symbol' && typeof schema.denormalize === 'function') { | ||
return schema.denormalize(entity, args, unvisit); | ||
} | ||
@@ -186,12 +181,3 @@ if (typeof entity !== 'object' || entity === null) { | ||
function unvisitEntityObject(entity, schema, unvisit, pk, localCacheKey, args) { | ||
let entityCopy, _, deleted; | ||
/* istanbul ignore else */ | ||
if (schema.createIfValid) { | ||
entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
// TODO(breaking): remove once old verions no longer supported | ||
} /* istanbul ignore next */else { | ||
entityCopy = entity; | ||
unvisit = withTrackedEntities(unvisit); | ||
unvisit.setLocal = entityCopy => localCacheKey[pk] = entityCopy; | ||
} | ||
const entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
if (entityCopy === undefined) { | ||
@@ -201,24 +187,8 @@ // undefined indicates we should suspense (perhaps failed validation) | ||
} else { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
localCacheKey[pk] = schema.denormalizeOnly(entityCopy, args, unvisit); | ||
} else { | ||
[localCacheKey[pk], _, deleted] = schema.denormalize(entityCopy, unvisit); | ||
if (deleted) localCacheKey[pk] = INVALID; | ||
if (typeof schema.denormalize === 'function') { | ||
localCacheKey[pk] = schema.denormalize(entityCopy, args, unvisit); | ||
} | ||
} | ||
} | ||
// TODO(breaking): remove once unused | ||
/* istanbul ignore next */ | ||
function withTrackedEntities(unvisit) { | ||
// every time we nest, we want to unwrap back to the top. | ||
// this is due to only needed the next level of nested entities for lookup | ||
const originalUnvisit = unvisit.og || unvisit; | ||
const wrappedUnvisit = (input, schema) => originalUnvisit(input, schema); | ||
wrappedUnvisit.og = unvisit; | ||
return wrappedUnvisit; | ||
} | ||
const getUnvisit = (getEntity, cache, args) => { | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
const unvisitAdapter = getUnvisitAdapter(unvisit); | ||
function unvisit(input, schema) { | ||
@@ -229,14 +199,11 @@ if (!schema) return input; | ||
} | ||
const hasDenormalize = typeof schema.denormalize === 'function' || typeof schema.denormalizeOnly === 'function'; | ||
const hasDenormalize = typeof schema.denormalize === 'function'; | ||
// deserialize fields (like Date) | ||
// deserialize fields (like Temporal.Instant) | ||
if (!hasDenormalize && typeof schema === 'function') { | ||
if (input instanceof schema) return input; | ||
if (input === undefined) return input; | ||
return new schema(input); | ||
return schema(input); | ||
} | ||
if (input === undefined) { | ||
var _schema$constructor; | ||
// TODO(breaking): Drop support for initial All version | ||
const isAll = ((_schema$constructor = schema.constructor) == null ? void 0 : _schema$constructor.name) === 'AllSchema'; | ||
const isAll = schema.constructor.name === 'AllSchema'; | ||
return isAll ? INVALID : undefined; | ||
@@ -249,10 +216,6 @@ } | ||
if (isEntity(schema)) { | ||
return unvisitEntity(input, schema, args, schema.denormalizeOnly ? unvisit : unvisitAdapter, getEntity, cache); | ||
return unvisitEntity(input, schema, args, unvisit, getEntity, cache); | ||
} | ||
if (hasDenormalize) { | ||
if (schema.denormalizeOnly) { | ||
return schema.denormalizeOnly(input, args, unvisit); | ||
} else { | ||
return denormalizeLegacySchema(schema, input, unvisitAdapter); | ||
} | ||
return schema.denormalize(input, args, unvisit); | ||
} | ||
@@ -269,27 +232,3 @@ return input; | ||
var getUnvisit$1 = getUnvisit; | ||
function denormalizeLegacySchema(schema, input, unvisitAdapter) { | ||
const [data, _, suspend] = schema.denormalize(input, unvisitAdapter); | ||
// TODO(breaking): Drop support for initial Query version | ||
// queryEndpoint schema only overrides 'denormalize' and 'infer' | ||
const isQuery = !Object.hasOwn(schema, 'normalize') && Object.hasOwn(schema, 'denormalize') && Object.hasOwn(schema, 'infer'); | ||
return suspend && !isQuery ? INVALID : data; | ||
} | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
function getUnvisitAdapter(unvisit) { | ||
return function (input, schema) { | ||
var _schema$constructor2; | ||
const isAll = (schema == null ? void 0 : (_schema$constructor2 = schema.constructor) == null ? void 0 : _schema$constructor2.name) === 'AllSchema'; | ||
const value = unvisit(input, schema); | ||
// TODO(breaking): Drop support for initial All version | ||
if (isAll) { | ||
// we swap 'found' and 'suspend' because the initial Query version used 'found' to determine whether | ||
// it should 'process' | ||
return [typeof value === 'symbol' ? undefined : value, typeof value !== 'symbol', false]; | ||
} | ||
return [typeof value === 'symbol' ? undefined : value, true, typeof value === 'symbol']; | ||
}; | ||
} | ||
/** Maps entity dependencies to a value (usually their denormalized form) | ||
@@ -548,5 +487,2 @@ * | ||
const DELETED = Symbol('ENTITY WAS DELETED'); | ||
var _s = $RefreshSig$(); | ||
const visit = (value, parent, key, schema, addEntity, visitedEntities, storeEntities, args) => { | ||
@@ -560,7 +496,2 @@ if (!value || !schema) { | ||
} | ||
// serializable | ||
if (typeof schema === 'function') { | ||
return new schema(value); | ||
} | ||
if (typeof value !== 'object' || typeof schema !== 'object') return value; | ||
@@ -585,9 +516,8 @@ const method = Array.isArray(schema) ? normalize$2 : normalize$1; | ||
if (inStoreEntity && (inStoreMeta = storeEntityMeta[schemaKey][id])) { | ||
entities[schemaKey][id] = schema.mergeWithStore ? schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore ? schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeMetaWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
entities[schemaKey][id] = schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
} else { | ||
entities[schemaKey][id] = processedEntity; | ||
storeEntityMeta[schemaKey][id] = { | ||
// TODO(breaking): Remove schema.expiresat | ||
expiresAt: schema.expiresAt ? schema.expiresAt(meta, processedEntity) : meta.expiresAt, | ||
expiresAt: meta.expiresAt, | ||
date: meta.date, | ||
@@ -621,3 +551,3 @@ fetchedAt: meta.fetchedAt | ||
if (storeEntities && storeEntities[id] && storeEntities[id][index] !== entity[index]) { | ||
indexMap[storeEntities[id][index]] = DELETED; | ||
indexMap[storeEntities[id][index]] = INVALID; | ||
} | ||
@@ -635,33 +565,2 @@ if (index in entity) { | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeStore() instead */ | ||
function mergeWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
_s(); | ||
const useIncoming = | ||
// useIncoming should not be used with legacy optimistic | ||
schema.useIncoming && incomingMeta.fetchedAt ? schema.useIncoming(existingMeta, incomingMeta, existing, incoming) : existingMeta.date <= incomingMeta.date; | ||
if (useIncoming) { | ||
if (typeof incoming !== typeof existing) { | ||
return incoming; | ||
} else { | ||
return schema.merge(existing, incoming); | ||
} | ||
} else { | ||
return existing; | ||
} | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeMetaWithStore() instead */ | ||
_s(mergeWithStore, "RSHyr3aBwsmLX8s7SwDQGEQTEhQ=", false, function () { | ||
return [schema.useIncoming]; | ||
}); | ||
function mergeMetaWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
return { | ||
expiresAt: Math.max(schema.expiresAt ? schema.expiresAt(incomingMeta, incoming) : incomingMeta.expiresAt, existingMeta.expiresAt), | ||
date: Math.max(incomingMeta.date, existingMeta.date), | ||
fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt) | ||
}; | ||
} | ||
function expectedSchemaType(schema) { | ||
@@ -702,3 +601,3 @@ return ['object', 'function'].includes(typeof schema) ? 'object' : typeof schema; | ||
the JSON. By default, this only happens if "content-type" header includes "json". | ||
See https://resthooks.io/rest/api/RestEndpoint#parseResponse for more information | ||
See https://dataclient.io/rest/api/RestEndpoint#parseResponse for more information | ||
@@ -740,9 +639,3 @@ Schema: ${JSON.stringify(schema, undefined, 2)} | ||
if (canInfer(schema)) { | ||
var _entities$schema$key; | ||
const ret = schema.infer(args, indexes, inferResults, entities); | ||
// TODO(breaking): back compatibility with endpoint@3.7 and less | ||
if (isEntity(schema) && ret !== undefined && !((_entities$schema$key = entities[schema.key]) != null && _entities$schema$key[ret])) { | ||
return undefined; | ||
} | ||
return ret; | ||
return schema.infer(args, indexes, inferResults, entities); | ||
} | ||
@@ -783,3 +676,2 @@ | ||
exports.DELETED = DELETED; | ||
exports.ExpiryStatus = ExpiryStatus; | ||
@@ -786,0 +678,0 @@ exports.INVALID = INVALID; |
@@ -11,9 +11,4 @@ import { INVALID } from './symbol.js'; | ||
}); | ||
if (typeof entity === 'symbol') { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
return schema.denormalizeOnly(entity, args, unvisit); | ||
// TODO(breaking): Change to this as breaking change once we only support newer entities | ||
} else if (entity.toString().includes('DELETED')) { | ||
return INVALID; | ||
} | ||
if (typeof entity === 'symbol' && typeof schema.denormalize === 'function') { | ||
return schema.denormalize(entity, args, unvisit); | ||
} | ||
@@ -43,12 +38,4 @@ if (typeof entity !== 'object' || entity === null) { | ||
function unvisitEntityObject(entity, schema, unvisit, pk, localCacheKey, args) { | ||
let entityCopy, _, deleted; | ||
/* istanbul ignore else */ | ||
if (schema.createIfValid) { | ||
entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
// TODO(breaking): remove once old verions no longer supported | ||
} /* istanbul ignore next */else { | ||
entityCopy = entity; | ||
unvisit = withTrackedEntities(unvisit); | ||
unvisit.setLocal = entityCopy => localCacheKey[pk] = entityCopy; | ||
} | ||
let _, deleted; | ||
const entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
if (entityCopy === undefined) { | ||
@@ -58,24 +45,8 @@ // undefined indicates we should suspense (perhaps failed validation) | ||
} else { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
localCacheKey[pk] = schema.denormalizeOnly(entityCopy, args, unvisit); | ||
} else { | ||
[localCacheKey[pk], _, deleted] = schema.denormalize(entityCopy, unvisit); | ||
if (deleted) localCacheKey[pk] = INVALID; | ||
if (typeof schema.denormalize === 'function') { | ||
localCacheKey[pk] = schema.denormalize(entityCopy, args, unvisit); | ||
} | ||
} | ||
} | ||
// TODO(breaking): remove once unused | ||
/* istanbul ignore next */ | ||
function withTrackedEntities(unvisit) { | ||
// every time we nest, we want to unwrap back to the top. | ||
// this is due to only needed the next level of nested entities for lookup | ||
const originalUnvisit = unvisit.og || unvisit; | ||
const wrappedUnvisit = (input, schema) => originalUnvisit(input, schema); | ||
wrappedUnvisit.og = unvisit; | ||
return wrappedUnvisit; | ||
} | ||
const getUnvisit = (getEntity, cache, args) => { | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
const unvisitAdapter = getUnvisitAdapter(unvisit); | ||
function unvisit(input, schema) { | ||
@@ -86,14 +57,11 @@ if (!schema) return input; | ||
} | ||
const hasDenormalize = typeof schema.denormalize === 'function' || typeof schema.denormalizeOnly === 'function'; | ||
const hasDenormalize = typeof schema.denormalize === 'function'; | ||
// deserialize fields (like Date) | ||
// deserialize fields (like Temporal.Instant) | ||
if (!hasDenormalize && typeof schema === 'function') { | ||
if (input instanceof schema) return input; | ||
if (input === undefined) return input; | ||
return new schema(input); | ||
return schema(input); | ||
} | ||
if (input === undefined) { | ||
var _schema$constructor; | ||
// TODO(breaking): Drop support for initial All version | ||
const isAll = ((_schema$constructor = schema.constructor) == null ? void 0 : _schema$constructor.name) === 'AllSchema'; | ||
const isAll = schema.constructor.name === 'AllSchema'; | ||
return isAll ? INVALID : undefined; | ||
@@ -106,10 +74,6 @@ } | ||
if (isEntity(schema)) { | ||
return unvisitEntity(input, schema, args, schema.denormalizeOnly ? unvisit : unvisitAdapter, getEntity, cache); | ||
return unvisitEntity(input, schema, args, unvisit, getEntity, cache); | ||
} | ||
if (hasDenormalize) { | ||
if (schema.denormalizeOnly) { | ||
return schema.denormalizeOnly(input, args, unvisit); | ||
} else { | ||
return denormalizeLegacySchema(schema, input, unvisitAdapter); | ||
} | ||
return schema.denormalize(input, args, unvisit); | ||
} | ||
@@ -126,26 +90,2 @@ return input; | ||
export default getUnvisit; | ||
function denormalizeLegacySchema(schema, input, unvisitAdapter) { | ||
const [data, _, suspend] = schema.denormalize(input, unvisitAdapter); | ||
// TODO(breaking): Drop support for initial Query version | ||
// queryEndpoint schema only overrides 'denormalize' and 'infer' | ||
const isQuery = !Object.hasOwn(schema, 'normalize') && Object.hasOwn(schema, 'denormalize') && Object.hasOwn(schema, 'infer'); | ||
return suspend && !isQuery ? INVALID : data; | ||
} | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
function getUnvisitAdapter(unvisit) { | ||
return function (input, schema) { | ||
var _schema$constructor2; | ||
const isAll = (schema == null ? void 0 : (_schema$constructor2 = schema.constructor) == null ? void 0 : _schema$constructor2.name) === 'AllSchema'; | ||
const value = unvisit(input, schema); | ||
// TODO(breaking): Drop support for initial All version | ||
if (isAll) { | ||
// we swap 'found' and 'suspend' because the initial Query version used 'found' to determine whether | ||
// it should 'process' | ||
return [typeof value === 'symbol' ? undefined : value, typeof value !== 'symbol', false]; | ||
} | ||
return [typeof value === 'symbol' ? undefined : value, true, typeof value === 'symbol']; | ||
}; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["INVALID","isEntity","denormalize","arrayDenormalize","isImmutable","objectDenormalize","unvisitEntity","entityOrId","schema","args","unvisit","getEntity","cache","entity","key","pk","denormalizeOnly","toString","includes","toJS","undefined","noCacheGetEntity","localCacheKey","unvisitEntityObject","computeValue","entityCopy","_","deleted","createIfValid","toObject","withTrackedEntities","setLocal","originalUnvisit","og","wrappedUnvisit","input","getUnvisit","unvisitAdapter","getUnvisitAdapter","hasDenormalize","_schema$constructor","isAll","constructor","name","method","Array","isArray","denormalizeLegacySchema","cachable","Object","getResults","data","suspend","isQuery","hasOwn","_schema$constructor2","value"],"sources":["../../src/denormalize/unvisit.ts"],"sourcesContent":["import type Cache from './cache.js';\nimport { INVALID } from './symbol.js';\nimport type { EntityInterface, UnvisitFunction } from '../interface.js';\nimport { isEntity } from '../isEntity.js';\nimport { denormalize as arrayDenormalize } from '../schemas/Array.js';\nimport { isImmutable } from '../schemas/ImmutableUtils.js';\nimport { denormalize as objectDenormalize } from '../schemas/Object.js';\nimport type { Path } from '../types.js';\nimport { type GetEntity } from '../WeakEntityMap.js';\n\nfunction unvisitEntity(\n  entityOrId: Record<string, any> | string,\n  schema: EntityInterface,\n  args: readonly any[],\n  unvisit: UnvisitFunction,\n  getEntity: GetEntity,\n  cache: Cache,\n): object | undefined | symbol {\n  const entity =\n    typeof entityOrId === 'object'\n      ? entityOrId\n      : getEntity({ key: schema.key, pk: entityOrId });\n  if (typeof entity === 'symbol') {\n    if (typeof schema.denormalizeOnly === 'function') {\n      return schema.denormalizeOnly(entity, args, unvisit);\n      // TODO(breaking): Change to this as breaking change once we only support newer entities\n    } else if ((entity as symbol).toString().includes('DELETED')) {\n      return INVALID;\n    }\n  }\n\n  if (typeof entity !== 'object' || entity === null) {\n    return entity as any;\n  }\n\n  const pk =\n    // normalize must always place a string, because pk() return value is string | undefined\n    // therefore no need to check for numbers\n    typeof entityOrId === 'string'\n      ? entityOrId\n      : schema.pk(\n          isImmutable(entity) ? (entity as any).toJS() : entity,\n          undefined,\n          undefined,\n          args,\n        );\n\n  // if we can't generate a working pk we cannot do cache lookups properly,\n  // so simply denormalize without caching\n  if (pk === undefined || pk === '' || pk === 'undefined') {\n    return noCacheGetEntity(localCacheKey =>\n      unvisitEntityObject(entity, schema, unvisit, '', localCacheKey, args),\n    );\n  }\n\n  // last function computes if it is not in any caches\n  return cache.getEntity(pk, schema, entity, localCacheKey =>\n    unvisitEntityObject(entity, schema, unvisit, pk, localCacheKey, args),\n  );\n}\n\nfunction noCacheGetEntity(\n  computeValue: (localCacheKey: Record<string, any>) => void,\n): object | undefined | symbol {\n  const localCacheKey = {};\n  computeValue(localCacheKey);\n\n  return localCacheKey[''];\n}\n\nfunction unvisitEntityObject(\n  entity: object,\n  schema: EntityInterface<any>,\n  unvisit: UnvisitFunction,\n  pk: string,\n  localCacheKey: Record<string, any>,\n  args: readonly any[],\n): void {\n  let entityCopy: any, _, deleted;\n  /* istanbul ignore else */\n  if (schema.createIfValid) {\n    entityCopy = localCacheKey[pk] = isImmutable(entity)\n      ? schema.createIfValid(entity.toObject())\n      : schema.createIfValid(entity);\n    // TODO(breaking): remove once old verions no longer supported\n  } /* istanbul ignore next */ else {\n    entityCopy = entity;\n    unvisit = withTrackedEntities(unvisit);\n    unvisit.setLocal = entityCopy => (localCacheKey[pk] = entityCopy);\n  }\n\n  if (entityCopy === undefined) {\n    // undefined indicates we should suspense (perhaps failed validation)\n    localCacheKey[pk] = INVALID;\n  } else {\n    if (typeof schema.denormalizeOnly === 'function') {\n      localCacheKey[pk] = schema.denormalizeOnly(entityCopy, args, unvisit);\n    } else {\n      [localCacheKey[pk], _, deleted] = (schema as any).denormalize(\n        entityCopy,\n        unvisit,\n      );\n      if (deleted) localCacheKey[pk] = INVALID;\n    }\n  }\n}\n\n// TODO(breaking): remove once unused\n/* istanbul ignore next */\nfunction withTrackedEntities(unvisit: UnvisitFunction): UnvisitFunction {\n  // every time we nest, we want to unwrap back to the top.\n  // this is due to only needed the next level of nested entities for lookup\n  const originalUnvisit = unvisit.og || unvisit;\n  const wrappedUnvisit = (input: any, schema: any) =>\n    originalUnvisit(input, schema);\n  wrappedUnvisit.og = unvisit;\n  return wrappedUnvisit;\n}\n\nconst getUnvisit = (\n  getEntity: GetEntity,\n  cache: Cache,\n  args: readonly any[],\n) => {\n  // TODO(breaking): This handles legacy schemas from 3.7 and below\n  const unvisitAdapter = getUnvisitAdapter(unvisit);\n\n  function unvisit(input: any, schema: any): any {\n    if (!schema) return input;\n\n    if (input === null) {\n      return input;\n    }\n\n    const hasDenormalize =\n      typeof schema.denormalize === 'function' ||\n      typeof schema.denormalizeOnly === 'function';\n\n    // deserialize fields (like Date)\n    if (!hasDenormalize && typeof schema === 'function') {\n      if (input instanceof schema) return input;\n      if (input === undefined) return input;\n      return new schema(input);\n    }\n\n    if (input === undefined) {\n      // TODO(breaking): Drop support for initial All version\n      const isAll = schema.constructor?.name === 'AllSchema';\n\n      return isAll ? INVALID : undefined;\n    }\n\n    if (!hasDenormalize && typeof schema === 'object') {\n      const method = Array.isArray(schema)\n        ? arrayDenormalize\n        : objectDenormalize;\n      return method(schema, input, args, unvisit);\n    }\n\n    if (isEntity(schema)) {\n      return unvisitEntity(\n        input,\n        schema,\n        args,\n        schema.denormalizeOnly ? unvisit : unvisitAdapter,\n        getEntity,\n        cache,\n      );\n    }\n\n    if (hasDenormalize) {\n      if (schema.denormalizeOnly) {\n        return schema.denormalizeOnly(input, args, unvisit);\n      } else {\n        return denormalizeLegacySchema(schema, input, unvisitAdapter);\n      }\n    }\n\n    return input;\n  }\n\n  return (input: any, schema: any): { data: any; paths: Path[] } => {\n    // in the case where WeakMap cannot be used\n    // this test ensures null is properly excluded from WeakMap\n    const cachable = Object(input) === input && Object(schema) === schema;\n    return cache.getResults(input, cachable, () => unvisit(input, schema));\n  };\n};\nexport default getUnvisit;\n\nfunction denormalizeLegacySchema(\n  schema: any,\n  input: any,\n  unvisitAdapter: (input: any, schema: any) => [any, boolean, boolean],\n) {\n  const [data, _, suspend] = schema.denormalize(input, unvisitAdapter);\n  // TODO(breaking): Drop support for initial Query version\n  // queryEndpoint schema only overrides 'denormalize' and 'infer'\n  const isQuery =\n    !Object.hasOwn(schema, 'normalize') &&\n    Object.hasOwn(schema, 'denormalize') &&\n    Object.hasOwn(schema, 'infer');\n  return suspend && !isQuery ? INVALID : data;\n}\n\n// TODO(breaking): This handles legacy schemas from 3.7 and below\nfunction getUnvisitAdapter(unvisit) {\n  return function (input: any, schema: any): [any, boolean, boolean] {\n    const isAll = schema?.constructor?.name === 'AllSchema';\n    const value = unvisit(input, schema);\n\n    // TODO(breaking): Drop support for initial All version\n    if (isAll) {\n      // we swap 'found' and 'suspend' because the initial Query version used 'found' to determine whether\n      // it should 'process'\n      return [\n        typeof value === 'symbol' ? undefined : value,\n        typeof value !== 'symbol',\n        false,\n      ];\n    }\n    return [\n      typeof value === 'symbol' ? undefined : value,\n      true,\n      typeof value === 'symbol',\n    ];\n  };\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["INVALID","isEntity","denormalize","arrayDenormalize","isImmutable","objectDenormalize","unvisitEntity","entityOrId","schema","args","unvisit","getEntity","cache","entity","key","pk","toJS","undefined","noCacheGetEntity","localCacheKey","unvisitEntityObject","computeValue","_","deleted","entityCopy","createIfValid","toObject","getUnvisit","input","hasDenormalize","isAll","constructor","name","method","Array","isArray","cachable","Object","getResults"],"sources":["../../src/denormalize/unvisit.ts"],"sourcesContent":["import type Cache from './cache.js';\nimport { INVALID } from './symbol.js';\nimport type { EntityInterface } from '../interface.js';\nimport { isEntity } from '../isEntity.js';\nimport { denormalize as arrayDenormalize } from '../schemas/Array.js';\nimport { isImmutable } from '../schemas/ImmutableUtils.js';\nimport { denormalize as objectDenormalize } from '../schemas/Object.js';\nimport type { Path } from '../types.js';\nimport { type GetEntity } from '../WeakEntityMap.js';\n\nfunction unvisitEntity(\n  entityOrId: Record<string, any> | string,\n  schema: EntityInterface,\n  args: readonly any[],\n  unvisit: (input: any, schema: any) => any,\n  getEntity: GetEntity,\n  cache: Cache,\n): object | undefined | symbol {\n  const entity =\n    typeof entityOrId === 'object'\n      ? entityOrId\n      : getEntity({ key: schema.key, pk: entityOrId });\n  if (typeof entity === 'symbol' && typeof schema.denormalize === 'function') {\n    return schema.denormalize(entity, args, unvisit);\n  }\n\n  if (typeof entity !== 'object' || entity === null) {\n    return entity as any;\n  }\n\n  const pk =\n    // normalize must always place a string, because pk() return value is string | undefined\n    // therefore no need to check for numbers\n    typeof entityOrId === 'string'\n      ? entityOrId\n      : schema.pk(\n          isImmutable(entity) ? (entity as any).toJS() : entity,\n          undefined,\n          undefined,\n          args,\n        );\n\n  // if we can't generate a working pk we cannot do cache lookups properly,\n  // so simply denormalize without caching\n  if (pk === undefined || pk === '' || pk === 'undefined') {\n    return noCacheGetEntity(localCacheKey =>\n      unvisitEntityObject(entity, schema, unvisit, '', localCacheKey, args),\n    );\n  }\n\n  // last function computes if it is not in any caches\n  return cache.getEntity(pk, schema, entity, localCacheKey =>\n    unvisitEntityObject(entity, schema, unvisit, pk, localCacheKey, args),\n  );\n}\n\nfunction noCacheGetEntity(\n  computeValue: (localCacheKey: Record<string, any>) => void,\n): object | undefined | symbol {\n  const localCacheKey = {};\n  computeValue(localCacheKey);\n\n  return localCacheKey[''];\n}\n\nfunction unvisitEntityObject(\n  entity: object,\n  schema: EntityInterface<any>,\n  unvisit: (input: any, schema: any) => any,\n  pk: string,\n  localCacheKey: Record<string, any>,\n  args: readonly any[],\n): void {\n  let _, deleted;\n  const entityCopy = (localCacheKey[pk] = isImmutable(entity)\n    ? schema.createIfValid(entity.toObject())\n    : schema.createIfValid(entity));\n\n  if (entityCopy === undefined) {\n    // undefined indicates we should suspense (perhaps failed validation)\n    localCacheKey[pk] = INVALID;\n  } else {\n    if (typeof schema.denormalize === 'function') {\n      localCacheKey[pk] = schema.denormalize(entityCopy, args, unvisit);\n    }\n  }\n}\n\nconst getUnvisit = (\n  getEntity: GetEntity,\n  cache: Cache,\n  args: readonly any[],\n) => {\n  function unvisit(input: any, schema: any): any {\n    if (!schema) return input;\n\n    if (input === null) {\n      return input;\n    }\n\n    const hasDenormalize = typeof schema.denormalize === 'function';\n\n    // deserialize fields (like Temporal.Instant)\n    if (!hasDenormalize && typeof schema === 'function') {\n      if (input === undefined) return input;\n      return schema(input);\n    }\n\n    if (input === undefined) {\n      const isAll = schema.constructor.name === 'AllSchema';\n\n      return isAll ? INVALID : undefined;\n    }\n\n    if (!hasDenormalize && typeof schema === 'object') {\n      const method = Array.isArray(schema)\n        ? arrayDenormalize\n        : objectDenormalize;\n      return method(schema, input, args, unvisit);\n    }\n\n    if (isEntity(schema)) {\n      return unvisitEntity(input, schema, args, unvisit, getEntity, cache);\n    }\n\n    if (hasDenormalize) {\n      return schema.denormalize(input, args, unvisit);\n    }\n\n    return input;\n  }\n\n  return (input: any, schema: any): { data: any; paths: Path[] } => {\n    // in the case where WeakMap cannot be used\n    // this test ensures null is properly excluded from WeakMap\n    const cachable = Object(input) === input && Object(schema) === schema;\n    return cache.getResults(input, cachable, () => unvisit(input, schema));\n  };\n};\nexport default getUnvisit;\n"],"mappings":"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"} |
@@ -10,9 +10,7 @@ Object.hasOwn = Object.hasOwn || /* istanbul ignore next */function hasOwn(it, key) { | ||
export { default as inferResults, validateInference } from './inferResults.js'; | ||
export { DELETED } from './special.js'; | ||
export * from './endpoint/types.js'; | ||
export * from './interface.js'; | ||
export * from './Expiry.js'; | ||
export * from './normal.js'; | ||
export { INVALID } from './denormalize/symbol.js'; | ||
export { denormalize, denormalizeCached, normalize, isEntity, WeakEntityMap }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPYmplY3QiLCJoYXNPd24iLCJpdCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImRlbm9ybWFsaXplIiwiZGVub3JtYWxpemVDYWNoZWQiLCJpc0VudGl0eSIsIm5vcm1hbGl6ZSIsIldlYWtFbnRpdHlNYXAiLCJkZWZhdWx0IiwiaW5mZXJSZXN1bHRzIiwidmFsaWRhdGVJbmZlcmVuY2UiLCJERUxFVEVEIiwiSU5WQUxJRCJdLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuaGFzT3duID1cbiAgT2JqZWN0Lmhhc093biB8fFxuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqLyBmdW5jdGlvbiBoYXNPd24oaXQsIGtleSkge1xuICAgIHJldHVybiBPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoaXQsIGtleSk7XG4gIH07XG5pbXBvcnQgeyBkZW5vcm1hbGl6ZSB9IGZyb20gJy4vZGVub3JtYWxpemUvZGVub3JtYWxpemUuanMnO1xuaW1wb3J0IHsgZGVub3JtYWxpemUgYXMgZGVub3JtYWxpemVDYWNoZWQgfSBmcm9tICcuL2Rlbm9ybWFsaXplL2Rlbm9ybWFsaXplQ2FjaGVkLmpzJztcbmltcG9ydCB7IGlzRW50aXR5IH0gZnJvbSAnLi9pc0VudGl0eS5qcyc7XG5pbXBvcnQgeyBub3JtYWxpemUgfSBmcm9tICcuL25vcm1hbGl6ZS5qcyc7XG5pbXBvcnQgV2Vha0VudGl0eU1hcCBmcm9tICcuL1dlYWtFbnRpdHlNYXAuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBpbmZlclJlc3VsdHMsIHZhbGlkYXRlSW5mZXJlbmNlIH0gZnJvbSAnLi9pbmZlclJlc3VsdHMuanMnO1xuZXhwb3J0IHsgREVMRVRFRCB9IGZyb20gJy4vc3BlY2lhbC5qcyc7XG5cbmV4cG9ydCB0eXBlIHtcbiAgQWJzdHJhY3RJbnN0YW5jZVR5cGUsXG4gIE5vcm1hbGl6ZVJldHVyblR5cGUsXG4gIE5vcm1hbGl6ZWRTY2hlbWEsXG4gIERlbm9ybWFsaXplUmV0dXJuVHlwZSxcbiAgRGVub3JtYWxpemVDYWNoZSxcbiAgUGF0aCxcbn0gZnJvbSAnLi90eXBlcy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2VuZHBvaW50L3R5cGVzLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vRXhwaXJ5LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vbm9ybWFsLmpzJztcbmV4cG9ydCB7IElOVkFMSUQgfSBmcm9tICcuL2Rlbm9ybWFsaXplL3N5bWJvbC5qcyc7XG5cbmV4cG9ydCB7IGRlbm9ybWFsaXplLCBkZW5vcm1hbGl6ZUNhY2hlZCwgbm9ybWFsaXplLCBpc0VudGl0eSwgV2Vha0VudGl0eU1hcCB9O1xuIl0sIm1hcHBpbmdzIjoiQUFBQUEsTUFBTSxDQUFDQyxNQUFNLEdBQ1hELE1BQU0sQ0FBQ0MsTUFBTSxJQUNiLDBCQUEyQixTQUFTQSxNQUFNQSxDQUFDQyxFQUFFLEVBQUVDLEdBQUcsRUFBRTtFQUNsRCxPQUFPSCxNQUFNLENBQUNJLFNBQVMsQ0FBQ0MsY0FBYyxDQUFDQyxJQUFJLENBQUNKLEVBQUUsRUFBRUMsR0FBRyxDQUFDO0FBQ3RELENBQUM7QUFDSCxTQUFTSSxXQUFXLFFBQVEsOEJBQThCO0FBQzFELFNBQVNBLFdBQVcsSUFBSUMsaUJBQWlCLFFBQVEsb0NBQW9DO0FBQ3JGLFNBQVNDLFFBQVEsUUFBUSxlQUFlO0FBQ3hDLFNBQVNDLFNBQVMsUUFBUSxnQkFBZ0I7QUFDMUMsT0FBT0MsYUFBYSxNQUFNLG9CQUFvQjtBQUM5QyxTQUFTQyxPQUFPLElBQUlDLFlBQVksRUFBRUMsaUJBQWlCLFFBQVEsbUJBQW1CO0FBQzlFLFNBQVNDLE9BQU8sUUFBUSxjQUFjO0FBVXRDLGNBQWMscUJBQXFCO0FBQ25DLGNBQWMsZ0JBQWdCO0FBQzlCLGNBQWMsYUFBYTtBQUMzQixjQUFjLGFBQWE7QUFDM0IsU0FBU0MsT0FBTyxRQUFRLHlCQUF5QjtBQUVqRCxTQUFTVCxXQUFXLEVBQUVDLGlCQUFpQixFQUFFRSxTQUFTLEVBQUVELFFBQVEsRUFBRUUsYUFBYSJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPYmplY3QiLCJoYXNPd24iLCJpdCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImRlbm9ybWFsaXplIiwiZGVub3JtYWxpemVDYWNoZWQiLCJpc0VudGl0eSIsIm5vcm1hbGl6ZSIsIldlYWtFbnRpdHlNYXAiLCJkZWZhdWx0IiwiaW5mZXJSZXN1bHRzIiwidmFsaWRhdGVJbmZlcmVuY2UiLCJJTlZBTElEIl0sInNvdXJjZXMiOlsiLi4vc3JjL2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5oYXNPd24gPVxuICBPYmplY3QuaGFzT3duIHx8XG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovIGZ1bmN0aW9uIGhhc093bihpdCwga2V5KSB7XG4gICAgcmV0dXJuIE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChpdCwga2V5KTtcbiAgfTtcbmltcG9ydCB7IGRlbm9ybWFsaXplIH0gZnJvbSAnLi9kZW5vcm1hbGl6ZS9kZW5vcm1hbGl6ZS5qcyc7XG5pbXBvcnQgeyBkZW5vcm1hbGl6ZSBhcyBkZW5vcm1hbGl6ZUNhY2hlZCB9IGZyb20gJy4vZGVub3JtYWxpemUvZGVub3JtYWxpemVDYWNoZWQuanMnO1xuaW1wb3J0IHsgaXNFbnRpdHkgfSBmcm9tICcuL2lzRW50aXR5LmpzJztcbmltcG9ydCB7IG5vcm1hbGl6ZSB9IGZyb20gJy4vbm9ybWFsaXplLmpzJztcbmltcG9ydCBXZWFrRW50aXR5TWFwIGZyb20gJy4vV2Vha0VudGl0eU1hcC5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIGluZmVyUmVzdWx0cywgdmFsaWRhdGVJbmZlcmVuY2UgfSBmcm9tICcuL2luZmVyUmVzdWx0cy5qcyc7XG5cbmV4cG9ydCB0eXBlIHtcbiAgQWJzdHJhY3RJbnN0YW5jZVR5cGUsXG4gIE5vcm1hbGl6ZVJldHVyblR5cGUsXG4gIE5vcm1hbGl6ZWRTY2hlbWEsXG4gIERlbm9ybWFsaXplQ2FjaGUsXG4gIFBhdGgsXG4gIERlbm9ybWFsaXplLFxuICBEZW5vcm1hbGl6ZU51bGxhYmxlLFxuICBOb3JtYWxpemUsXG4gIE5vcm1hbGl6ZU51bGxhYmxlLFxufSBmcm9tICcuL3R5cGVzLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vZW5kcG9pbnQvdHlwZXMuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnRlcmZhY2UuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9FeHBpcnkuanMnO1xuZXhwb3J0IHsgSU5WQUxJRCB9IGZyb20gJy4vZGVub3JtYWxpemUvc3ltYm9sLmpzJztcblxuZXhwb3J0IHsgZGVub3JtYWxpemUsIGRlbm9ybWFsaXplQ2FjaGVkLCBub3JtYWxpemUsIGlzRW50aXR5LCBXZWFrRW50aXR5TWFwIH07XG4iXSwibWFwcGluZ3MiOiJBQUFBQSxNQUFNLENBQUNDLE1BQU0sR0FDWEQsTUFBTSxDQUFDQyxNQUFNLElBQ2IsMEJBQTJCLFNBQVNBLE1BQU1BLENBQUNDLEVBQUUsRUFBRUMsR0FBRyxFQUFFO0VBQ2xELE9BQU9ILE1BQU0sQ0FBQ0ksU0FBUyxDQUFDQyxjQUFjLENBQUNDLElBQUksQ0FBQ0osRUFBRSxFQUFFQyxHQUFHLENBQUM7QUFDdEQsQ0FBQztBQUNILFNBQVNJLFdBQVcsUUFBUSw4QkFBOEI7QUFDMUQsU0FBU0EsV0FBVyxJQUFJQyxpQkFBaUIsUUFBUSxvQ0FBb0M7QUFDckYsU0FBU0MsUUFBUSxRQUFRLGVBQWU7QUFDeEMsU0FBU0MsU0FBUyxRQUFRLGdCQUFnQjtBQUMxQyxPQUFPQyxhQUFhLE1BQU0sb0JBQW9CO0FBQzlDLFNBQVNDLE9BQU8sSUFBSUMsWUFBWSxFQUFFQyxpQkFBaUIsUUFBUSxtQkFBbUI7QUFhOUUsY0FBYyxxQkFBcUI7QUFDbkMsY0FBYyxnQkFBZ0I7QUFDOUIsY0FBYyxhQUFhO0FBQzNCLFNBQVNDLE9BQU8sUUFBUSx5QkFBeUI7QUFFakQsU0FBU1IsV0FBVyxFQUFFQyxpQkFBaUIsRUFBRUUsU0FBUyxFQUFFRCxRQUFRLEVBQUVFLGFBQWEifQ== |
@@ -1,2 +0,1 @@ | ||
import { isEntity } from './isEntity.js'; | ||
import { infer as arrayInfer } from './schemas/Array.js'; | ||
@@ -11,9 +10,3 @@ import { infer as objectInfer } from './schemas/Object.js'; | ||
if (canInfer(schema)) { | ||
var _entities$schema$key; | ||
const ret = schema.infer(args, indexes, inferResults, entities); | ||
// TODO(breaking): back compatibility with endpoint@3.7 and less | ||
if (isEntity(schema) && ret !== undefined && !((_entities$schema$key = entities[schema.key]) != null && _entities$schema$key[ret])) { | ||
return undefined; | ||
} | ||
return ret; | ||
return schema.infer(args, indexes, inferResults, entities); | ||
} | ||
@@ -42,2 +35,2 @@ | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpc0VudGl0eSIsImluZmVyIiwiYXJyYXlJbmZlciIsIm9iamVjdEluZmVyIiwiaW5mZXJSZXN1bHRzIiwic2NoZW1hIiwiYXJncyIsImluZGV4ZXMiLCJlbnRpdGllcyIsImNhbkluZmVyIiwiX2VudGl0aWVzJHNjaGVtYSRrZXkiLCJyZXQiLCJ1bmRlZmluZWQiLCJrZXkiLCJtZXRob2QiLCJBcnJheSIsImlzQXJyYXkiLCJ2YWxpZGF0ZUluZmVyZW5jZSIsInJlc3VsdHMiLCJPYmplY3QiLCJ2YWx1ZXMiLCJldmVyeSJdLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmZlclJlc3VsdHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBTY2hlbWEsXG4gIFNjaGVtYVNpbXBsZSxcbiAgTm9ybWFsaXplZEluZGV4LFxuICBFbnRpdHlUYWJsZSxcbn0gZnJvbSAnLi9pbnRlcmZhY2UuanMnO1xuaW1wb3J0IHsgaXNFbnRpdHkgfSBmcm9tICcuL2lzRW50aXR5LmpzJztcbmltcG9ydCB7IGluZmVyIGFzIGFycmF5SW5mZXIgfSBmcm9tICcuL3NjaGVtYXMvQXJyYXkuanMnO1xuaW1wb3J0IHsgaW5mZXIgYXMgb2JqZWN0SW5mZXIgfSBmcm9tICcuL3NjaGVtYXMvT2JqZWN0LmpzJztcbmltcG9ydCB0eXBlIHsgTm9ybWFsaXplTnVsbGFibGUgfSBmcm9tICcuL3R5cGVzLmpzJztcblxuLyoqXG4gKiBCdWlsZCB0aGUgcmVzdWx0IHBhcmFtZXRlciB0byBkZW5vcm1hbGl6ZSBmcm9tIHNjaGVtYSBhbG9uZS5cbiAqIFRyaWVzIHRvIGNvbXB1dGUgdGhlIGVudGl0eSBpZHMgZnJvbSBwYXJhbXMuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGluZmVyUmVzdWx0czxTIGV4dGVuZHMgU2NoZW1hPihcbiAgc2NoZW1hOiBTLFxuICBhcmdzOiBhbnlbXSxcbiAgaW5kZXhlczogTm9ybWFsaXplZEluZGV4LFxuICBlbnRpdGllczogRW50aXR5VGFibGUsXG4pOiBOb3JtYWxpemVOdWxsYWJsZTxTPiB7XG4gIC8vIHNjaGVtYSBjbGFzc2VzXG4gIGlmIChjYW5JbmZlcihzY2hlbWEpKSB7XG4gICAgY29uc3QgcmV0ID0gc2NoZW1hLmluZmVyKGFyZ3MsIGluZGV4ZXMsIGluZmVyUmVzdWx0cywgZW50aXRpZXMpO1xuICAgIC8vIFRPRE8oYnJlYWtpbmcpOiBiYWNrIGNvbXBhdGliaWxpdHkgd2l0aCBlbmRwb2ludEAzLjcgYW5kIGxlc3NcbiAgICBpZiAoaXNFbnRpdHkoc2NoZW1hKSAmJiByZXQgIT09IHVuZGVmaW5lZCAmJiAhZW50aXRpZXNbc2NoZW1hLmtleV0/LltyZXRdKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkIGFzIGFueTtcbiAgICB9XG4gICAgcmV0dXJuIHJldDtcbiAgfVxuXG4gIC8vIHBsYWluIGNhc2VcbiAgaWYgKHR5cGVvZiBzY2hlbWEgPT09ICdvYmplY3QnICYmIHNjaGVtYSkge1xuICAgIGNvbnN0IG1ldGhvZCA9IEFycmF5LmlzQXJyYXkoc2NoZW1hKSA/IGFycmF5SW5mZXIgOiBvYmplY3RJbmZlcjtcbiAgICByZXR1cm4gbWV0aG9kKHNjaGVtYSwgYXJncywgaW5kZXhlcywgaW5mZXJSZXN1bHRzLCBlbnRpdGllcyk7XG4gIH1cblxuICAvLyBmYWxsYmFjayBmb3IgdGhpbmdzIGxpa2UgbnVsbCBvciB1bmRlZmluZWRcbiAgcmV0dXJuIHNjaGVtYSBhcyBhbnk7XG59XG5cbmZ1bmN0aW9uIGNhbkluZmVyKHNjaGVtYTogU2NoZW1hKTogc2NoZW1hIGlzIFBpY2s8U2NoZW1hU2ltcGxlLCAnaW5mZXInPiB7XG4gIHJldHVybiAhIXNjaGVtYSAmJiB0eXBlb2YgKHNjaGVtYSBhcyBhbnkpLmluZmVyID09PSAnZnVuY3Rpb24nO1xufVxuXG4vLyB0aGlzIG9ubHkgd29ya3MgaWYgZW50aXR5IGRvZXMgYSBsb29rdXAgZmlyc3QgdG8gc2VlIGlmIGl0cyBlbnRpdHkgaXMgJ2ZvdW5kJ1xuZXhwb3J0IGZ1bmN0aW9uIHZhbGlkYXRlSW5mZXJlbmNlKHJlc3VsdHM6IHVua25vd24pIHtcbiAgaWYgKHJlc3VsdHMgPT09IHVuZGVmaW5lZCkgcmV0dXJuIGZhbHNlO1xuICBpZiAocmVzdWx0cyAmJiB0eXBlb2YgcmVzdWx0cyA9PT0gJ29iamVjdCcgJiYgIUFycmF5LmlzQXJyYXkocmVzdWx0cykpIHtcbiAgICByZXR1cm4gT2JqZWN0LnZhbHVlcyhyZXN1bHRzKS5ldmVyeSh2YWxpZGF0ZUluZmVyZW5jZSk7XG4gIH1cbiAgcmV0dXJuIHRydWU7XG59XG4iXSwibWFwcGluZ3MiOiJBQU1BLFNBQVNBLFFBQVEsUUFBUSxlQUFlO0FBQ3hDLFNBQVNDLEtBQUssSUFBSUMsVUFBVSxRQUFRLG9CQUFvQjtBQUN4RCxTQUFTRCxLQUFLLElBQUlFLFdBQVcsUUFBUSxxQkFBcUI7QUFHMUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLFNBQVNDLFlBQVlBLENBQ2xDQyxNQUFTLEVBQ1RDLElBQVcsRUFDWEMsT0FBd0IsRUFDeEJDLFFBQXFCLEVBQ0M7RUFDdEI7RUFDQSxJQUFJQyxRQUFRLENBQUNKLE1BQU0sQ0FBQyxFQUFFO0lBQUEsSUFBQUssb0JBQUE7SUFDcEIsTUFBTUMsR0FBRyxHQUFHTixNQUFNLENBQUNKLEtBQUssQ0FBQ0ssSUFBSSxFQUFFQyxPQUFPLEVBQUVILFlBQVksRUFBRUksUUFBUSxDQUFDO0lBQy9EO0lBQ0EsSUFBSVIsUUFBUSxDQUFDSyxNQUFNLENBQUMsSUFBSU0sR0FBRyxLQUFLQyxTQUFTLElBQUksR0FBQUYsb0JBQUEsR0FBQ0YsUUFBUSxDQUFDSCxNQUFNLENBQUNRLEdBQUcsQ0FBQyxhQUFwQkgsb0JBQUEsQ0FBdUJDLEdBQUcsQ0FBQyxHQUFFO01BQ3pFLE9BQU9DLFNBQVM7SUFDbEI7SUFDQSxPQUFPRCxHQUFHO0VBQ1o7O0VBRUE7RUFDQSxJQUFJLE9BQU9OLE1BQU0sS0FBSyxRQUFRLElBQUlBLE1BQU0sRUFBRTtJQUN4QyxNQUFNUyxNQUFNLEdBQUdDLEtBQUssQ0FBQ0MsT0FBTyxDQUFDWCxNQUFNLENBQUMsR0FBR0gsVUFBVSxHQUFHQyxXQUFXO0lBQy9ELE9BQU9XLE1BQU0sQ0FBQ1QsTUFBTSxFQUFFQyxJQUFJLEVBQUVDLE9BQU8sRUFBRUgsWUFBWSxFQUFFSSxRQUFRLENBQUM7RUFDOUQ7O0VBRUE7RUFDQSxPQUFPSCxNQUFNO0FBQ2Y7QUFFQSxTQUFTSSxRQUFRQSxDQUFDSixNQUFjLEVBQXlDO0VBQ3ZFLE9BQU8sQ0FBQyxDQUFDQSxNQUFNLElBQUksT0FBUUEsTUFBTSxDQUFTSixLQUFLLEtBQUssVUFBVTtBQUNoRTs7QUFFQTtBQUNBLE9BQU8sU0FBU2dCLGlCQUFpQkEsQ0FBQ0MsT0FBZ0IsRUFBRTtFQUNsRCxJQUFJQSxPQUFPLEtBQUtOLFNBQVMsRUFBRSxPQUFPLEtBQUs7RUFDdkMsSUFBSU0sT0FBTyxJQUFJLE9BQU9BLE9BQU8sS0FBSyxRQUFRLElBQUksQ0FBQ0gsS0FBSyxDQUFDQyxPQUFPLENBQUNFLE9BQU8sQ0FBQyxFQUFFO0lBQ3JFLE9BQU9DLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDRixPQUFPLENBQUMsQ0FBQ0csS0FBSyxDQUFDSixpQkFBaUIsQ0FBQztFQUN4RDtFQUNBLE9BQU8sSUFBSTtBQUNiIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpbmZlciIsImFycmF5SW5mZXIiLCJvYmplY3RJbmZlciIsImluZmVyUmVzdWx0cyIsInNjaGVtYSIsImFyZ3MiLCJpbmRleGVzIiwiZW50aXRpZXMiLCJjYW5JbmZlciIsIm1ldGhvZCIsIkFycmF5IiwiaXNBcnJheSIsInZhbGlkYXRlSW5mZXJlbmNlIiwicmVzdWx0cyIsInVuZGVmaW5lZCIsIk9iamVjdCIsInZhbHVlcyIsImV2ZXJ5Il0sInNvdXJjZXMiOlsiLi4vc3JjL2luZmVyUmVzdWx0cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIFNjaGVtYSxcbiAgU2NoZW1hU2ltcGxlLFxuICBOb3JtYWxpemVkSW5kZXgsXG4gIEVudGl0eVRhYmxlLFxufSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgeyBpbmZlciBhcyBhcnJheUluZmVyIH0gZnJvbSAnLi9zY2hlbWFzL0FycmF5LmpzJztcbmltcG9ydCB7IGluZmVyIGFzIG9iamVjdEluZmVyIH0gZnJvbSAnLi9zY2hlbWFzL09iamVjdC5qcyc7XG5pbXBvcnQgdHlwZSB7IE5vcm1hbGl6ZU51bGxhYmxlIH0gZnJvbSAnLi90eXBlcy5qcyc7XG5cbi8qKlxuICogQnVpbGQgdGhlIHJlc3VsdCBwYXJhbWV0ZXIgdG8gZGVub3JtYWxpemUgZnJvbSBzY2hlbWEgYWxvbmUuXG4gKiBUcmllcyB0byBjb21wdXRlIHRoZSBlbnRpdHkgaWRzIGZyb20gcGFyYW1zLlxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBpbmZlclJlc3VsdHM8UyBleHRlbmRzIFNjaGVtYT4oXG4gIHNjaGVtYTogUyxcbiAgYXJnczogYW55W10sXG4gIGluZGV4ZXM6IE5vcm1hbGl6ZWRJbmRleCxcbiAgZW50aXRpZXM6IEVudGl0eVRhYmxlLFxuKTogTm9ybWFsaXplTnVsbGFibGU8Uz4ge1xuICAvLyBzY2hlbWEgY2xhc3Nlc1xuICBpZiAoY2FuSW5mZXIoc2NoZW1hKSkge1xuICAgIHJldHVybiBzY2hlbWEuaW5mZXIoYXJncywgaW5kZXhlcywgaW5mZXJSZXN1bHRzLCBlbnRpdGllcyk7XG4gIH1cblxuICAvLyBwbGFpbiBjYXNlXG4gIGlmICh0eXBlb2Ygc2NoZW1hID09PSAnb2JqZWN0JyAmJiBzY2hlbWEpIHtcbiAgICBjb25zdCBtZXRob2QgPSBBcnJheS5pc0FycmF5KHNjaGVtYSkgPyBhcnJheUluZmVyIDogb2JqZWN0SW5mZXI7XG4gICAgcmV0dXJuIG1ldGhvZChzY2hlbWEsIGFyZ3MsIGluZGV4ZXMsIGluZmVyUmVzdWx0cywgZW50aXRpZXMpO1xuICB9XG5cbiAgLy8gZmFsbGJhY2sgZm9yIHRoaW5ncyBsaWtlIG51bGwgb3IgdW5kZWZpbmVkXG4gIHJldHVybiBzY2hlbWEgYXMgYW55O1xufVxuXG5mdW5jdGlvbiBjYW5JbmZlcihzY2hlbWE6IFNjaGVtYSk6IHNjaGVtYSBpcyBQaWNrPFNjaGVtYVNpbXBsZSwgJ2luZmVyJz4ge1xuICByZXR1cm4gISFzY2hlbWEgJiYgdHlwZW9mIChzY2hlbWEgYXMgYW55KS5pbmZlciA9PT0gJ2Z1bmN0aW9uJztcbn1cblxuLy8gdGhpcyBvbmx5IHdvcmtzIGlmIGVudGl0eSBkb2VzIGEgbG9va3VwIGZpcnN0IHRvIHNlZSBpZiBpdHMgZW50aXR5IGlzICdmb3VuZCdcbmV4cG9ydCBmdW5jdGlvbiB2YWxpZGF0ZUluZmVyZW5jZShyZXN1bHRzOiB1bmtub3duKSB7XG4gIGlmIChyZXN1bHRzID09PSB1bmRlZmluZWQpIHJldHVybiBmYWxzZTtcbiAgaWYgKHJlc3VsdHMgJiYgdHlwZW9mIHJlc3VsdHMgPT09ICdvYmplY3QnICYmICFBcnJheS5pc0FycmF5KHJlc3VsdHMpKSB7XG4gICAgcmV0dXJuIE9iamVjdC52YWx1ZXMocmVzdWx0cykuZXZlcnkodmFsaWRhdGVJbmZlcmVuY2UpO1xuICB9XG4gIHJldHVybiB0cnVlO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFNQSxTQUFTQSxLQUFLLElBQUlDLFVBQVUsUUFBUSxvQkFBb0I7QUFDeEQsU0FBU0QsS0FBSyxJQUFJRSxXQUFXLFFBQVEscUJBQXFCO0FBRzFEO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxTQUFTQyxZQUFZQSxDQUNsQ0MsTUFBUyxFQUNUQyxJQUFXLEVBQ1hDLE9BQXdCLEVBQ3hCQyxRQUFxQixFQUNDO0VBQ3RCO0VBQ0EsSUFBSUMsUUFBUSxDQUFDSixNQUFNLENBQUMsRUFBRTtJQUNwQixPQUFPQSxNQUFNLENBQUNKLEtBQUssQ0FBQ0ssSUFBSSxFQUFFQyxPQUFPLEVBQUVILFlBQVksRUFBRUksUUFBUSxDQUFDO0VBQzVEOztFQUVBO0VBQ0EsSUFBSSxPQUFPSCxNQUFNLEtBQUssUUFBUSxJQUFJQSxNQUFNLEVBQUU7SUFDeEMsTUFBTUssTUFBTSxHQUFHQyxLQUFLLENBQUNDLE9BQU8sQ0FBQ1AsTUFBTSxDQUFDLEdBQUdILFVBQVUsR0FBR0MsV0FBVztJQUMvRCxPQUFPTyxNQUFNLENBQUNMLE1BQU0sRUFBRUMsSUFBSSxFQUFFQyxPQUFPLEVBQUVILFlBQVksRUFBRUksUUFBUSxDQUFDO0VBQzlEOztFQUVBO0VBQ0EsT0FBT0gsTUFBTTtBQUNmO0FBRUEsU0FBU0ksUUFBUUEsQ0FBQ0osTUFBYyxFQUF5QztFQUN2RSxPQUFPLENBQUMsQ0FBQ0EsTUFBTSxJQUFJLE9BQVFBLE1BQU0sQ0FBU0osS0FBSyxLQUFLLFVBQVU7QUFDaEU7O0FBRUE7QUFDQSxPQUFPLFNBQVNZLGlCQUFpQkEsQ0FBQ0MsT0FBZ0IsRUFBRTtFQUNsRCxJQUFJQSxPQUFPLEtBQUtDLFNBQVMsRUFBRSxPQUFPLEtBQUs7RUFDdkMsSUFBSUQsT0FBTyxJQUFJLE9BQU9BLE9BQU8sS0FBSyxRQUFRLElBQUksQ0FBQ0gsS0FBSyxDQUFDQyxPQUFPLENBQUNFLE9BQU8sQ0FBQyxFQUFFO0lBQ3JFLE9BQU9FLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDSCxPQUFPLENBQUMsQ0FBQ0ksS0FBSyxDQUFDTCxpQkFBaUIsQ0FBQztFQUN4RDtFQUNBLE9BQU8sSUFBSTtBQUNiIn0= |
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2ludGVyZmFjZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBTY2hlbWEgPVxuICB8IG51bGxcbiAgfCBzdHJpbmdcbiAgfCB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICB8IFNjaGVtYVtdXG4gIHwgU2NoZW1hU2ltcGxlXG4gIHwgU2VyaWFsaXphYmxlO1xuXG5leHBvcnQgdHlwZSBTZXJpYWxpemFibGU8XG4gIFQgZXh0ZW5kcyB7IHRvSlNPTigpOiBzdHJpbmcgfSA9IHsgdG9KU09OKCk6IHN0cmluZyB9LFxuPiA9IHtcbiAgcHJvdG90eXBlOiBUO1xufTtcblxuZXhwb3J0IGludGVyZmFjZSBTY2hlbWFTaW1wbGU8VCA9IGFueT4ge1xuICBub3JtYWxpemUoXG4gICAgaW5wdXQ6IGFueSxcbiAgICBwYXJlbnQ6IGFueSxcbiAgICBrZXk6IGFueSxcbiAgICB2aXNpdDogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIGFkZEVudGl0eTogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIHZpc2l0ZWRFbnRpdGllczogUmVjb3JkPHN0cmluZywgYW55PixcbiAgICBzdG9yZUVudGl0aWVzPzogYW55LFxuICAgIGFyZ3M/OiBhbnlbXSxcbiAgKTogYW55O1xuICBkZW5vcm1hbGl6ZT8oXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbiAgICBpbnB1dDoge30sXG4gICAgdW52aXNpdDogVW52aXNpdEZ1bmN0aW9uLFxuICApOiBbZGVub3JtYWxpemVkOiBULCBmb3VuZDogYm9vbGVhbiwgc3VzcGVuZDogYm9vbGVhbl07XG4gIGRlbm9ybWFsaXplT25seT8oXG4gICAgaW5wdXQ6IHt9LFxuICAgIGFyZ3M6IGFueSxcbiAgICB1bnZpc2l0OiAoaW5wdXQ6IGFueSwgc2NoZW1hOiBhbnkpID0+IGFueSxcbiAgKTogVDtcbiAgaW5mZXIoXG4gICAgYXJnczogcmVhZG9ubHkgYW55W10sXG4gICAgaW5kZXhlczogTm9ybWFsaXplZEluZGV4LFxuICAgIHJlY3Vyc2U6ICguLi5hcmdzOiBhbnkpID0+IGFueSxcbiAgICBlbnRpdGllczogRW50aXR5VGFibGUsXG4gICk6IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTY2hlbWFDbGFzczxUID0gYW55LCBOID0gVCB8IHVuZGVmaW5lZD5cbiAgZXh0ZW5kcyBTY2hlbWFTaW1wbGU8VD4ge1xuICAvLyB0aGlzIGlzIG5vdCBhbiBhY3R1YWwgbWVtYmVyLCBidXQgaXMgbmVlZGVkIGZvciB0aGUgcmVjdXJzaXZlIE5vcm1hbGl6ZU51bGxhYmxlPD4gdHlwZSBhbGdvXG4gIF9ub3JtYWxpemVOdWxsYWJsZSgpOiBhbnk7XG4gIC8vIHRoaXMgaXMgbm90IGFuIGFjdHVhbCBtZW1iZXIsIGJ1dCBpcyBuZWVkZWQgZm9yIHRoZSByZWN1cnNpdmUgRGVub3JtYWxpemVOdWxsYWJsZTw+IHR5cGUgYWxnb1xuICBfZGVub3JtYWxpemVOdWxsYWJsZSgpOiBbTiwgYm9vbGVhbiwgYm9vbGVhbl07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW50aXR5SW50ZXJmYWNlPFQgPSBhbnk+IGV4dGVuZHMgU2NoZW1hU2ltcGxlIHtcbiAgY3JlYXRlSWZWYWxpZD8ocHJvcHM6IGFueSk6IGFueTtcbiAgcGsoXG4gICAgcGFyYW1zOiBhbnksXG4gICAgcGFyZW50PzogYW55LFxuICAgIGtleT86IHN0cmluZyxcbiAgICBhcmdzPzogcmVhZG9ubHkgYW55W10sXG4gICk6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgcmVhZG9ubHkga2V5OiBzdHJpbmc7XG4gIG1lcmdlKGV4aXN0aW5nOiBhbnksIGluY29taW5nOiBhbnkpOiBhbnk7XG4gIC8qKiBAZGVwcmVjYXRlZCB1c2UgbWVyZ2VXaXRoU3RvcmUgaW5zdGVhZCAod2hpY2ggY2FuIGNhbGwgdGhpcykgKi9cbiAgZXhwaXJlc0F0PyhtZXRhOiBhbnksIGlucHV0OiBhbnkpOiBudW1iZXI7XG4gIG1lcmdlV2l0aFN0b3JlPyhcbiAgICBleGlzdGluZ01ldGE6IGFueSxcbiAgICBpbmNvbWluZ01ldGE6IGFueSxcbiAgICBleGlzdGluZzogYW55LFxuICAgIGluY29taW5nOiBhbnksXG4gICk6IGFueTtcbiAgbWVyZ2VNZXRhV2l0aFN0b3JlPyhcbiAgICBleGlzdGluZ01ldGE6IGFueSxcbiAgICBpbmNvbWluZ01ldGE6IGFueSxcbiAgICBleGlzdGluZzogYW55LFxuICAgIGluY29taW5nOiBhbnksXG4gICk6IGFueTtcbiAgLyoqIEBkZXByZWNhdGVkIHVzZSBtZXJnZVdpdGhTdG9yZSBpbnN0ZWFkICh3aGljaCBjYW4gY2FsbCB0aGlzKSAqL1xuICB1c2VJbmNvbWluZz8oXG4gICAgZXhpc3RpbmdNZXRhOiBhbnksXG4gICAgaW5jb21pbmdNZXRhOiBhbnksXG4gICAgZXhpc3Rpbmc6IGFueSxcbiAgICBpbmNvbWluZzogYW55LFxuICApOiBib29sZWFuO1xuICBpbmRleGVzPzogYW55O1xuICBzY2hlbWE6IFJlY29yZDxzdHJpbmcsIFNjaGVtYT47XG4gIGNhY2hlV2l0aD86IG9iamVjdDtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFVudmlzaXRGdW5jdGlvbiB7XG4gIChpbnB1dDogYW55LCBzY2hlbWE6IGFueSk6IFthbnksIGJvb2xlYW4sIGJvb2xlYW5dIHwgYW55O1xuICBvZz86IFVudmlzaXRGdW5jdGlvbjtcbiAgc2V0TG9jYWw/OiAoZW50aXR5OiBhbnkpID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTm9ybWFsaXplZEluZGV4IHtcbiAgcmVhZG9ubHkgW2VudGl0eUtleTogc3RyaW5nXToge1xuICAgIHJlYWRvbmx5IFtpbmRleE5hbWU6IHN0cmluZ106IHsgcmVhZG9ubHkgW2xvb2t1cDogc3RyaW5nXTogc3RyaW5nIH07XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW50aXR5VGFibGUge1xuICBbZW50aXR5S2V5OiBzdHJpbmddOlxuICAgIHwge1xuICAgICAgICBbcGs6IHN0cmluZ106IHVua25vd247XG4gICAgICB9XG4gICAgfCB1bmRlZmluZWQ7XG59XG4iXSwibWFwcGluZ3MiOiIifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2ludGVyZmFjZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBTY2hlbWEgPVxuICB8IG51bGxcbiAgfCBzdHJpbmdcbiAgfCB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICB8IFNjaGVtYVtdXG4gIHwgU2NoZW1hU2ltcGxlXG4gIHwgU2VyaWFsaXphYmxlO1xuXG5leHBvcnQgdHlwZSBTZXJpYWxpemFibGU8XG4gIFQgZXh0ZW5kcyB7IHRvSlNPTigpOiBzdHJpbmcgfSA9IHsgdG9KU09OKCk6IHN0cmluZyB9LFxuPiA9ICh2YWx1ZTogYW55KSA9PiBUO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYVNpbXBsZTxUID0gYW55PiB7XG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgYWRkRW50aXR5OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+LFxuICAgIHN0b3JlRW50aXRpZXM/OiBhbnksXG4gICAgYXJncz86IGFueVtdLFxuICApOiBhbnk7XG4gIGRlbm9ybWFsaXplKFxuICAgIGlucHV0OiB7fSxcbiAgICBhcmdzOiBhbnksXG4gICAgdW52aXNpdDogKGlucHV0OiBhbnksIHNjaGVtYTogYW55KSA9PiBhbnksXG4gICk6IFQ7XG4gIGluZmVyKFxuICAgIGFyZ3M6IHJlYWRvbmx5IGFueVtdLFxuICAgIGluZGV4ZXM6IE5vcm1hbGl6ZWRJbmRleCxcbiAgICByZWN1cnNlOiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgZW50aXRpZXM6IEVudGl0eVRhYmxlLFxuICApOiBhbnk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZW1hQ2xhc3M8VCA9IGFueSwgTiA9IFQgfCB1bmRlZmluZWQ+XG4gIGV4dGVuZHMgU2NoZW1hU2ltcGxlPFQ+IHtcbiAgLy8gdGhpcyBpcyBub3QgYW4gYWN0dWFsIG1lbWJlciwgYnV0IGlzIG5lZWRlZCBmb3IgdGhlIHJlY3Vyc2l2ZSBOb3JtYWxpemVOdWxsYWJsZTw+IHR5cGUgYWxnb1xuICBfbm9ybWFsaXplTnVsbGFibGUoKTogYW55O1xuICAvLyB0aGlzIGlzIG5vdCBhbiBhY3R1YWwgbWVtYmVyLCBidXQgaXMgbmVlZGVkIGZvciB0aGUgcmVjdXJzaXZlIERlbm9ybWFsaXplTnVsbGFibGU8PiB0eXBlIGFsZ29cbiAgX2Rlbm9ybWFsaXplTnVsbGFibGUoKTogTjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbnRpdHlJbnRlcmZhY2U8VCA9IGFueT4gZXh0ZW5kcyBTY2hlbWFTaW1wbGUge1xuICBjcmVhdGVJZlZhbGlkKHByb3BzOiBhbnkpOiBhbnk7XG4gIHBrKFxuICAgIHBhcmFtczogYW55LFxuICAgIHBhcmVudD86IGFueSxcbiAgICBrZXk/OiBzdHJpbmcsXG4gICAgYXJncz86IHJlYWRvbmx5IGFueVtdLFxuICApOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIHJlYWRvbmx5IGtleTogc3RyaW5nO1xuICBtZXJnZShleGlzdGluZzogYW55LCBpbmNvbWluZzogYW55KTogYW55O1xuICBtZXJnZVdpdGhTdG9yZShcbiAgICBleGlzdGluZ01ldGE6IGFueSxcbiAgICBpbmNvbWluZ01ldGE6IGFueSxcbiAgICBleGlzdGluZzogYW55LFxuICAgIGluY29taW5nOiBhbnksXG4gICk6IGFueTtcbiAgbWVyZ2VNZXRhV2l0aFN0b3JlKFxuICAgIGV4aXN0aW5nTWV0YTogYW55LFxuICAgIGluY29taW5nTWV0YTogYW55LFxuICAgIGV4aXN0aW5nOiBhbnksXG4gICAgaW5jb21pbmc6IGFueSxcbiAgKTogYW55O1xuICBpbmRleGVzPzogYW55O1xuICBzY2hlbWE6IFJlY29yZDxzdHJpbmcsIFNjaGVtYT47XG4gIGNhY2hlV2l0aD86IG9iamVjdDtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE5vcm1hbGl6ZWRJbmRleCB7XG4gIHJlYWRvbmx5IFtlbnRpdHlLZXk6IHN0cmluZ106IHtcbiAgICByZWFkb25seSBbaW5kZXhOYW1lOiBzdHJpbmddOiB7IHJlYWRvbmx5IFtsb29rdXA6IHN0cmluZ106IHN0cmluZyB9O1xuICB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVudGl0eVRhYmxlIHtcbiAgW2VudGl0eUtleTogc3RyaW5nXTpcbiAgICB8IHtcbiAgICAgICAgW3BrOiBzdHJpbmddOiB1bmtub3duO1xuICAgICAgfVxuICAgIHwgdW5kZWZpbmVkO1xufVxuIl0sIm1hcHBpbmdzIjoiIn0= |
@@ -0,4 +1,4 @@ | ||
import { INVALID } from './denormalize/symbol.js'; | ||
import { normalize as arrayNormalize } from './schemas/Array.js'; | ||
import { normalize as objectNormalize } from './schemas/Object.js'; | ||
import { DELETED } from './special.js'; | ||
const visit = (value, parent, key, schema, addEntity, visitedEntities, storeEntities, args) => { | ||
@@ -12,7 +12,2 @@ if (!value || !schema) { | ||
} | ||
// serializable | ||
if (typeof schema === 'function') { | ||
return new schema(value); | ||
} | ||
if (typeof value !== 'object' || typeof schema !== 'object') return value; | ||
@@ -37,9 +32,8 @@ const method = Array.isArray(schema) ? arrayNormalize : objectNormalize; | ||
if (inStoreEntity && (inStoreMeta = storeEntityMeta[schemaKey][id])) { | ||
entities[schemaKey][id] = schema.mergeWithStore ? schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore ? schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeMetaWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
entities[schemaKey][id] = schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
} else { | ||
entities[schemaKey][id] = processedEntity; | ||
storeEntityMeta[schemaKey][id] = { | ||
// TODO(breaking): Remove schema.expiresat | ||
expiresAt: schema.expiresAt ? schema.expiresAt(meta, processedEntity) : meta.expiresAt, | ||
expiresAt: meta.expiresAt, | ||
date: meta.date, | ||
@@ -73,3 +67,3 @@ fetchedAt: meta.fetchedAt | ||
if (storeEntities && storeEntities[id] && storeEntities[id][index] !== entity[index]) { | ||
indexMap[storeEntities[id][index]] = DELETED; | ||
indexMap[storeEntities[id][index]] = INVALID; | ||
} | ||
@@ -87,29 +81,2 @@ if (index in entity) { | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeStore() instead */ | ||
function mergeWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
const useIncoming = | ||
// useIncoming should not be used with legacy optimistic | ||
schema.useIncoming && incomingMeta.fetchedAt ? schema.useIncoming(existingMeta, incomingMeta, existing, incoming) : existingMeta.date <= incomingMeta.date; | ||
if (useIncoming) { | ||
if (typeof incoming !== typeof existing) { | ||
return incoming; | ||
} else { | ||
return schema.merge(existing, incoming); | ||
} | ||
} else { | ||
return existing; | ||
} | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeMetaWithStore() instead */ | ||
function mergeMetaWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
return { | ||
expiresAt: Math.max(schema.expiresAt ? schema.expiresAt(incomingMeta, incoming) : incomingMeta.expiresAt, existingMeta.expiresAt), | ||
date: Math.max(incomingMeta.date, existingMeta.date), | ||
fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt) | ||
}; | ||
} | ||
function expectedSchemaType(schema) { | ||
@@ -150,3 +117,3 @@ return ['object', 'function'].includes(typeof schema) ? 'object' : typeof schema; | ||
the JSON. By default, this only happens if "content-type" header includes "json". | ||
See https://resthooks.io/rest/api/RestEndpoint#parseResponse for more information | ||
See https://dataclient.io/rest/api/RestEndpoint#parseResponse for more information | ||
@@ -180,2 +147,2 @@ Schema: ${JSON.stringify(schema, undefined, 2)} | ||
}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["normalize","arrayNormalize","objectNormalize","DELETED","visit","value","parent","key","schema","addEntity","visitedEntities","storeEntities","args","method","Array","isArray","addEntities","entities","indexes","storeIndexes","storeEntityMeta","meta","processedEntity","id","schemaKey","Object","assign","existingEntity","merge","inStoreEntity","inStoreMeta","mergeWithStore","mergeMetaWithStore","expiresAt","date","fetchedAt","handleIndexes","schemaIndexes","entity","index","indexMap","process","env","NODE_ENV","console","warn","JSON","stringify","undefined","existingMeta","incomingMeta","existing","incoming","useIncoming","Math","max","expectedSchemaType","includes","input","Date","now","Infinity","result","entityMeta","schemaType","pk","parseWorks","parse","e","Error","newEntities","newIndexes"],"sources":["../src/normalize.ts"],"sourcesContent":["import type { EntityInterface, Schema, NormalizedIndex } from './interface.js';\nimport { normalize as arrayNormalize } from './schemas/Array.js';\nimport { normalize as objectNormalize } from './schemas/Object.js';\nimport { DELETED } from './special.js';\nimport type { NormalizeNullable, NormalizedSchema } from './types.js';\n\nconst visit = (\n  value: any,\n  parent: any,\n  key: any,\n  schema: any,\n  addEntity: (\n    schema: EntityInterface,\n    processedEntity: any,\n    id: string,\n  ) => void,\n  visitedEntities: any,\n  storeEntities: any,\n  args: any[],\n) => {\n  if (!value || !schema) {\n    return value;\n  }\n\n  if (schema.normalize && typeof schema.normalize === 'function') {\n    if (typeof value !== 'object') return value;\n    return schema.normalize(\n      value,\n      parent,\n      key,\n      visit,\n      addEntity,\n      visitedEntities,\n      storeEntities,\n      args,\n    );\n  }\n\n  // serializable\n  if (typeof schema === 'function') {\n    return new schema(value);\n  }\n\n  if (typeof value !== 'object' || typeof schema !== 'object') return value;\n\n  const method = Array.isArray(schema) ? arrayNormalize : objectNormalize;\n  return method(\n    schema,\n    value,\n    parent,\n    key,\n    visit,\n    addEntity,\n    visitedEntities,\n    storeEntities,\n    args,\n  );\n};\n\nconst addEntities =\n  (\n    entities: Record<string, any>,\n    indexes: Record<string, any>,\n    storeEntities: Record<string, any>,\n    storeIndexes: Record<string, any>,\n    storeEntityMeta: {\n      [entityKey: string]: {\n        [pk: string]: {\n          date: number;\n          expiresAt: number;\n          fetchedAt: number;\n        };\n      };\n    },\n    meta: { expiresAt: number; date: number; fetchedAt: number },\n  ) =>\n  (schema: EntityInterface, processedEntity: any, id: string) => {\n    const schemaKey = schema.key;\n    if (!(schemaKey in entities)) {\n      entities[schemaKey] = {};\n      storeEntities[schemaKey] = { ...storeEntities[schemaKey] };\n      storeEntityMeta[schemaKey] = { ...storeEntityMeta[schemaKey] };\n    }\n\n    const existingEntity = entities[schemaKey][id];\n    if (existingEntity) {\n      entities[schemaKey][id] = schema.merge(existingEntity, processedEntity);\n    } else {\n      const inStoreEntity = storeEntities[schemaKey][id];\n      let inStoreMeta: {\n        date: number;\n        expiresAt: number;\n        fetchedAt: number;\n      };\n      // this case we already have this entity in store\n      if (inStoreEntity && (inStoreMeta = storeEntityMeta[schemaKey][id])) {\n        entities[schemaKey][id] = schema.mergeWithStore\n          ? schema.mergeWithStore(\n              inStoreMeta,\n              meta,\n              inStoreEntity,\n              processedEntity,\n            )\n          : mergeWithStore(\n              schema,\n              inStoreMeta,\n              meta,\n              inStoreEntity,\n              processedEntity,\n            );\n        storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore\n          ? schema.mergeMetaWithStore(\n              inStoreMeta,\n              meta,\n              inStoreEntity,\n              processedEntity,\n            )\n          : mergeMetaWithStore(\n              schema,\n              inStoreMeta,\n              meta,\n              inStoreEntity,\n              processedEntity,\n            );\n      } else {\n        entities[schemaKey][id] = processedEntity;\n        storeEntityMeta[schemaKey][id] = {\n          // TODO(breaking): Remove schema.expiresat\n          expiresAt: schema.expiresAt\n            ? schema.expiresAt(meta, processedEntity)\n            : meta.expiresAt,\n          date: meta.date,\n          fetchedAt: meta.fetchedAt,\n        };\n      }\n    }\n\n    // update index\n    if (schema.indexes) {\n      if (!(schemaKey in indexes)) {\n        indexes[schemaKey] = {};\n        storeIndexes[schemaKey] = { ...storeIndexes[schemaKey] };\n      }\n      handleIndexes(\n        id,\n        schema.indexes,\n        indexes[schemaKey],\n        storeIndexes[schemaKey],\n        entities[schemaKey][id],\n        storeEntities[schemaKey],\n      );\n    }\n    // set this after index updates so we know what indexes to remove from\n    storeEntities[schemaKey][id] = entities[schemaKey][id];\n  };\n\nfunction handleIndexes(\n  id: string,\n  schemaIndexes: string[],\n  indexes: Record<string, any>,\n  storeIndexes: Record<string, any>,\n  entity: any,\n  storeEntities: Record<string, any>,\n) {\n  for (const index of schemaIndexes) {\n    if (!(index in indexes)) {\n      storeIndexes[index] = indexes[index] = {};\n    }\n    const indexMap = indexes[index];\n    if (storeEntities[id]) {\n      delete indexMap[storeEntities[id][index]];\n    }\n    // entity already in cache but the index changed\n    if (\n      storeEntities &&\n      storeEntities[id] &&\n      storeEntities[id][index] !== entity[index]\n    ) {\n      indexMap[storeEntities[id][index]] = DELETED;\n    }\n    if (index in entity) {\n      indexMap[entity[index]] = id;\n    } /* istanbul ignore next */ else if (\n      // eslint-disable-next-line no-undef\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.warn(`Index not found in entity. Indexes must be top-level members of your entity.\nIndex: ${index}\nEntity: ${JSON.stringify(entity, undefined, 2)}`);\n    }\n  }\n}\n\n// TODO(breaking): remove this in 1 breaking releases\n/** @deprecated use Entity.mergeStore() instead */\nfunction mergeWithStore(\n  schema: EntityInterface<any>,\n  existingMeta: {\n    date: number;\n    expiresAt: number;\n    fetchedAt: number;\n  },\n  incomingMeta: {\n    expiresAt: number;\n    date: number;\n    fetchedAt?: number | undefined;\n  },\n  existing: any,\n  incoming: any,\n) {\n  const useIncoming =\n    // useIncoming should not be used with legacy optimistic\n    schema.useIncoming && incomingMeta.fetchedAt\n      ? schema.useIncoming(existingMeta, incomingMeta, existing, incoming)\n      : existingMeta.date <= incomingMeta.date;\n  if (useIncoming) {\n    if (typeof incoming !== typeof existing) {\n      return incoming;\n    } else {\n      return schema.merge(existing, incoming);\n    }\n  } else {\n    return existing;\n  }\n}\n\n// TODO(breaking): remove this in 1 breaking releases\n/** @deprecated use Entity.mergeMetaWithStore() instead */\nfunction mergeMetaWithStore(\n  schema: any,\n  existingMeta: {\n    date: number;\n    expiresAt: number;\n    fetchedAt: number;\n  },\n  incomingMeta: {\n    expiresAt: number;\n    date: number;\n    fetchedAt: number;\n  },\n  existing: any,\n  incoming: any,\n) {\n  return {\n    expiresAt: Math.max(\n      schema.expiresAt\n        ? schema.expiresAt(incomingMeta, incoming)\n        : incomingMeta.expiresAt,\n      existingMeta.expiresAt,\n    ),\n    date: Math.max(incomingMeta.date, existingMeta.date),\n    fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt),\n  };\n}\n\nfunction expectedSchemaType(schema: Schema) {\n  return ['object', 'function'].includes(typeof schema)\n    ? 'object'\n    : typeof schema;\n}\n\n// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\nexport const normalize = <\n  S extends Schema = Schema,\n  E extends Record<string, Record<string, any> | undefined> = Record<\n    string,\n    Record<string, any>\n  >,\n  R = NormalizeNullable<S>,\n>(\n  input: any,\n  schema?: S,\n  args: any[] = [],\n  storeEntities: Readonly<E> = {} as any,\n  storeIndexes: Readonly<NormalizedIndex> = {},\n  storeEntityMeta: {\n    readonly [entityKey: string]: {\n      readonly [pk: string]: {\n        readonly date: number;\n        readonly expiresAt: number;\n        readonly fetchedAt: number;\n      };\n    };\n  } = {},\n  meta: { expiresAt: number; date: number; fetchedAt: number } = {\n    date: Date.now(),\n    expiresAt: Infinity,\n    fetchedAt: 0,\n  },\n): NormalizedSchema<E, R> => {\n  // no schema means we don't process at all\n  if (schema === undefined || schema === null)\n    return {\n      entities: storeEntities,\n      indexes: storeIndexes,\n      result: input,\n      entityMeta: storeEntityMeta,\n    };\n\n  const schemaType = expectedSchemaType(schema);\n  if (\n    input === null ||\n    (typeof input !== schemaType &&\n      // we will allow a Delete schema to be a string or object\n      !(\n        (schema as any).key !== undefined &&\n        (schema as any).pk === undefined &&\n        typeof input === 'string'\n      ))\n  ) {\n    /* istanbul ignore else */\n    if (process.env.NODE_ENV !== 'production') {\n      const parseWorks = (input: string) => {\n        try {\n          return typeof JSON.parse(input) !== 'string';\n        } catch (e) {\n          return false;\n        }\n      };\n      if (typeof input === 'string' && parseWorks(input)) {\n        throw new Error(`Normalizing a string, but this does match schema.\n\nParsing this input string as JSON worked. This likely indicates fetch function did not parse\nthe JSON. By default, this only happens if \"content-type\" header includes \"json\".\nSee https://resthooks.io/rest/api/RestEndpoint#parseResponse for more information\n\n  Schema: ${JSON.stringify(schema, undefined, 2)}\n  Input: \"${input}\"`);\n      } else {\n        throw new Error(\n          `Unexpected input given to normalize. Expected type to be \"${schemaType}\", found \"${\n            input === null ? 'null' : typeof input\n          }\".\n\n          Schema: ${JSON.stringify(schema, undefined, 2)}\n          Input: \"${input}\"`,\n        );\n      }\n    } else {\n      throw new Error(\n        `Unexpected input given to normalize. Expected type to be \"${schemaType}\", found \"${\n          input === null ? 'null' : typeof input\n        }\".`,\n      );\n    }\n  }\n\n  const newEntities: E = {} as any;\n  const newIndexes: NormalizedIndex = {} as any;\n  const entities: E = { ...storeEntities } as any;\n  const indexes: NormalizedIndex = { ...storeIndexes };\n  const entityMeta: any = { ...storeEntityMeta };\n  const addEntity = addEntities(\n    newEntities,\n    newIndexes,\n    entities,\n    indexes,\n    entityMeta,\n    meta,\n  );\n  const visitedEntities = {};\n\n  const result = visit(\n    input,\n    input,\n    undefined,\n    schema,\n    addEntity,\n    visitedEntities,\n    storeEntities,\n    args,\n  );\n  return { entities, indexes, result, entityMeta };\n};\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["INVALID","normalize","arrayNormalize","objectNormalize","visit","value","parent","key","schema","addEntity","visitedEntities","storeEntities","args","method","Array","isArray","addEntities","entities","indexes","storeIndexes","storeEntityMeta","meta","processedEntity","id","schemaKey","Object","assign","existingEntity","merge","inStoreEntity","inStoreMeta","mergeWithStore","mergeMetaWithStore","expiresAt","date","fetchedAt","handleIndexes","schemaIndexes","entity","index","indexMap","process","env","NODE_ENV","console","warn","JSON","stringify","undefined","expectedSchemaType","includes","input","Date","now","Infinity","result","entityMeta","schemaType","pk","parseWorks","parse","e","Error","newEntities","newIndexes"],"sources":["../src/normalize.ts"],"sourcesContent":["import { INVALID } from './denormalize/symbol.js';\nimport type { EntityInterface, Schema, NormalizedIndex } from './interface.js';\nimport { normalize as arrayNormalize } from './schemas/Array.js';\nimport { normalize as objectNormalize } from './schemas/Object.js';\nimport type { NormalizeNullable, NormalizedSchema } from './types.js';\n\nconst visit = (\n  value: any,\n  parent: any,\n  key: any,\n  schema: any,\n  addEntity: (\n    schema: EntityInterface,\n    processedEntity: any,\n    id: string,\n  ) => void,\n  visitedEntities: any,\n  storeEntities: any,\n  args: any[],\n) => {\n  if (!value || !schema) {\n    return value;\n  }\n\n  if (schema.normalize && typeof schema.normalize === 'function') {\n    if (typeof value !== 'object') return value;\n    return schema.normalize(\n      value,\n      parent,\n      key,\n      visit,\n      addEntity,\n      visitedEntities,\n      storeEntities,\n      args,\n    );\n  }\n\n  if (typeof value !== 'object' || typeof schema !== 'object') return value;\n\n  const method = Array.isArray(schema) ? arrayNormalize : objectNormalize;\n  return method(\n    schema,\n    value,\n    parent,\n    key,\n    visit,\n    addEntity,\n    visitedEntities,\n    storeEntities,\n    args,\n  );\n};\n\nconst addEntities =\n  (\n    entities: Record<string, any>,\n    indexes: Record<string, any>,\n    storeEntities: Record<string, any>,\n    storeIndexes: Record<string, any>,\n    storeEntityMeta: {\n      [entityKey: string]: {\n        [pk: string]: {\n          date: number;\n          expiresAt: number;\n          fetchedAt: number;\n        };\n      };\n    },\n    meta: { expiresAt: number; date: number; fetchedAt: number },\n  ) =>\n  (schema: EntityInterface, processedEntity: any, id: string) => {\n    const schemaKey = schema.key;\n    if (!(schemaKey in entities)) {\n      entities[schemaKey] = {};\n      storeEntities[schemaKey] = { ...storeEntities[schemaKey] };\n      storeEntityMeta[schemaKey] = { ...storeEntityMeta[schemaKey] };\n    }\n\n    const existingEntity = entities[schemaKey][id];\n    if (existingEntity) {\n      entities[schemaKey][id] = schema.merge(existingEntity, processedEntity);\n    } else {\n      const inStoreEntity = storeEntities[schemaKey][id];\n      let inStoreMeta: {\n        date: number;\n        expiresAt: number;\n        fetchedAt: number;\n      };\n      // this case we already have this entity in store\n      if (inStoreEntity && (inStoreMeta = storeEntityMeta[schemaKey][id])) {\n        entities[schemaKey][id] = schema.mergeWithStore(\n          inStoreMeta,\n          meta,\n          inStoreEntity,\n          processedEntity,\n        );\n        storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore(\n          inStoreMeta,\n          meta,\n          inStoreEntity,\n          processedEntity,\n        );\n      } else {\n        entities[schemaKey][id] = processedEntity;\n        storeEntityMeta[schemaKey][id] = {\n          expiresAt: meta.expiresAt,\n          date: meta.date,\n          fetchedAt: meta.fetchedAt,\n        };\n      }\n    }\n\n    // update index\n    if (schema.indexes) {\n      if (!(schemaKey in indexes)) {\n        indexes[schemaKey] = {};\n        storeIndexes[schemaKey] = { ...storeIndexes[schemaKey] };\n      }\n      handleIndexes(\n        id,\n        schema.indexes,\n        indexes[schemaKey],\n        storeIndexes[schemaKey],\n        entities[schemaKey][id],\n        storeEntities[schemaKey],\n      );\n    }\n    // set this after index updates so we know what indexes to remove from\n    storeEntities[schemaKey][id] = entities[schemaKey][id];\n  };\n\nfunction handleIndexes(\n  id: string,\n  schemaIndexes: string[],\n  indexes: Record<string, any>,\n  storeIndexes: Record<string, any>,\n  entity: any,\n  storeEntities: Record<string, any>,\n) {\n  for (const index of schemaIndexes) {\n    if (!(index in indexes)) {\n      storeIndexes[index] = indexes[index] = {};\n    }\n    const indexMap = indexes[index];\n    if (storeEntities[id]) {\n      delete indexMap[storeEntities[id][index]];\n    }\n    // entity already in cache but the index changed\n    if (\n      storeEntities &&\n      storeEntities[id] &&\n      storeEntities[id][index] !== entity[index]\n    ) {\n      indexMap[storeEntities[id][index]] = INVALID;\n    }\n    if (index in entity) {\n      indexMap[entity[index]] = id;\n    } /* istanbul ignore next */ else if (\n      // eslint-disable-next-line no-undef\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.warn(`Index not found in entity. Indexes must be top-level members of your entity.\nIndex: ${index}\nEntity: ${JSON.stringify(entity, undefined, 2)}`);\n    }\n  }\n}\n\nfunction expectedSchemaType(schema: Schema) {\n  return ['object', 'function'].includes(typeof schema)\n    ? 'object'\n    : typeof schema;\n}\n\n// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\nexport const normalize = <\n  S extends Schema = Schema,\n  E extends Record<string, Record<string, any> | undefined> = Record<\n    string,\n    Record<string, any>\n  >,\n  R = NormalizeNullable<S>,\n>(\n  input: any,\n  schema?: S,\n  args: any[] = [],\n  storeEntities: Readonly<E> = {} as any,\n  storeIndexes: Readonly<NormalizedIndex> = {},\n  storeEntityMeta: {\n    readonly [entityKey: string]: {\n      readonly [pk: string]: {\n        readonly date: number;\n        readonly expiresAt: number;\n        readonly fetchedAt: number;\n      };\n    };\n  } = {},\n  meta: { expiresAt: number; date: number; fetchedAt: number } = {\n    date: Date.now(),\n    expiresAt: Infinity,\n    fetchedAt: 0,\n  },\n): NormalizedSchema<E, R> => {\n  // no schema means we don't process at all\n  if (schema === undefined || schema === null)\n    return {\n      entities: storeEntities,\n      indexes: storeIndexes,\n      result: input,\n      entityMeta: storeEntityMeta,\n    };\n\n  const schemaType = expectedSchemaType(schema);\n  if (\n    input === null ||\n    (typeof input !== schemaType &&\n      // we will allow a Delete schema to be a string or object\n      !(\n        (schema as any).key !== undefined &&\n        (schema as any).pk === undefined &&\n        typeof input === 'string'\n      ))\n  ) {\n    /* istanbul ignore else */\n    if (process.env.NODE_ENV !== 'production') {\n      const parseWorks = (input: string) => {\n        try {\n          return typeof JSON.parse(input) !== 'string';\n        } catch (e) {\n          return false;\n        }\n      };\n      if (typeof input === 'string' && parseWorks(input)) {\n        throw new Error(`Normalizing a string, but this does match schema.\n\nParsing this input string as JSON worked. This likely indicates fetch function did not parse\nthe JSON. By default, this only happens if \"content-type\" header includes \"json\".\nSee https://dataclient.io/rest/api/RestEndpoint#parseResponse for more information\n\n  Schema: ${JSON.stringify(schema, undefined, 2)}\n  Input: \"${input}\"`);\n      } else {\n        throw new Error(\n          `Unexpected input given to normalize. Expected type to be \"${schemaType}\", found \"${\n            input === null ? 'null' : typeof input\n          }\".\n\n          Schema: ${JSON.stringify(schema, undefined, 2)}\n          Input: \"${input}\"`,\n        );\n      }\n    } else {\n      throw new Error(\n        `Unexpected input given to normalize. Expected type to be \"${schemaType}\", found \"${\n          input === null ? 'null' : typeof input\n        }\".`,\n      );\n    }\n  }\n\n  const newEntities: E = {} as any;\n  const newIndexes: NormalizedIndex = {} as any;\n  const entities: E = { ...storeEntities } as any;\n  const indexes: NormalizedIndex = { ...storeIndexes };\n  const entityMeta: any = { ...storeEntityMeta };\n  const addEntity = addEntities(\n    newEntities,\n    newIndexes,\n    entities,\n    indexes,\n    entityMeta,\n    meta,\n  );\n  const visitedEntities = {};\n\n  const result = visit(\n    input,\n    input,\n    undefined,\n    schema,\n    addEntity,\n    visitedEntities,\n    storeEntities,\n    args,\n  );\n  return { entities, indexes, result, entityMeta };\n};\n"],"mappings":"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"} |
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtcbiAgU2NoZW1hLFxuICBTZXJpYWxpemFibGUsXG4gIEVudGl0eUludGVyZmFjZSxcbiAgTm9ybWFsaXplZEluZGV4LFxuICBTY2hlbWFDbGFzcyxcbn0gZnJvbSAnLi9pbnRlcmZhY2UuanMnO1xuaW1wb3J0IHR5cGUgV2Vha0VudGl0eU1hcCBmcm9tICcuL1dlYWtFbnRpdHlNYXAuanMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBhdGgge1xuICBrZXk6IHN0cmluZztcbiAgcGs6IHN0cmluZztcbn1cblxuLy8gVHlwZVNjcmlwdCA8NC4yIEluc3RhbmNlVHlwZTw+IGRvZXMgbm90IHdvcmsgb24gYWJzdHJhY3QgY2xhc3Nlc1xuZXhwb3J0IHR5cGUgQWJzdHJhY3RJbnN0YW5jZVR5cGU8VD4gPSBUIGV4dGVuZHMgbmV3ICguLi5hcmdzOiBhbnkpID0+IGluZmVyIFVcbiAgPyBVXG4gIDogVCBleHRlbmRzIHsgcHJvdG90eXBlOiBpbmZlciBVIH1cbiAgPyBVXG4gIDogbmV2ZXI7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRFbnRpdHk8VD4gPSBUIGV4dGVuZHMge1xuICBwcm90b3R5cGU6IGluZmVyIFU7XG4gIHNjaGVtYTogaW5mZXIgUztcbn1cbiAgPyB7IFtLIGluIEV4Y2x1ZGU8a2V5b2YgVSwga2V5b2YgUz5dOiBVW0tdIH0gJiB7IFtLIGluIGtleW9mIFNdOiBzdHJpbmcgfVxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemU8U1tLXT4gOiBTW0tdO1xufTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVOdWxsYWJsZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemVOdWxsYWJsZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZU51bGxhYmxlPFNbS10+IDogU1tLXTtcbn07XG5cbmludGVyZmFjZSBOZXN0ZWRTY2hlbWFDbGFzczxUID0gYW55PiB7XG4gIHNjaGVtYTogUmVjb3JkPHN0cmluZywgU2NoZW1hPjtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlY29yZENsYXNzPFQgPSBhbnk+IGV4dGVuZHMgTmVzdGVkU2NoZW1hQ2xhc3M8VD4ge1xuICBmcm9tSlM6ICguLi5hcmdzOiBhbnkpID0+IEFic3RyYWN0SW5zdGFuY2VUeXBlPFQ+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlbm9ybWFsaXplQ2FjaGUge1xuICBlbnRpdGllczoge1xuICAgIFtrZXk6IHN0cmluZ106IHtcbiAgICAgIFtwazogc3RyaW5nXTogV2Vha01hcDxFbnRpdHlJbnRlcmZhY2UsIFdlYWtFbnRpdHlNYXA8b2JqZWN0LCBhbnk+PjtcbiAgICB9O1xuICB9O1xuICByZXN1bHRzOiB7XG4gICAgW2tleTogc3RyaW5nXTogV2Vha0VudGl0eU1hcDxvYmplY3QsIGFueT47XG4gIH07XG59XG5cbmV4cG9ydCB0eXBlIERlbm9ybWFsaXplTnVsbGFibGVOZXN0ZWRTY2hlbWE8UyBleHRlbmRzIE5lc3RlZFNjaGVtYUNsYXNzPiA9XG4gIGtleW9mIFNbJ3NjaGVtYSddIGV4dGVuZHMgbmV2ZXJcbiAgICA/IFNbJ3Byb3RvdHlwZSddIC8vIHRoaXMgaXMgdGhlIGNhc2Ugb2YgYSBub24tc2V0IHNjaGVtYSwgd2hpY2ggbWVhbnMgaXQgYWN0dWFsbHkgaGFzIG5vIG1lbWJlcnNcbiAgICA6IHN0cmluZyBleHRlbmRzIGtleW9mIFNbJ3NjaGVtYSddXG4gICAgPyBTWydwcm90b3R5cGUnXVxuICAgIDogU1sncHJvdG90eXBlJ10gLyomIHtcbiAgICAgICAgW0sgaW4ga2V5b2YgU1snc2NoZW1hJ11dOiBEZW5vcm1hbGl6ZU51bGxhYmxlPFNbJ3NjaGVtYSddW0tdPjtcbiAgICAgIH0qLztcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVSZXR1cm5UeXBlPFQ+ID0gVCBleHRlbmRzIChcbiAgaW5wdXQ6IGFueSxcbiAgdW52aXNpdDogYW55LFxuKSA9PiBbaW5mZXIgUiwgYW55LCBhbnldXG4gID8gUlxuICA6IG5ldmVyO1xuZXhwb3J0IHR5cGUgTm9ybWFsaXplUmV0dXJuVHlwZTxUPiA9IFQgZXh0ZW5kcyAoLi4uYXJnczogYW55KSA9PiBpbmZlciBSXG4gID8gUlxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2U8aW5mZXIgVT5cbiAgPyBVXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gQWJzdHJhY3RJbnN0YW5jZVR5cGU8Uz5cbiAgOiBTIGV4dGVuZHMgeyBkZW5vcm1hbGl6ZU9ubHk6ICguLi5hcmdzOiBhbnkpID0+IGFueSB9XG4gID8gUmV0dXJuVHlwZTxTWydkZW5vcm1hbGl6ZU9ubHknXT5cbiAgOiBTIGV4dGVuZHMgeyBkZW5vcm1hbGl6ZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBEZW5vcm1hbGl6ZVJldHVyblR5cGU8U1snZGVub3JtYWxpemUnXT5cbiAgOiBTIGV4dGVuZHMgU2VyaWFsaXphYmxlPGluZmVyIFQ+XG4gID8gVFxuICA6IFMgZXh0ZW5kcyBBcnJheTxpbmZlciBGPlxuICA/IERlbm9ybWFsaXplPEY+W11cbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBEZW5vcm1hbGl6ZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIERlbm9ybWFsaXplTnVsbGFibGU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlPGFueT5cbiAgPyBEZW5vcm1hbGl6ZU51bGxhYmxlTmVzdGVkU2NoZW1hPFM+IHwgdW5kZWZpbmVkXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gRGVub3JtYWxpemVOdWxsYWJsZU5lc3RlZFNjaGVtYTxTPlxuICA6IFMgZXh0ZW5kcyB7IF9kZW5vcm1hbGl6ZU51bGxhYmxlOiAoLi4uYXJnczogYW55KSA9PiBhbnkgfVxuICA/IERlbm9ybWFsaXplUmV0dXJuVHlwZTxTWydfZGVub3JtYWxpemVOdWxsYWJsZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gRGVub3JtYWxpemU8Rj5bXSB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IERlbm9ybWFsaXplTnVsbGFibGVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlXG4gID8gc3RyaW5nXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gTm9ybWFsaXplT2JqZWN0PFNbJ3NjaGVtYSddPlxuICA6IFMgZXh0ZW5kcyB7IG5vcm1hbGl6ZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBOb3JtYWxpemVSZXR1cm5UeXBlPFNbJ25vcm1hbGl6ZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gTm9ybWFsaXplPEY+W11cbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBOb3JtYWxpemVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVOdWxsYWJsZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2VcbiAgPyBzdHJpbmcgfCB1bmRlZmluZWRcbiAgOiBTIGV4dGVuZHMgUmVjb3JkQ2xhc3NcbiAgPyBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8U1snc2NoZW1hJ10+XG4gIDogUyBleHRlbmRzIHsgX25vcm1hbGl6ZU51bGxhYmxlOiAoLi4uYXJnczogYW55KSA9PiBhbnkgfVxuICA/IE5vcm1hbGl6ZVJldHVyblR5cGU8U1snX25vcm1hbGl6ZU51bGxhYmxlJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBOb3JtYWxpemU8Rj5bXSB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IE5vcm1hbGl6ZWROdWxsYWJsZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRTY2hlbWE8RSwgUj4gPSB7XG4gIGVudGl0aWVzOiBFO1xuICByZXN1bHQ6IFI7XG4gIGluZGV4ZXM6IE5vcm1hbGl6ZWRJbmRleDtcbiAgZW50aXR5TWV0YToge1xuICAgIHJlYWRvbmx5IFtlbnRpdHlLZXk6IHN0cmluZ106IHtcbiAgICAgIHJlYWRvbmx5IFtwazogc3RyaW5nXToge1xuICAgICAgICByZWFkb25seSBkYXRlOiBudW1iZXI7XG4gICAgICAgIHJlYWRvbmx5IGV4cGlyZXNBdDogbnVtYmVyO1xuICAgICAgICByZWFkb25seSBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgICAgIH07XG4gICAgfTtcbiAgfTtcbn07XG5cbmV4cG9ydCB0eXBlIEVudGl0eU1hcDxUID0gYW55PiA9IFJlY29yZDxzdHJpbmcsIEVudGl0eUludGVyZmFjZTxUPj47XG4iXSwibWFwcGluZ3MiOiIifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtcbiAgU2NoZW1hLFxuICBTZXJpYWxpemFibGUsXG4gIEVudGl0eUludGVyZmFjZSxcbiAgTm9ybWFsaXplZEluZGV4LFxuICBTY2hlbWFDbGFzcyxcbn0gZnJvbSAnLi9pbnRlcmZhY2UuanMnO1xuaW1wb3J0IHR5cGUgV2Vha0VudGl0eU1hcCBmcm9tICcuL1dlYWtFbnRpdHlNYXAuanMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBhdGgge1xuICBrZXk6IHN0cmluZztcbiAgcGs6IHN0cmluZztcbn1cblxuLy8gVHlwZVNjcmlwdCA8NC4yIEluc3RhbmNlVHlwZTw+IGRvZXMgbm90IHdvcmsgb24gYWJzdHJhY3QgY2xhc3Nlc1xuZXhwb3J0IHR5cGUgQWJzdHJhY3RJbnN0YW5jZVR5cGU8VD4gPSBUIGV4dGVuZHMgbmV3ICguLi5hcmdzOiBhbnkpID0+IGluZmVyIFVcbiAgPyBVXG4gIDogVCBleHRlbmRzIHsgcHJvdG90eXBlOiBpbmZlciBVIH1cbiAgPyBVXG4gIDogbmV2ZXI7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRFbnRpdHk8VD4gPSBUIGV4dGVuZHMge1xuICBwcm90b3R5cGU6IGluZmVyIFU7XG4gIHNjaGVtYTogaW5mZXIgUztcbn1cbiAgPyB7IFtLIGluIEV4Y2x1ZGU8a2V5b2YgVSwga2V5b2YgUz5dOiBVW0tdIH0gJiB7IFtLIGluIGtleW9mIFNdOiBzdHJpbmcgfVxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemU8U1tLXT4gOiBTW0tdO1xufTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVOdWxsYWJsZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemVOdWxsYWJsZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZU51bGxhYmxlPFNbS10+IDogU1tLXTtcbn07XG5cbmludGVyZmFjZSBOZXN0ZWRTY2hlbWFDbGFzczxUID0gYW55PiB7XG4gIHNjaGVtYTogUmVjb3JkPHN0cmluZywgU2NoZW1hPjtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlY29yZENsYXNzPFQgPSBhbnk+IGV4dGVuZHMgTmVzdGVkU2NoZW1hQ2xhc3M8VD4ge1xuICBmcm9tSlM6ICguLi5hcmdzOiBhbnkpID0+IEFic3RyYWN0SW5zdGFuY2VUeXBlPFQ+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlbm9ybWFsaXplQ2FjaGUge1xuICBlbnRpdGllczoge1xuICAgIFtrZXk6IHN0cmluZ106IHtcbiAgICAgIFtwazogc3RyaW5nXTogV2Vha01hcDxFbnRpdHlJbnRlcmZhY2UsIFdlYWtFbnRpdHlNYXA8b2JqZWN0LCBhbnk+PjtcbiAgICB9O1xuICB9O1xuICByZXN1bHRzOiB7XG4gICAgW2tleTogc3RyaW5nXTogV2Vha0VudGl0eU1hcDxvYmplY3QsIGFueT47XG4gIH07XG59XG5cbmV4cG9ydCB0eXBlIERlbm9ybWFsaXplTnVsbGFibGVOZXN0ZWRTY2hlbWE8UyBleHRlbmRzIE5lc3RlZFNjaGVtYUNsYXNzPiA9XG4gIGtleW9mIFNbJ3NjaGVtYSddIGV4dGVuZHMgbmV2ZXJcbiAgICA/IFNbJ3Byb3RvdHlwZSddIC8vIHRoaXMgaXMgdGhlIGNhc2Ugb2YgYSBub24tc2V0IHNjaGVtYSwgd2hpY2ggbWVhbnMgaXQgYWN0dWFsbHkgaGFzIG5vIG1lbWJlcnNcbiAgICA6IHN0cmluZyBleHRlbmRzIGtleW9mIFNbJ3NjaGVtYSddXG4gICAgPyBTWydwcm90b3R5cGUnXVxuICAgIDogU1sncHJvdG90eXBlJ10gLyomIHtcbiAgICAgICAgW0sgaW4ga2V5b2YgU1snc2NoZW1hJ11dOiBEZW5vcm1hbGl6ZU51bGxhYmxlPFNbJ3NjaGVtYSddW0tdPjtcbiAgICAgIH0qLztcblxuZXhwb3J0IHR5cGUgTm9ybWFsaXplUmV0dXJuVHlwZTxUPiA9IFQgZXh0ZW5kcyAoLi4uYXJnczogYW55KSA9PiBpbmZlciBSXG4gID8gUlxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2U8aW5mZXIgVT5cbiAgPyBVXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gQWJzdHJhY3RJbnN0YW5jZVR5cGU8Uz5cbiAgOiBTIGV4dGVuZHMgeyBkZW5vcm1hbGl6ZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBSZXR1cm5UeXBlPFNbJ2Rlbm9ybWFsaXplJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBEZW5vcm1hbGl6ZTxGPltdXG4gIDogUyBleHRlbmRzIHsgW0s6IHN0cmluZ106IGFueSB9XG4gID8gRGVub3JtYWxpemVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU51bGxhYmxlPFM+ID0gUyBleHRlbmRzIEVudGl0eUludGVyZmFjZTxhbnk+XG4gID8gRGVub3JtYWxpemVOdWxsYWJsZU5lc3RlZFNjaGVtYTxTPiB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyBSZWNvcmRDbGFzc1xuICA/IERlbm9ybWFsaXplTnVsbGFibGVOZXN0ZWRTY2hlbWE8Uz5cbiAgOiBTIGV4dGVuZHMgeyBfZGVub3JtYWxpemVOdWxsYWJsZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBSZXR1cm5UeXBlPFNbJ19kZW5vcm1hbGl6ZU51bGxhYmxlJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBEZW5vcm1hbGl6ZTxGPltdIHwgdW5kZWZpbmVkXG4gIDogUyBleHRlbmRzIHsgW0s6IHN0cmluZ106IGFueSB9XG4gID8gRGVub3JtYWxpemVOdWxsYWJsZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2VcbiAgPyBzdHJpbmdcbiAgOiBTIGV4dGVuZHMgUmVjb3JkQ2xhc3NcbiAgPyBOb3JtYWxpemVPYmplY3Q8U1snc2NoZW1hJ10+XG4gIDogUyBleHRlbmRzIHsgbm9ybWFsaXplOiAoLi4uYXJnczogYW55KSA9PiBhbnkgfVxuICA/IE5vcm1hbGl6ZVJldHVyblR5cGU8U1snbm9ybWFsaXplJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBOb3JtYWxpemU8Rj5bXVxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IE5vcm1hbGl6ZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZU51bGxhYmxlPFM+ID0gUyBleHRlbmRzIEVudGl0eUludGVyZmFjZVxuICA/IHN0cmluZyB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyBSZWNvcmRDbGFzc1xuICA/IE5vcm1hbGl6ZWROdWxsYWJsZU9iamVjdDxTWydzY2hlbWEnXT5cbiAgOiBTIGV4dGVuZHMgeyBfbm9ybWFsaXplTnVsbGFibGU6ICguLi5hcmdzOiBhbnkpID0+IGFueSB9XG4gID8gTm9ybWFsaXplUmV0dXJuVHlwZTxTWydfbm9ybWFsaXplTnVsbGFibGUnXT5cbiAgOiBTIGV4dGVuZHMgU2VyaWFsaXphYmxlPGluZmVyIFQ+XG4gID8gVFxuICA6IFMgZXh0ZW5kcyBBcnJheTxpbmZlciBGPlxuICA/IE5vcm1hbGl6ZTxGPltdIHwgdW5kZWZpbmVkXG4gIDogUyBleHRlbmRzIHsgW0s6IHN0cmluZ106IGFueSB9XG4gID8gTm9ybWFsaXplZE51bGxhYmxlT2JqZWN0PFM+XG4gIDogUztcblxuZXhwb3J0IHR5cGUgTm9ybWFsaXplZFNjaGVtYTxFLCBSPiA9IHtcbiAgZW50aXRpZXM6IEU7XG4gIHJlc3VsdDogUjtcbiAgaW5kZXhlczogTm9ybWFsaXplZEluZGV4O1xuICBlbnRpdHlNZXRhOiB7XG4gICAgcmVhZG9ubHkgW2VudGl0eUtleTogc3RyaW5nXToge1xuICAgICAgcmVhZG9ubHkgW3BrOiBzdHJpbmddOiB7XG4gICAgICAgIHJlYWRvbmx5IGRhdGU6IG51bWJlcjtcbiAgICAgICAgcmVhZG9ubHkgZXhwaXJlc0F0OiBudW1iZXI7XG4gICAgICAgIHJlYWRvbmx5IGZldGNoZWRBdDogbnVtYmVyO1xuICAgICAgfTtcbiAgICB9O1xuICB9O1xufTtcblxuZXhwb3J0IHR5cGUgRW50aXR5TWFwPFQgPSBhbnk+ID0gUmVjb3JkPHN0cmluZywgRW50aXR5SW50ZXJmYWNlPFQ+PjtcbiJdLCJtYXBwaW5ncyI6IiJ9 |
@@ -11,9 +11,4 @@ import { INVALID } from './symbol.js'; | ||
}); | ||
if (typeof entity === 'symbol') { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
return schema.denormalizeOnly(entity, args, unvisit); | ||
// TODO(breaking): Change to this as breaking change once we only support newer entities | ||
} else if (entity.toString().includes('DELETED')) { | ||
return INVALID; | ||
} | ||
if (typeof entity === 'symbol' && typeof schema.denormalize === 'function') { | ||
return schema.denormalize(entity, args, unvisit); | ||
} | ||
@@ -43,12 +38,4 @@ if (typeof entity !== 'object' || entity === null) { | ||
function unvisitEntityObject(entity, schema, unvisit, pk, localCacheKey, args) { | ||
let entityCopy, _, deleted; | ||
/* istanbul ignore else */ | ||
if (schema.createIfValid) { | ||
entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
// TODO(breaking): remove once old verions no longer supported | ||
} /* istanbul ignore next */else { | ||
entityCopy = entity; | ||
unvisit = withTrackedEntities(unvisit); | ||
unvisit.setLocal = entityCopy => localCacheKey[pk] = entityCopy; | ||
} | ||
let _, deleted; | ||
const entityCopy = localCacheKey[pk] = isImmutable(entity) ? schema.createIfValid(entity.toObject()) : schema.createIfValid(entity); | ||
if (entityCopy === undefined) { | ||
@@ -58,24 +45,8 @@ // undefined indicates we should suspense (perhaps failed validation) | ||
} else { | ||
if (typeof schema.denormalizeOnly === 'function') { | ||
localCacheKey[pk] = schema.denormalizeOnly(entityCopy, args, unvisit); | ||
} else { | ||
[localCacheKey[pk], _, deleted] = schema.denormalize(entityCopy, unvisit); | ||
if (deleted) localCacheKey[pk] = INVALID; | ||
if (typeof schema.denormalize === 'function') { | ||
localCacheKey[pk] = schema.denormalize(entityCopy, args, unvisit); | ||
} | ||
} | ||
} | ||
// TODO(breaking): remove once unused | ||
/* istanbul ignore next */ | ||
function withTrackedEntities(unvisit) { | ||
// every time we nest, we want to unwrap back to the top. | ||
// this is due to only needed the next level of nested entities for lookup | ||
const originalUnvisit = unvisit.og || unvisit; | ||
const wrappedUnvisit = (input, schema) => originalUnvisit(input, schema); | ||
wrappedUnvisit.og = unvisit; | ||
return wrappedUnvisit; | ||
} | ||
const getUnvisit = (getEntity, cache, args) => { | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
const unvisitAdapter = getUnvisitAdapter(unvisit); | ||
function unvisit(input, schema) { | ||
@@ -86,14 +57,11 @@ if (!schema) return input; | ||
} | ||
const hasDenormalize = typeof schema.denormalize === 'function' || typeof schema.denormalizeOnly === 'function'; | ||
const hasDenormalize = typeof schema.denormalize === 'function'; | ||
// deserialize fields (like Date) | ||
// deserialize fields (like Temporal.Instant) | ||
if (!hasDenormalize && typeof schema === 'function') { | ||
if (input instanceof schema) return input; | ||
if (input === undefined) return input; | ||
return new schema(input); | ||
return schema(input); | ||
} | ||
if (input === undefined) { | ||
var _schema$constructor; | ||
// TODO(breaking): Drop support for initial All version | ||
const isAll = ((_schema$constructor = schema.constructor) == null ? void 0 : _schema$constructor.name) === 'AllSchema'; | ||
const isAll = schema.constructor.name === 'AllSchema'; | ||
return isAll ? INVALID : undefined; | ||
@@ -106,10 +74,6 @@ } | ||
if (isEntity(schema)) { | ||
return unvisitEntity(input, schema, args, schema.denormalizeOnly ? unvisit : unvisitAdapter, getEntity, cache); | ||
return unvisitEntity(input, schema, args, unvisit, getEntity, cache); | ||
} | ||
if (hasDenormalize) { | ||
if (schema.denormalizeOnly) { | ||
return schema.denormalizeOnly(input, args, unvisit); | ||
} else { | ||
return denormalizeLegacySchema(schema, input, unvisitAdapter); | ||
} | ||
return schema.denormalize(input, args, unvisit); | ||
} | ||
@@ -126,26 +90,2 @@ return input; | ||
export default getUnvisit; | ||
function denormalizeLegacySchema(schema, input, unvisitAdapter) { | ||
const [data, _, suspend] = schema.denormalize(input, unvisitAdapter); | ||
// TODO(breaking): Drop support for initial Query version | ||
// queryEndpoint schema only overrides 'denormalize' and 'infer' | ||
const isQuery = !Object.hasOwn(schema, 'normalize') && Object.hasOwn(schema, 'denormalize') && Object.hasOwn(schema, 'infer'); | ||
return suspend && !isQuery ? INVALID : data; | ||
} | ||
// TODO(breaking): This handles legacy schemas from 3.7 and below | ||
function getUnvisitAdapter(unvisit) { | ||
return function (input, schema) { | ||
var _schema$constructor2; | ||
const isAll = (schema == null ? void 0 : (_schema$constructor2 = schema.constructor) == null ? void 0 : _schema$constructor2.name) === 'AllSchema'; | ||
const value = unvisit(input, schema); | ||
// TODO(breaking): Drop support for initial All version | ||
if (isAll) { | ||
// we swap 'found' and 'suspend' because the initial Query version used 'found' to determine whether | ||
// it should 'process' | ||
return [typeof value === 'symbol' ? undefined : value, typeof value !== 'symbol', false]; | ||
} | ||
return [typeof value === 'symbol' ? undefined : value, true, typeof value === 'symbol']; | ||
}; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["INVALID","isEntity","denormalize","arrayDenormalize","isImmutable","objectDenormalize","unvisitEntity","entityOrId","schema","args","unvisit","getEntity","cache","entity","key","pk","denormalizeOnly","toString","includes","toJS","undefined","noCacheGetEntity","localCacheKey","unvisitEntityObject","computeValue","entityCopy","_","deleted","createIfValid","toObject","withTrackedEntities","setLocal","originalUnvisit","og","wrappedUnvisit","input","getUnvisit","unvisitAdapter","getUnvisitAdapter","hasDenormalize","_schema$constructor","isAll","constructor","name","method","Array","isArray","denormalizeLegacySchema","cachable","Object","getResults","data","suspend","isQuery","hasOwn","_schema$constructor2","value"],"sources":["../../src/denormalize/unvisit.ts"],"sourcesContent":["import type Cache from './cache.js';\nimport { INVALID } from './symbol.js';\nimport type { EntityInterface, UnvisitFunction } from '../interface.js';\nimport { isEntity } from '../isEntity.js';\nimport { denormalize as arrayDenormalize } from '../schemas/Array.js';\nimport { isImmutable } from '../schemas/ImmutableUtils.js';\nimport { denormalize as objectDenormalize } from '../schemas/Object.js';\nimport type { Path } from '../types.js';\nimport { type GetEntity } from '../WeakEntityMap.js';\n\nfunction unvisitEntity(\n  entityOrId: Record<string, any> | string,\n  schema: EntityInterface,\n  args: readonly any[],\n  unvisit: UnvisitFunction,\n  getEntity: GetEntity,\n  cache: Cache,\n): object | undefined | symbol {\n  const entity =\n    typeof entityOrId === 'object'\n      ? entityOrId\n      : getEntity({ key: schema.key, pk: entityOrId });\n  if (typeof entity === 'symbol') {\n    if (typeof schema.denormalizeOnly === 'function') {\n      return schema.denormalizeOnly(entity, args, unvisit);\n      // TODO(breaking): Change to this as breaking change once we only support newer entities\n    } else if ((entity as symbol).toString().includes('DELETED')) {\n      return INVALID;\n    }\n  }\n\n  if (typeof entity !== 'object' || entity === null) {\n    return entity as any;\n  }\n\n  const pk =\n    // normalize must always place a string, because pk() return value is string | undefined\n    // therefore no need to check for numbers\n    typeof entityOrId === 'string'\n      ? entityOrId\n      : schema.pk(\n          isImmutable(entity) ? (entity as any).toJS() : entity,\n          undefined,\n          undefined,\n          args,\n        );\n\n  // if we can't generate a working pk we cannot do cache lookups properly,\n  // so simply denormalize without caching\n  if (pk === undefined || pk === '' || pk === 'undefined') {\n    return noCacheGetEntity(localCacheKey =>\n      unvisitEntityObject(entity, schema, unvisit, '', localCacheKey, args),\n    );\n  }\n\n  // last function computes if it is not in any caches\n  return cache.getEntity(pk, schema, entity, localCacheKey =>\n    unvisitEntityObject(entity, schema, unvisit, pk, localCacheKey, args),\n  );\n}\n\nfunction noCacheGetEntity(\n  computeValue: (localCacheKey: Record<string, any>) => void,\n): object | undefined | symbol {\n  const localCacheKey = {};\n  computeValue(localCacheKey);\n\n  return localCacheKey[''];\n}\n\nfunction unvisitEntityObject(\n  entity: object,\n  schema: EntityInterface<any>,\n  unvisit: UnvisitFunction,\n  pk: string,\n  localCacheKey: Record<string, any>,\n  args: readonly any[],\n): void {\n  let entityCopy: any, _, deleted;\n  /* istanbul ignore else */\n  if (schema.createIfValid) {\n    entityCopy = localCacheKey[pk] = isImmutable(entity)\n      ? schema.createIfValid(entity.toObject())\n      : schema.createIfValid(entity);\n    // TODO(breaking): remove once old verions no longer supported\n  } /* istanbul ignore next */ else {\n    entityCopy = entity;\n    unvisit = withTrackedEntities(unvisit);\n    unvisit.setLocal = entityCopy => (localCacheKey[pk] = entityCopy);\n  }\n\n  if (entityCopy === undefined) {\n    // undefined indicates we should suspense (perhaps failed validation)\n    localCacheKey[pk] = INVALID;\n  } else {\n    if (typeof schema.denormalizeOnly === 'function') {\n      localCacheKey[pk] = schema.denormalizeOnly(entityCopy, args, unvisit);\n    } else {\n      [localCacheKey[pk], _, deleted] = (schema as any).denormalize(\n        entityCopy,\n        unvisit,\n      );\n      if (deleted) localCacheKey[pk] = INVALID;\n    }\n  }\n}\n\n// TODO(breaking): remove once unused\n/* istanbul ignore next */\nfunction withTrackedEntities(unvisit: UnvisitFunction): UnvisitFunction {\n  // every time we nest, we want to unwrap back to the top.\n  // this is due to only needed the next level of nested entities for lookup\n  const originalUnvisit = unvisit.og || unvisit;\n  const wrappedUnvisit = (input: any, schema: any) =>\n    originalUnvisit(input, schema);\n  wrappedUnvisit.og = unvisit;\n  return wrappedUnvisit;\n}\n\nconst getUnvisit = (\n  getEntity: GetEntity,\n  cache: Cache,\n  args: readonly any[],\n) => {\n  // TODO(breaking): This handles legacy schemas from 3.7 and below\n  const unvisitAdapter = getUnvisitAdapter(unvisit);\n\n  function unvisit(input: any, schema: any): any {\n    if (!schema) return input;\n\n    if (input === null) {\n      return input;\n    }\n\n    const hasDenormalize =\n      typeof schema.denormalize === 'function' ||\n      typeof schema.denormalizeOnly === 'function';\n\n    // deserialize fields (like Date)\n    if (!hasDenormalize && typeof schema === 'function') {\n      if (input instanceof schema) return input;\n      if (input === undefined) return input;\n      return new schema(input);\n    }\n\n    if (input === undefined) {\n      // TODO(breaking): Drop support for initial All version\n      const isAll = schema.constructor?.name === 'AllSchema';\n\n      return isAll ? INVALID : undefined;\n    }\n\n    if (!hasDenormalize && typeof schema === 'object') {\n      const method = Array.isArray(schema)\n        ? arrayDenormalize\n        : objectDenormalize;\n      return method(schema, input, args, unvisit);\n    }\n\n    if (isEntity(schema)) {\n      return unvisitEntity(\n        input,\n        schema,\n        args,\n        schema.denormalizeOnly ? unvisit : unvisitAdapter,\n        getEntity,\n        cache,\n      );\n    }\n\n    if (hasDenormalize) {\n      if (schema.denormalizeOnly) {\n        return schema.denormalizeOnly(input, args, unvisit);\n      } else {\n        return denormalizeLegacySchema(schema, input, unvisitAdapter);\n      }\n    }\n\n    return input;\n  }\n\n  return (input: any, schema: any): { data: any; paths: Path[] } => {\n    // in the case where WeakMap cannot be used\n    // this test ensures null is properly excluded from WeakMap\n    const cachable = Object(input) === input && Object(schema) === schema;\n    return cache.getResults(input, cachable, () => unvisit(input, schema));\n  };\n};\nexport default getUnvisit;\n\nfunction denormalizeLegacySchema(\n  schema: any,\n  input: any,\n  unvisitAdapter: (input: any, schema: any) => [any, boolean, boolean],\n) {\n  const [data, _, suspend] = schema.denormalize(input, unvisitAdapter);\n  // TODO(breaking): Drop support for initial Query version\n  // queryEndpoint schema only overrides 'denormalize' and 'infer'\n  const isQuery =\n    !Object.hasOwn(schema, 'normalize') &&\n    Object.hasOwn(schema, 'denormalize') &&\n    Object.hasOwn(schema, 'infer');\n  return suspend && !isQuery ? INVALID : data;\n}\n\n// TODO(breaking): This handles legacy schemas from 3.7 and below\nfunction getUnvisitAdapter(unvisit) {\n  return function (input: any, schema: any): [any, boolean, boolean] {\n    const isAll = schema?.constructor?.name === 'AllSchema';\n    const value = unvisit(input, schema);\n\n    // TODO(breaking): Drop support for initial All version\n    if (isAll) {\n      // we swap 'found' and 'suspend' because the initial Query version used 'found' to determine whether\n      // it should 'process'\n      return [\n        typeof value === 'symbol' ? undefined : value,\n        typeof value !== 'symbol',\n        false,\n      ];\n    }\n    return [\n      typeof value === 'symbol' ? undefined : value,\n      true,\n      typeof value === 'symbol',\n    ];\n  };\n}\n"],"mappings":"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"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["INVALID","isEntity","denormalize","arrayDenormalize","isImmutable","objectDenormalize","unvisitEntity","entityOrId","schema","args","unvisit","getEntity","cache","entity","key","pk","toJS","undefined","noCacheGetEntity","localCacheKey","unvisitEntityObject","computeValue","_","deleted","entityCopy","createIfValid","toObject","getUnvisit","input","hasDenormalize","isAll","constructor","name","method","Array","isArray","cachable","Object","getResults"],"sources":["../../src/denormalize/unvisit.ts"],"sourcesContent":["import type Cache from './cache.js';\nimport { INVALID } from './symbol.js';\nimport type { EntityInterface } from '../interface.js';\nimport { isEntity } from '../isEntity.js';\nimport { denormalize as arrayDenormalize } from '../schemas/Array.js';\nimport { isImmutable } from '../schemas/ImmutableUtils.js';\nimport { denormalize as objectDenormalize } from '../schemas/Object.js';\nimport type { Path } from '../types.js';\nimport { type GetEntity } from '../WeakEntityMap.js';\n\nfunction unvisitEntity(\n  entityOrId: Record<string, any> | string,\n  schema: EntityInterface,\n  args: readonly any[],\n  unvisit: (input: any, schema: any) => any,\n  getEntity: GetEntity,\n  cache: Cache,\n): object | undefined | symbol {\n  const entity =\n    typeof entityOrId === 'object'\n      ? entityOrId\n      : getEntity({ key: schema.key, pk: entityOrId });\n  if (typeof entity === 'symbol' && typeof schema.denormalize === 'function') {\n    return schema.denormalize(entity, args, unvisit);\n  }\n\n  if (typeof entity !== 'object' || entity === null) {\n    return entity as any;\n  }\n\n  const pk =\n    // normalize must always place a string, because pk() return value is string | undefined\n    // therefore no need to check for numbers\n    typeof entityOrId === 'string'\n      ? entityOrId\n      : schema.pk(\n          isImmutable(entity) ? (entity as any).toJS() : entity,\n          undefined,\n          undefined,\n          args,\n        );\n\n  // if we can't generate a working pk we cannot do cache lookups properly,\n  // so simply denormalize without caching\n  if (pk === undefined || pk === '' || pk === 'undefined') {\n    return noCacheGetEntity(localCacheKey =>\n      unvisitEntityObject(entity, schema, unvisit, '', localCacheKey, args),\n    );\n  }\n\n  // last function computes if it is not in any caches\n  return cache.getEntity(pk, schema, entity, localCacheKey =>\n    unvisitEntityObject(entity, schema, unvisit, pk, localCacheKey, args),\n  );\n}\n\nfunction noCacheGetEntity(\n  computeValue: (localCacheKey: Record<string, any>) => void,\n): object | undefined | symbol {\n  const localCacheKey = {};\n  computeValue(localCacheKey);\n\n  return localCacheKey[''];\n}\n\nfunction unvisitEntityObject(\n  entity: object,\n  schema: EntityInterface<any>,\n  unvisit: (input: any, schema: any) => any,\n  pk: string,\n  localCacheKey: Record<string, any>,\n  args: readonly any[],\n): void {\n  let _, deleted;\n  const entityCopy = (localCacheKey[pk] = isImmutable(entity)\n    ? schema.createIfValid(entity.toObject())\n    : schema.createIfValid(entity));\n\n  if (entityCopy === undefined) {\n    // undefined indicates we should suspense (perhaps failed validation)\n    localCacheKey[pk] = INVALID;\n  } else {\n    if (typeof schema.denormalize === 'function') {\n      localCacheKey[pk] = schema.denormalize(entityCopy, args, unvisit);\n    }\n  }\n}\n\nconst getUnvisit = (\n  getEntity: GetEntity,\n  cache: Cache,\n  args: readonly any[],\n) => {\n  function unvisit(input: any, schema: any): any {\n    if (!schema) return input;\n\n    if (input === null) {\n      return input;\n    }\n\n    const hasDenormalize = typeof schema.denormalize === 'function';\n\n    // deserialize fields (like Temporal.Instant)\n    if (!hasDenormalize && typeof schema === 'function') {\n      if (input === undefined) return input;\n      return schema(input);\n    }\n\n    if (input === undefined) {\n      const isAll = schema.constructor.name === 'AllSchema';\n\n      return isAll ? INVALID : undefined;\n    }\n\n    if (!hasDenormalize && typeof schema === 'object') {\n      const method = Array.isArray(schema)\n        ? arrayDenormalize\n        : objectDenormalize;\n      return method(schema, input, args, unvisit);\n    }\n\n    if (isEntity(schema)) {\n      return unvisitEntity(input, schema, args, unvisit, getEntity, cache);\n    }\n\n    if (hasDenormalize) {\n      return schema.denormalize(input, args, unvisit);\n    }\n\n    return input;\n  }\n\n  return (input: any, schema: any): { data: any; paths: Path[] } => {\n    // in the case where WeakMap cannot be used\n    // this test ensures null is properly excluded from WeakMap\n    const cachable = Object(input) === input && Object(schema) === schema;\n    return cache.getResults(input, cachable, () => unvisit(input, schema));\n  };\n};\nexport default getUnvisit;\n"],"mappings":"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"} |
@@ -7,10 +7,8 @@ import { denormalize } from './denormalize/denormalize.js'; | ||
export { default as inferResults, validateInference } from './inferResults.js'; | ||
export { DELETED } from './special.js'; | ||
export type { AbstractInstanceType, NormalizeReturnType, NormalizedSchema, DenormalizeReturnType, DenormalizeCache, Path, } from './types.js'; | ||
export type { AbstractInstanceType, NormalizeReturnType, NormalizedSchema, DenormalizeCache, Path, Denormalize, DenormalizeNullable, Normalize, NormalizeNullable, } from './types.js'; | ||
export * from './endpoint/types.js'; | ||
export * from './interface.js'; | ||
export * from './Expiry.js'; | ||
export * from './normal.js'; | ||
export { INVALID } from './denormalize/symbol.js'; | ||
export { denormalize, denormalizeCached, normalize, isEntity, WeakEntityMap }; | ||
//# sourceMappingURL=index.d.ts.map |
@@ -10,9 +10,7 @@ Object.hasOwn = Object.hasOwn || /* istanbul ignore next */function hasOwn(it, key) { | ||
export { default as inferResults, validateInference } from './inferResults.js'; | ||
export { DELETED } from './special.js'; | ||
export * from './endpoint/types.js'; | ||
export * from './interface.js'; | ||
export * from './Expiry.js'; | ||
export * from './normal.js'; | ||
export { INVALID } from './denormalize/symbol.js'; | ||
export { denormalize, denormalizeCached, normalize, isEntity, WeakEntityMap }; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPYmplY3QiLCJoYXNPd24iLCJpdCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImRlbm9ybWFsaXplIiwiZGVub3JtYWxpemVDYWNoZWQiLCJpc0VudGl0eSIsIm5vcm1hbGl6ZSIsIldlYWtFbnRpdHlNYXAiLCJkZWZhdWx0IiwiaW5mZXJSZXN1bHRzIiwidmFsaWRhdGVJbmZlcmVuY2UiLCJERUxFVEVEIiwiSU5WQUxJRCJdLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJPYmplY3QuaGFzT3duID1cbiAgT2JqZWN0Lmhhc093biB8fFxuICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqLyBmdW5jdGlvbiBoYXNPd24oaXQsIGtleSkge1xuICAgIHJldHVybiBPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwoaXQsIGtleSk7XG4gIH07XG5pbXBvcnQgeyBkZW5vcm1hbGl6ZSB9IGZyb20gJy4vZGVub3JtYWxpemUvZGVub3JtYWxpemUuanMnO1xuaW1wb3J0IHsgZGVub3JtYWxpemUgYXMgZGVub3JtYWxpemVDYWNoZWQgfSBmcm9tICcuL2Rlbm9ybWFsaXplL2Rlbm9ybWFsaXplQ2FjaGVkLmpzJztcbmltcG9ydCB7IGlzRW50aXR5IH0gZnJvbSAnLi9pc0VudGl0eS5qcyc7XG5pbXBvcnQgeyBub3JtYWxpemUgfSBmcm9tICcuL25vcm1hbGl6ZS5qcyc7XG5pbXBvcnQgV2Vha0VudGl0eU1hcCBmcm9tICcuL1dlYWtFbnRpdHlNYXAuanMnO1xuZXhwb3J0IHsgZGVmYXVsdCBhcyBpbmZlclJlc3VsdHMsIHZhbGlkYXRlSW5mZXJlbmNlIH0gZnJvbSAnLi9pbmZlclJlc3VsdHMuanMnO1xuZXhwb3J0IHsgREVMRVRFRCB9IGZyb20gJy4vc3BlY2lhbC5qcyc7XG5cbmV4cG9ydCB0eXBlIHtcbiAgQWJzdHJhY3RJbnN0YW5jZVR5cGUsXG4gIE5vcm1hbGl6ZVJldHVyblR5cGUsXG4gIE5vcm1hbGl6ZWRTY2hlbWEsXG4gIERlbm9ybWFsaXplUmV0dXJuVHlwZSxcbiAgRGVub3JtYWxpemVDYWNoZSxcbiAgUGF0aCxcbn0gZnJvbSAnLi90eXBlcy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2VuZHBvaW50L3R5cGVzLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vRXhwaXJ5LmpzJztcbmV4cG9ydCAqIGZyb20gJy4vbm9ybWFsLmpzJztcbmV4cG9ydCB7IElOVkFMSUQgfSBmcm9tICcuL2Rlbm9ybWFsaXplL3N5bWJvbC5qcyc7XG5cbmV4cG9ydCB7IGRlbm9ybWFsaXplLCBkZW5vcm1hbGl6ZUNhY2hlZCwgbm9ybWFsaXplLCBpc0VudGl0eSwgV2Vha0VudGl0eU1hcCB9O1xuIl0sIm1hcHBpbmdzIjoiQUFBQUEsTUFBTSxDQUFDQyxNQUFNLEdBQ1hELE1BQU0sQ0FBQ0MsTUFBTSxJQUNiLDBCQUEyQixTQUFTQSxNQUFNQSxDQUFDQyxFQUFFLEVBQUVDLEdBQUcsRUFBRTtFQUNsRCxPQUFPSCxNQUFNLENBQUNJLFNBQVMsQ0FBQ0MsY0FBYyxDQUFDQyxJQUFJLENBQUNKLEVBQUUsRUFBRUMsR0FBRyxDQUFDO0FBQ3RELENBQUM7QUFDSCxTQUFTSSxXQUFXLFFBQVEsOEJBQThCO0FBQzFELFNBQVNBLFdBQVcsSUFBSUMsaUJBQWlCLFFBQVEsb0NBQW9DO0FBQ3JGLFNBQVNDLFFBQVEsUUFBUSxlQUFlO0FBQ3hDLFNBQVNDLFNBQVMsUUFBUSxnQkFBZ0I7QUFDMUMsT0FBT0MsYUFBYSxNQUFNLG9CQUFvQjtBQUM5QyxTQUFTQyxPQUFPLElBQUlDLFlBQVksRUFBRUMsaUJBQWlCLFFBQVEsbUJBQW1CO0FBQzlFLFNBQVNDLE9BQU8sUUFBUSxjQUFjO0FBVXRDLGNBQWMscUJBQXFCO0FBQ25DLGNBQWMsZ0JBQWdCO0FBQzlCLGNBQWMsYUFBYTtBQUMzQixjQUFjLGFBQWE7QUFDM0IsU0FBU0MsT0FBTyxRQUFRLHlCQUF5QjtBQUVqRCxTQUFTVCxXQUFXLEVBQUVDLGlCQUFpQixFQUFFRSxTQUFTLEVBQUVELFFBQVEsRUFBRUUsYUFBYSJ9 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJPYmplY3QiLCJoYXNPd24iLCJpdCIsImtleSIsInByb3RvdHlwZSIsImhhc093blByb3BlcnR5IiwiY2FsbCIsImRlbm9ybWFsaXplIiwiZGVub3JtYWxpemVDYWNoZWQiLCJpc0VudGl0eSIsIm5vcm1hbGl6ZSIsIldlYWtFbnRpdHlNYXAiLCJkZWZhdWx0IiwiaW5mZXJSZXN1bHRzIiwidmFsaWRhdGVJbmZlcmVuY2UiLCJJTlZBTElEIl0sInNvdXJjZXMiOlsiLi4vc3JjL2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbIk9iamVjdC5oYXNPd24gPVxuICBPYmplY3QuaGFzT3duIHx8XG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovIGZ1bmN0aW9uIGhhc093bihpdCwga2V5KSB7XG4gICAgcmV0dXJuIE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChpdCwga2V5KTtcbiAgfTtcbmltcG9ydCB7IGRlbm9ybWFsaXplIH0gZnJvbSAnLi9kZW5vcm1hbGl6ZS9kZW5vcm1hbGl6ZS5qcyc7XG5pbXBvcnQgeyBkZW5vcm1hbGl6ZSBhcyBkZW5vcm1hbGl6ZUNhY2hlZCB9IGZyb20gJy4vZGVub3JtYWxpemUvZGVub3JtYWxpemVDYWNoZWQuanMnO1xuaW1wb3J0IHsgaXNFbnRpdHkgfSBmcm9tICcuL2lzRW50aXR5LmpzJztcbmltcG9ydCB7IG5vcm1hbGl6ZSB9IGZyb20gJy4vbm9ybWFsaXplLmpzJztcbmltcG9ydCBXZWFrRW50aXR5TWFwIGZyb20gJy4vV2Vha0VudGl0eU1hcC5qcyc7XG5leHBvcnQgeyBkZWZhdWx0IGFzIGluZmVyUmVzdWx0cywgdmFsaWRhdGVJbmZlcmVuY2UgfSBmcm9tICcuL2luZmVyUmVzdWx0cy5qcyc7XG5cbmV4cG9ydCB0eXBlIHtcbiAgQWJzdHJhY3RJbnN0YW5jZVR5cGUsXG4gIE5vcm1hbGl6ZVJldHVyblR5cGUsXG4gIE5vcm1hbGl6ZWRTY2hlbWEsXG4gIERlbm9ybWFsaXplQ2FjaGUsXG4gIFBhdGgsXG4gIERlbm9ybWFsaXplLFxuICBEZW5vcm1hbGl6ZU51bGxhYmxlLFxuICBOb3JtYWxpemUsXG4gIE5vcm1hbGl6ZU51bGxhYmxlLFxufSBmcm9tICcuL3R5cGVzLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vZW5kcG9pbnQvdHlwZXMuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnRlcmZhY2UuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9FeHBpcnkuanMnO1xuZXhwb3J0IHsgSU5WQUxJRCB9IGZyb20gJy4vZGVub3JtYWxpemUvc3ltYm9sLmpzJztcblxuZXhwb3J0IHsgZGVub3JtYWxpemUsIGRlbm9ybWFsaXplQ2FjaGVkLCBub3JtYWxpemUsIGlzRW50aXR5LCBXZWFrRW50aXR5TWFwIH07XG4iXSwibWFwcGluZ3MiOiJBQUFBQSxNQUFNLENBQUNDLE1BQU0sR0FDWEQsTUFBTSxDQUFDQyxNQUFNLElBQ2IsMEJBQTJCLFNBQVNBLE1BQU1BLENBQUNDLEVBQUUsRUFBRUMsR0FBRyxFQUFFO0VBQ2xELE9BQU9ILE1BQU0sQ0FBQ0ksU0FBUyxDQUFDQyxjQUFjLENBQUNDLElBQUksQ0FBQ0osRUFBRSxFQUFFQyxHQUFHLENBQUM7QUFDdEQsQ0FBQztBQUNILFNBQVNJLFdBQVcsUUFBUSw4QkFBOEI7QUFDMUQsU0FBU0EsV0FBVyxJQUFJQyxpQkFBaUIsUUFBUSxvQ0FBb0M7QUFDckYsU0FBU0MsUUFBUSxRQUFRLGVBQWU7QUFDeEMsU0FBU0MsU0FBUyxRQUFRLGdCQUFnQjtBQUMxQyxPQUFPQyxhQUFhLE1BQU0sb0JBQW9CO0FBQzlDLFNBQVNDLE9BQU8sSUFBSUMsWUFBWSxFQUFFQyxpQkFBaUIsUUFBUSxtQkFBbUI7QUFhOUUsY0FBYyxxQkFBcUI7QUFDbkMsY0FBYyxnQkFBZ0I7QUFDOUIsY0FBYyxhQUFhO0FBQzNCLFNBQVNDLE9BQU8sUUFBUSx5QkFBeUI7QUFFakQsU0FBU1IsV0FBVyxFQUFFQyxpQkFBaUIsRUFBRUUsU0FBUyxFQUFFRCxRQUFRLEVBQUVFLGFBQWEifQ== |
@@ -1,2 +0,1 @@ | ||
import { isEntity } from './isEntity.js'; | ||
import { infer as arrayInfer } from './schemas/Array.js'; | ||
@@ -11,9 +10,3 @@ import { infer as objectInfer } from './schemas/Object.js'; | ||
if (canInfer(schema)) { | ||
var _entities$schema$key; | ||
const ret = schema.infer(args, indexes, inferResults, entities); | ||
// TODO(breaking): back compatibility with endpoint@3.7 and less | ||
if (isEntity(schema) && ret !== undefined && !((_entities$schema$key = entities[schema.key]) != null && _entities$schema$key[ret])) { | ||
return undefined; | ||
} | ||
return ret; | ||
return schema.infer(args, indexes, inferResults, entities); | ||
} | ||
@@ -42,2 +35,2 @@ | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpc0VudGl0eSIsImluZmVyIiwiYXJyYXlJbmZlciIsIm9iamVjdEluZmVyIiwiaW5mZXJSZXN1bHRzIiwic2NoZW1hIiwiYXJncyIsImluZGV4ZXMiLCJlbnRpdGllcyIsImNhbkluZmVyIiwiX2VudGl0aWVzJHNjaGVtYSRrZXkiLCJyZXQiLCJ1bmRlZmluZWQiLCJrZXkiLCJtZXRob2QiLCJBcnJheSIsImlzQXJyYXkiLCJ2YWxpZGF0ZUluZmVyZW5jZSIsInJlc3VsdHMiLCJPYmplY3QiLCJ2YWx1ZXMiLCJldmVyeSJdLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmZlclJlc3VsdHMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1xuICBTY2hlbWEsXG4gIFNjaGVtYVNpbXBsZSxcbiAgTm9ybWFsaXplZEluZGV4LFxuICBFbnRpdHlUYWJsZSxcbn0gZnJvbSAnLi9pbnRlcmZhY2UuanMnO1xuaW1wb3J0IHsgaXNFbnRpdHkgfSBmcm9tICcuL2lzRW50aXR5LmpzJztcbmltcG9ydCB7IGluZmVyIGFzIGFycmF5SW5mZXIgfSBmcm9tICcuL3NjaGVtYXMvQXJyYXkuanMnO1xuaW1wb3J0IHsgaW5mZXIgYXMgb2JqZWN0SW5mZXIgfSBmcm9tICcuL3NjaGVtYXMvT2JqZWN0LmpzJztcbmltcG9ydCB0eXBlIHsgTm9ybWFsaXplTnVsbGFibGUgfSBmcm9tICcuL3R5cGVzLmpzJztcblxuLyoqXG4gKiBCdWlsZCB0aGUgcmVzdWx0IHBhcmFtZXRlciB0byBkZW5vcm1hbGl6ZSBmcm9tIHNjaGVtYSBhbG9uZS5cbiAqIFRyaWVzIHRvIGNvbXB1dGUgdGhlIGVudGl0eSBpZHMgZnJvbSBwYXJhbXMuXG4gKi9cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGluZmVyUmVzdWx0czxTIGV4dGVuZHMgU2NoZW1hPihcbiAgc2NoZW1hOiBTLFxuICBhcmdzOiBhbnlbXSxcbiAgaW5kZXhlczogTm9ybWFsaXplZEluZGV4LFxuICBlbnRpdGllczogRW50aXR5VGFibGUsXG4pOiBOb3JtYWxpemVOdWxsYWJsZTxTPiB7XG4gIC8vIHNjaGVtYSBjbGFzc2VzXG4gIGlmIChjYW5JbmZlcihzY2hlbWEpKSB7XG4gICAgY29uc3QgcmV0ID0gc2NoZW1hLmluZmVyKGFyZ3MsIGluZGV4ZXMsIGluZmVyUmVzdWx0cywgZW50aXRpZXMpO1xuICAgIC8vIFRPRE8oYnJlYWtpbmcpOiBiYWNrIGNvbXBhdGliaWxpdHkgd2l0aCBlbmRwb2ludEAzLjcgYW5kIGxlc3NcbiAgICBpZiAoaXNFbnRpdHkoc2NoZW1hKSAmJiByZXQgIT09IHVuZGVmaW5lZCAmJiAhZW50aXRpZXNbc2NoZW1hLmtleV0/LltyZXRdKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkIGFzIGFueTtcbiAgICB9XG4gICAgcmV0dXJuIHJldDtcbiAgfVxuXG4gIC8vIHBsYWluIGNhc2VcbiAgaWYgKHR5cGVvZiBzY2hlbWEgPT09ICdvYmplY3QnICYmIHNjaGVtYSkge1xuICAgIGNvbnN0IG1ldGhvZCA9IEFycmF5LmlzQXJyYXkoc2NoZW1hKSA/IGFycmF5SW5mZXIgOiBvYmplY3RJbmZlcjtcbiAgICByZXR1cm4gbWV0aG9kKHNjaGVtYSwgYXJncywgaW5kZXhlcywgaW5mZXJSZXN1bHRzLCBlbnRpdGllcyk7XG4gIH1cblxuICAvLyBmYWxsYmFjayBmb3IgdGhpbmdzIGxpa2UgbnVsbCBvciB1bmRlZmluZWRcbiAgcmV0dXJuIHNjaGVtYSBhcyBhbnk7XG59XG5cbmZ1bmN0aW9uIGNhbkluZmVyKHNjaGVtYTogU2NoZW1hKTogc2NoZW1hIGlzIFBpY2s8U2NoZW1hU2ltcGxlLCAnaW5mZXInPiB7XG4gIHJldHVybiAhIXNjaGVtYSAmJiB0eXBlb2YgKHNjaGVtYSBhcyBhbnkpLmluZmVyID09PSAnZnVuY3Rpb24nO1xufVxuXG4vLyB0aGlzIG9ubHkgd29ya3MgaWYgZW50aXR5IGRvZXMgYSBsb29rdXAgZmlyc3QgdG8gc2VlIGlmIGl0cyBlbnRpdHkgaXMgJ2ZvdW5kJ1xuZXhwb3J0IGZ1bmN0aW9uIHZhbGlkYXRlSW5mZXJlbmNlKHJlc3VsdHM6IHVua25vd24pIHtcbiAgaWYgKHJlc3VsdHMgPT09IHVuZGVmaW5lZCkgcmV0dXJuIGZhbHNlO1xuICBpZiAocmVzdWx0cyAmJiB0eXBlb2YgcmVzdWx0cyA9PT0gJ29iamVjdCcgJiYgIUFycmF5LmlzQXJyYXkocmVzdWx0cykpIHtcbiAgICByZXR1cm4gT2JqZWN0LnZhbHVlcyhyZXN1bHRzKS5ldmVyeSh2YWxpZGF0ZUluZmVyZW5jZSk7XG4gIH1cbiAgcmV0dXJuIHRydWU7XG59XG4iXSwibWFwcGluZ3MiOiJBQU1BLFNBQVNBLFFBQVEsUUFBUSxlQUFlO0FBQ3hDLFNBQVNDLEtBQUssSUFBSUMsVUFBVSxRQUFRLG9CQUFvQjtBQUN4RCxTQUFTRCxLQUFLLElBQUlFLFdBQVcsUUFBUSxxQkFBcUI7QUFHMUQ7QUFDQTtBQUNBO0FBQ0E7QUFDQSxlQUFlLFNBQVNDLFlBQVlBLENBQ2xDQyxNQUFTLEVBQ1RDLElBQVcsRUFDWEMsT0FBd0IsRUFDeEJDLFFBQXFCLEVBQ0M7RUFDdEI7RUFDQSxJQUFJQyxRQUFRLENBQUNKLE1BQU0sQ0FBQyxFQUFFO0lBQUEsSUFBQUssb0JBQUE7SUFDcEIsTUFBTUMsR0FBRyxHQUFHTixNQUFNLENBQUNKLEtBQUssQ0FBQ0ssSUFBSSxFQUFFQyxPQUFPLEVBQUVILFlBQVksRUFBRUksUUFBUSxDQUFDO0lBQy9EO0lBQ0EsSUFBSVIsUUFBUSxDQUFDSyxNQUFNLENBQUMsSUFBSU0sR0FBRyxLQUFLQyxTQUFTLElBQUksR0FBQUYsb0JBQUEsR0FBQ0YsUUFBUSxDQUFDSCxNQUFNLENBQUNRLEdBQUcsQ0FBQyxhQUFwQkgsb0JBQUEsQ0FBdUJDLEdBQUcsQ0FBQyxHQUFFO01BQ3pFLE9BQU9DLFNBQVM7SUFDbEI7SUFDQSxPQUFPRCxHQUFHO0VBQ1o7O0VBRUE7RUFDQSxJQUFJLE9BQU9OLE1BQU0sS0FBSyxRQUFRLElBQUlBLE1BQU0sRUFBRTtJQUN4QyxNQUFNUyxNQUFNLEdBQUdDLEtBQUssQ0FBQ0MsT0FBTyxDQUFDWCxNQUFNLENBQUMsR0FBR0gsVUFBVSxHQUFHQyxXQUFXO0lBQy9ELE9BQU9XLE1BQU0sQ0FBQ1QsTUFBTSxFQUFFQyxJQUFJLEVBQUVDLE9BQU8sRUFBRUgsWUFBWSxFQUFFSSxRQUFRLENBQUM7RUFDOUQ7O0VBRUE7RUFDQSxPQUFPSCxNQUFNO0FBQ2Y7QUFFQSxTQUFTSSxRQUFRQSxDQUFDSixNQUFjLEVBQXlDO0VBQ3ZFLE9BQU8sQ0FBQyxDQUFDQSxNQUFNLElBQUksT0FBUUEsTUFBTSxDQUFTSixLQUFLLEtBQUssVUFBVTtBQUNoRTs7QUFFQTtBQUNBLE9BQU8sU0FBU2dCLGlCQUFpQkEsQ0FBQ0MsT0FBZ0IsRUFBRTtFQUNsRCxJQUFJQSxPQUFPLEtBQUtOLFNBQVMsRUFBRSxPQUFPLEtBQUs7RUFDdkMsSUFBSU0sT0FBTyxJQUFJLE9BQU9BLE9BQU8sS0FBSyxRQUFRLElBQUksQ0FBQ0gsS0FBSyxDQUFDQyxPQUFPLENBQUNFLE9BQU8sQ0FBQyxFQUFFO0lBQ3JFLE9BQU9DLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDRixPQUFPLENBQUMsQ0FBQ0csS0FBSyxDQUFDSixpQkFBaUIsQ0FBQztFQUN4RDtFQUNBLE9BQU8sSUFBSTtBQUNiIn0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJpbmZlciIsImFycmF5SW5mZXIiLCJvYmplY3RJbmZlciIsImluZmVyUmVzdWx0cyIsInNjaGVtYSIsImFyZ3MiLCJpbmRleGVzIiwiZW50aXRpZXMiLCJjYW5JbmZlciIsIm1ldGhvZCIsIkFycmF5IiwiaXNBcnJheSIsInZhbGlkYXRlSW5mZXJlbmNlIiwicmVzdWx0cyIsInVuZGVmaW5lZCIsIk9iamVjdCIsInZhbHVlcyIsImV2ZXJ5Il0sInNvdXJjZXMiOlsiLi4vc3JjL2luZmVyUmVzdWx0cy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIFNjaGVtYSxcbiAgU2NoZW1hU2ltcGxlLFxuICBOb3JtYWxpemVkSW5kZXgsXG4gIEVudGl0eVRhYmxlLFxufSBmcm9tICcuL2ludGVyZmFjZS5qcyc7XG5pbXBvcnQgeyBpbmZlciBhcyBhcnJheUluZmVyIH0gZnJvbSAnLi9zY2hlbWFzL0FycmF5LmpzJztcbmltcG9ydCB7IGluZmVyIGFzIG9iamVjdEluZmVyIH0gZnJvbSAnLi9zY2hlbWFzL09iamVjdC5qcyc7XG5pbXBvcnQgdHlwZSB7IE5vcm1hbGl6ZU51bGxhYmxlIH0gZnJvbSAnLi90eXBlcy5qcyc7XG5cbi8qKlxuICogQnVpbGQgdGhlIHJlc3VsdCBwYXJhbWV0ZXIgdG8gZGVub3JtYWxpemUgZnJvbSBzY2hlbWEgYWxvbmUuXG4gKiBUcmllcyB0byBjb21wdXRlIHRoZSBlbnRpdHkgaWRzIGZyb20gcGFyYW1zLlxuICovXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBpbmZlclJlc3VsdHM8UyBleHRlbmRzIFNjaGVtYT4oXG4gIHNjaGVtYTogUyxcbiAgYXJnczogYW55W10sXG4gIGluZGV4ZXM6IE5vcm1hbGl6ZWRJbmRleCxcbiAgZW50aXRpZXM6IEVudGl0eVRhYmxlLFxuKTogTm9ybWFsaXplTnVsbGFibGU8Uz4ge1xuICAvLyBzY2hlbWEgY2xhc3Nlc1xuICBpZiAoY2FuSW5mZXIoc2NoZW1hKSkge1xuICAgIHJldHVybiBzY2hlbWEuaW5mZXIoYXJncywgaW5kZXhlcywgaW5mZXJSZXN1bHRzLCBlbnRpdGllcyk7XG4gIH1cblxuICAvLyBwbGFpbiBjYXNlXG4gIGlmICh0eXBlb2Ygc2NoZW1hID09PSAnb2JqZWN0JyAmJiBzY2hlbWEpIHtcbiAgICBjb25zdCBtZXRob2QgPSBBcnJheS5pc0FycmF5KHNjaGVtYSkgPyBhcnJheUluZmVyIDogb2JqZWN0SW5mZXI7XG4gICAgcmV0dXJuIG1ldGhvZChzY2hlbWEsIGFyZ3MsIGluZGV4ZXMsIGluZmVyUmVzdWx0cywgZW50aXRpZXMpO1xuICB9XG5cbiAgLy8gZmFsbGJhY2sgZm9yIHRoaW5ncyBsaWtlIG51bGwgb3IgdW5kZWZpbmVkXG4gIHJldHVybiBzY2hlbWEgYXMgYW55O1xufVxuXG5mdW5jdGlvbiBjYW5JbmZlcihzY2hlbWE6IFNjaGVtYSk6IHNjaGVtYSBpcyBQaWNrPFNjaGVtYVNpbXBsZSwgJ2luZmVyJz4ge1xuICByZXR1cm4gISFzY2hlbWEgJiYgdHlwZW9mIChzY2hlbWEgYXMgYW55KS5pbmZlciA9PT0gJ2Z1bmN0aW9uJztcbn1cblxuLy8gdGhpcyBvbmx5IHdvcmtzIGlmIGVudGl0eSBkb2VzIGEgbG9va3VwIGZpcnN0IHRvIHNlZSBpZiBpdHMgZW50aXR5IGlzICdmb3VuZCdcbmV4cG9ydCBmdW5jdGlvbiB2YWxpZGF0ZUluZmVyZW5jZShyZXN1bHRzOiB1bmtub3duKSB7XG4gIGlmIChyZXN1bHRzID09PSB1bmRlZmluZWQpIHJldHVybiBmYWxzZTtcbiAgaWYgKHJlc3VsdHMgJiYgdHlwZW9mIHJlc3VsdHMgPT09ICdvYmplY3QnICYmICFBcnJheS5pc0FycmF5KHJlc3VsdHMpKSB7XG4gICAgcmV0dXJuIE9iamVjdC52YWx1ZXMocmVzdWx0cykuZXZlcnkodmFsaWRhdGVJbmZlcmVuY2UpO1xuICB9XG4gIHJldHVybiB0cnVlO1xufVxuIl0sIm1hcHBpbmdzIjoiQUFNQSxTQUFTQSxLQUFLLElBQUlDLFVBQVUsUUFBUSxvQkFBb0I7QUFDeEQsU0FBU0QsS0FBSyxJQUFJRSxXQUFXLFFBQVEscUJBQXFCO0FBRzFEO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsZUFBZSxTQUFTQyxZQUFZQSxDQUNsQ0MsTUFBUyxFQUNUQyxJQUFXLEVBQ1hDLE9BQXdCLEVBQ3hCQyxRQUFxQixFQUNDO0VBQ3RCO0VBQ0EsSUFBSUMsUUFBUSxDQUFDSixNQUFNLENBQUMsRUFBRTtJQUNwQixPQUFPQSxNQUFNLENBQUNKLEtBQUssQ0FBQ0ssSUFBSSxFQUFFQyxPQUFPLEVBQUVILFlBQVksRUFBRUksUUFBUSxDQUFDO0VBQzVEOztFQUVBO0VBQ0EsSUFBSSxPQUFPSCxNQUFNLEtBQUssUUFBUSxJQUFJQSxNQUFNLEVBQUU7SUFDeEMsTUFBTUssTUFBTSxHQUFHQyxLQUFLLENBQUNDLE9BQU8sQ0FBQ1AsTUFBTSxDQUFDLEdBQUdILFVBQVUsR0FBR0MsV0FBVztJQUMvRCxPQUFPTyxNQUFNLENBQUNMLE1BQU0sRUFBRUMsSUFBSSxFQUFFQyxPQUFPLEVBQUVILFlBQVksRUFBRUksUUFBUSxDQUFDO0VBQzlEOztFQUVBO0VBQ0EsT0FBT0gsTUFBTTtBQUNmO0FBRUEsU0FBU0ksUUFBUUEsQ0FBQ0osTUFBYyxFQUF5QztFQUN2RSxPQUFPLENBQUMsQ0FBQ0EsTUFBTSxJQUFJLE9BQVFBLE1BQU0sQ0FBU0osS0FBSyxLQUFLLFVBQVU7QUFDaEU7O0FBRUE7QUFDQSxPQUFPLFNBQVNZLGlCQUFpQkEsQ0FBQ0MsT0FBZ0IsRUFBRTtFQUNsRCxJQUFJQSxPQUFPLEtBQUtDLFNBQVMsRUFBRSxPQUFPLEtBQUs7RUFDdkMsSUFBSUQsT0FBTyxJQUFJLE9BQU9BLE9BQU8sS0FBSyxRQUFRLElBQUksQ0FBQ0gsS0FBSyxDQUFDQyxPQUFPLENBQUNFLE9BQU8sQ0FBQyxFQUFFO0lBQ3JFLE9BQU9FLE1BQU0sQ0FBQ0MsTUFBTSxDQUFDSCxPQUFPLENBQUMsQ0FBQ0ksS0FBSyxDQUFDTCxpQkFBaUIsQ0FBQztFQUN4RDtFQUNBLE9BQU8sSUFBSTtBQUNiIn0= |
@@ -8,9 +8,6 @@ export type Schema = null | string | { | ||
toJSON(): string; | ||
}> = { | ||
prototype: T; | ||
}; | ||
}> = (value: any) => T; | ||
export interface SchemaSimple<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; | ||
denormalize?(input: {}, unvisit: UnvisitFunction): [denormalized: T, found: boolean, suspend: boolean]; | ||
denormalizeOnly?(input: {}, args: any, unvisit: (input: any, schema: any) => any): T; | ||
denormalize(input: {}, args: any, unvisit: (input: any, schema: any) => any): T; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
@@ -20,15 +17,11 @@ } | ||
_normalizeNullable(): any; | ||
_denormalizeNullable(): [N, boolean, boolean]; | ||
_denormalizeNullable(): N; | ||
} | ||
export interface EntityInterface<T = any> extends SchemaSimple { | ||
createIfValid?(props: any): any; | ||
createIfValid(props: any): any; | ||
pk(params: any, parent?: any, key?: string, args?: readonly any[]): string | undefined; | ||
readonly key: string; | ||
merge(existing: any, incoming: any): any; | ||
/** @deprecated use mergeWithStore instead (which can call this) */ | ||
expiresAt?(meta: any, input: any): number; | ||
mergeWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
mergeMetaWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
/** @deprecated use mergeWithStore instead (which can call this) */ | ||
useIncoming?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): boolean; | ||
mergeWithStore(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
mergeMetaWithStore(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
indexes?: any; | ||
@@ -39,7 +32,2 @@ schema: Record<string, Schema>; | ||
} | ||
export interface UnvisitFunction { | ||
(input: any, schema: any): [any, boolean, boolean] | any; | ||
og?: UnvisitFunction; | ||
setLocal?: (entity: any) => void; | ||
} | ||
export interface NormalizedIndex { | ||
@@ -46,0 +34,0 @@ readonly [entityKey: string]: { |
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2ludGVyZmFjZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBTY2hlbWEgPVxuICB8IG51bGxcbiAgfCBzdHJpbmdcbiAgfCB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICB8IFNjaGVtYVtdXG4gIHwgU2NoZW1hU2ltcGxlXG4gIHwgU2VyaWFsaXphYmxlO1xuXG5leHBvcnQgdHlwZSBTZXJpYWxpemFibGU8XG4gIFQgZXh0ZW5kcyB7IHRvSlNPTigpOiBzdHJpbmcgfSA9IHsgdG9KU09OKCk6IHN0cmluZyB9LFxuPiA9IHtcbiAgcHJvdG90eXBlOiBUO1xufTtcblxuZXhwb3J0IGludGVyZmFjZSBTY2hlbWFTaW1wbGU8VCA9IGFueT4ge1xuICBub3JtYWxpemUoXG4gICAgaW5wdXQ6IGFueSxcbiAgICBwYXJlbnQ6IGFueSxcbiAgICBrZXk6IGFueSxcbiAgICB2aXNpdDogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIGFkZEVudGl0eTogKC4uLmFyZ3M6IGFueSkgPT4gYW55LFxuICAgIHZpc2l0ZWRFbnRpdGllczogUmVjb3JkPHN0cmluZywgYW55PixcbiAgICBzdG9yZUVudGl0aWVzPzogYW55LFxuICAgIGFyZ3M/OiBhbnlbXSxcbiAgKTogYW55O1xuICBkZW5vcm1hbGl6ZT8oXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9iYW4tdHlwZXNcbiAgICBpbnB1dDoge30sXG4gICAgdW52aXNpdDogVW52aXNpdEZ1bmN0aW9uLFxuICApOiBbZGVub3JtYWxpemVkOiBULCBmb3VuZDogYm9vbGVhbiwgc3VzcGVuZDogYm9vbGVhbl07XG4gIGRlbm9ybWFsaXplT25seT8oXG4gICAgaW5wdXQ6IHt9LFxuICAgIGFyZ3M6IGFueSxcbiAgICB1bnZpc2l0OiAoaW5wdXQ6IGFueSwgc2NoZW1hOiBhbnkpID0+IGFueSxcbiAgKTogVDtcbiAgaW5mZXIoXG4gICAgYXJnczogcmVhZG9ubHkgYW55W10sXG4gICAgaW5kZXhlczogTm9ybWFsaXplZEluZGV4LFxuICAgIHJlY3Vyc2U6ICguLi5hcmdzOiBhbnkpID0+IGFueSxcbiAgICBlbnRpdGllczogRW50aXR5VGFibGUsXG4gICk6IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTY2hlbWFDbGFzczxUID0gYW55LCBOID0gVCB8IHVuZGVmaW5lZD5cbiAgZXh0ZW5kcyBTY2hlbWFTaW1wbGU8VD4ge1xuICAvLyB0aGlzIGlzIG5vdCBhbiBhY3R1YWwgbWVtYmVyLCBidXQgaXMgbmVlZGVkIGZvciB0aGUgcmVjdXJzaXZlIE5vcm1hbGl6ZU51bGxhYmxlPD4gdHlwZSBhbGdvXG4gIF9ub3JtYWxpemVOdWxsYWJsZSgpOiBhbnk7XG4gIC8vIHRoaXMgaXMgbm90IGFuIGFjdHVhbCBtZW1iZXIsIGJ1dCBpcyBuZWVkZWQgZm9yIHRoZSByZWN1cnNpdmUgRGVub3JtYWxpemVOdWxsYWJsZTw+IHR5cGUgYWxnb1xuICBfZGVub3JtYWxpemVOdWxsYWJsZSgpOiBbTiwgYm9vbGVhbiwgYm9vbGVhbl07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW50aXR5SW50ZXJmYWNlPFQgPSBhbnk+IGV4dGVuZHMgU2NoZW1hU2ltcGxlIHtcbiAgY3JlYXRlSWZWYWxpZD8ocHJvcHM6IGFueSk6IGFueTtcbiAgcGsoXG4gICAgcGFyYW1zOiBhbnksXG4gICAgcGFyZW50PzogYW55LFxuICAgIGtleT86IHN0cmluZyxcbiAgICBhcmdzPzogcmVhZG9ubHkgYW55W10sXG4gICk6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgcmVhZG9ubHkga2V5OiBzdHJpbmc7XG4gIG1lcmdlKGV4aXN0aW5nOiBhbnksIGluY29taW5nOiBhbnkpOiBhbnk7XG4gIC8qKiBAZGVwcmVjYXRlZCB1c2UgbWVyZ2VXaXRoU3RvcmUgaW5zdGVhZCAod2hpY2ggY2FuIGNhbGwgdGhpcykgKi9cbiAgZXhwaXJlc0F0PyhtZXRhOiBhbnksIGlucHV0OiBhbnkpOiBudW1iZXI7XG4gIG1lcmdlV2l0aFN0b3JlPyhcbiAgICBleGlzdGluZ01ldGE6IGFueSxcbiAgICBpbmNvbWluZ01ldGE6IGFueSxcbiAgICBleGlzdGluZzogYW55LFxuICAgIGluY29taW5nOiBhbnksXG4gICk6IGFueTtcbiAgbWVyZ2VNZXRhV2l0aFN0b3JlPyhcbiAgICBleGlzdGluZ01ldGE6IGFueSxcbiAgICBpbmNvbWluZ01ldGE6IGFueSxcbiAgICBleGlzdGluZzogYW55LFxuICAgIGluY29taW5nOiBhbnksXG4gICk6IGFueTtcbiAgLyoqIEBkZXByZWNhdGVkIHVzZSBtZXJnZVdpdGhTdG9yZSBpbnN0ZWFkICh3aGljaCBjYW4gY2FsbCB0aGlzKSAqL1xuICB1c2VJbmNvbWluZz8oXG4gICAgZXhpc3RpbmdNZXRhOiBhbnksXG4gICAgaW5jb21pbmdNZXRhOiBhbnksXG4gICAgZXhpc3Rpbmc6IGFueSxcbiAgICBpbmNvbWluZzogYW55LFxuICApOiBib29sZWFuO1xuICBpbmRleGVzPzogYW55O1xuICBzY2hlbWE6IFJlY29yZDxzdHJpbmcsIFNjaGVtYT47XG4gIGNhY2hlV2l0aD86IG9iamVjdDtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFVudmlzaXRGdW5jdGlvbiB7XG4gIChpbnB1dDogYW55LCBzY2hlbWE6IGFueSk6IFthbnksIGJvb2xlYW4sIGJvb2xlYW5dIHwgYW55O1xuICBvZz86IFVudmlzaXRGdW5jdGlvbjtcbiAgc2V0TG9jYWw/OiAoZW50aXR5OiBhbnkpID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgTm9ybWFsaXplZEluZGV4IHtcbiAgcmVhZG9ubHkgW2VudGl0eUtleTogc3RyaW5nXToge1xuICAgIHJlYWRvbmx5IFtpbmRleE5hbWU6IHN0cmluZ106IHsgcmVhZG9ubHkgW2xvb2t1cDogc3RyaW5nXTogc3RyaW5nIH07XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW50aXR5VGFibGUge1xuICBbZW50aXR5S2V5OiBzdHJpbmddOlxuICAgIHwge1xuICAgICAgICBbcGs6IHN0cmluZ106IHVua25vd247XG4gICAgICB9XG4gICAgfCB1bmRlZmluZWQ7XG59XG4iXSwibWFwcGluZ3MiOiIifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL2ludGVyZmFjZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBTY2hlbWEgPVxuICB8IG51bGxcbiAgfCBzdHJpbmdcbiAgfCB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICB8IFNjaGVtYVtdXG4gIHwgU2NoZW1hU2ltcGxlXG4gIHwgU2VyaWFsaXphYmxlO1xuXG5leHBvcnQgdHlwZSBTZXJpYWxpemFibGU8XG4gIFQgZXh0ZW5kcyB7IHRvSlNPTigpOiBzdHJpbmcgfSA9IHsgdG9KU09OKCk6IHN0cmluZyB9LFxuPiA9ICh2YWx1ZTogYW55KSA9PiBUO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVtYVNpbXBsZTxUID0gYW55PiB7XG4gIG5vcm1hbGl6ZShcbiAgICBpbnB1dDogYW55LFxuICAgIHBhcmVudDogYW55LFxuICAgIGtleTogYW55LFxuICAgIHZpc2l0OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgYWRkRW50aXR5OiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgdmlzaXRlZEVudGl0aWVzOiBSZWNvcmQ8c3RyaW5nLCBhbnk+LFxuICAgIHN0b3JlRW50aXRpZXM/OiBhbnksXG4gICAgYXJncz86IGFueVtdLFxuICApOiBhbnk7XG4gIGRlbm9ybWFsaXplKFxuICAgIGlucHV0OiB7fSxcbiAgICBhcmdzOiBhbnksXG4gICAgdW52aXNpdDogKGlucHV0OiBhbnksIHNjaGVtYTogYW55KSA9PiBhbnksXG4gICk6IFQ7XG4gIGluZmVyKFxuICAgIGFyZ3M6IHJlYWRvbmx5IGFueVtdLFxuICAgIGluZGV4ZXM6IE5vcm1hbGl6ZWRJbmRleCxcbiAgICByZWN1cnNlOiAoLi4uYXJnczogYW55KSA9PiBhbnksXG4gICAgZW50aXRpZXM6IEVudGl0eVRhYmxlLFxuICApOiBhbnk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZW1hQ2xhc3M8VCA9IGFueSwgTiA9IFQgfCB1bmRlZmluZWQ+XG4gIGV4dGVuZHMgU2NoZW1hU2ltcGxlPFQ+IHtcbiAgLy8gdGhpcyBpcyBub3QgYW4gYWN0dWFsIG1lbWJlciwgYnV0IGlzIG5lZWRlZCBmb3IgdGhlIHJlY3Vyc2l2ZSBOb3JtYWxpemVOdWxsYWJsZTw+IHR5cGUgYWxnb1xuICBfbm9ybWFsaXplTnVsbGFibGUoKTogYW55O1xuICAvLyB0aGlzIGlzIG5vdCBhbiBhY3R1YWwgbWVtYmVyLCBidXQgaXMgbmVlZGVkIGZvciB0aGUgcmVjdXJzaXZlIERlbm9ybWFsaXplTnVsbGFibGU8PiB0eXBlIGFsZ29cbiAgX2Rlbm9ybWFsaXplTnVsbGFibGUoKTogTjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbnRpdHlJbnRlcmZhY2U8VCA9IGFueT4gZXh0ZW5kcyBTY2hlbWFTaW1wbGUge1xuICBjcmVhdGVJZlZhbGlkKHByb3BzOiBhbnkpOiBhbnk7XG4gIHBrKFxuICAgIHBhcmFtczogYW55LFxuICAgIHBhcmVudD86IGFueSxcbiAgICBrZXk/OiBzdHJpbmcsXG4gICAgYXJncz86IHJlYWRvbmx5IGFueVtdLFxuICApOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIHJlYWRvbmx5IGtleTogc3RyaW5nO1xuICBtZXJnZShleGlzdGluZzogYW55LCBpbmNvbWluZzogYW55KTogYW55O1xuICBtZXJnZVdpdGhTdG9yZShcbiAgICBleGlzdGluZ01ldGE6IGFueSxcbiAgICBpbmNvbWluZ01ldGE6IGFueSxcbiAgICBleGlzdGluZzogYW55LFxuICAgIGluY29taW5nOiBhbnksXG4gICk6IGFueTtcbiAgbWVyZ2VNZXRhV2l0aFN0b3JlKFxuICAgIGV4aXN0aW5nTWV0YTogYW55LFxuICAgIGluY29taW5nTWV0YTogYW55LFxuICAgIGV4aXN0aW5nOiBhbnksXG4gICAgaW5jb21pbmc6IGFueSxcbiAgKTogYW55O1xuICBpbmRleGVzPzogYW55O1xuICBzY2hlbWE6IFJlY29yZDxzdHJpbmcsIFNjaGVtYT47XG4gIGNhY2hlV2l0aD86IG9iamVjdDtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE5vcm1hbGl6ZWRJbmRleCB7XG4gIHJlYWRvbmx5IFtlbnRpdHlLZXk6IHN0cmluZ106IHtcbiAgICByZWFkb25seSBbaW5kZXhOYW1lOiBzdHJpbmddOiB7IHJlYWRvbmx5IFtsb29rdXA6IHN0cmluZ106IHN0cmluZyB9O1xuICB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEVudGl0eVRhYmxlIHtcbiAgW2VudGl0eUtleTogc3RyaW5nXTpcbiAgICB8IHtcbiAgICAgICAgW3BrOiBzdHJpbmddOiB1bmtub3duO1xuICAgICAgfVxuICAgIHwgdW5kZWZpbmVkO1xufVxuIl0sIm1hcHBpbmdzIjoiIn0= |
@@ -0,4 +1,4 @@ | ||
import { INVALID } from './denormalize/symbol.js'; | ||
import { normalize as arrayNormalize } from './schemas/Array.js'; | ||
import { normalize as objectNormalize } from './schemas/Object.js'; | ||
import { DELETED } from './special.js'; | ||
const visit = (value, parent, key, schema, addEntity, visitedEntities, storeEntities, args) => { | ||
@@ -12,7 +12,2 @@ if (!value || !schema) { | ||
} | ||
// serializable | ||
if (typeof schema === 'function') { | ||
return new schema(value); | ||
} | ||
if (typeof value !== 'object' || typeof schema !== 'object') return value; | ||
@@ -41,9 +36,8 @@ const method = Array.isArray(schema) ? arrayNormalize : objectNormalize; | ||
if (inStoreEntity && (inStoreMeta = storeEntityMeta[schemaKey][id])) { | ||
entities[schemaKey][id] = schema.mergeWithStore ? schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore ? schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity) : mergeMetaWithStore(schema, inStoreMeta, meta, inStoreEntity, processedEntity); | ||
entities[schemaKey][id] = schema.mergeWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore(inStoreMeta, meta, inStoreEntity, processedEntity); | ||
} else { | ||
entities[schemaKey][id] = processedEntity; | ||
storeEntityMeta[schemaKey][id] = { | ||
// TODO(breaking): Remove schema.expiresat | ||
expiresAt: schema.expiresAt ? schema.expiresAt(meta, processedEntity) : meta.expiresAt, | ||
expiresAt: meta.expiresAt, | ||
date: meta.date, | ||
@@ -79,3 +73,3 @@ fetchedAt: meta.fetchedAt | ||
if (storeEntities && storeEntities[id] && storeEntities[id][index] !== entity[index]) { | ||
indexMap[storeEntities[id][index]] = DELETED; | ||
indexMap[storeEntities[id][index]] = INVALID; | ||
} | ||
@@ -93,29 +87,2 @@ if (index in entity) { | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeStore() instead */ | ||
function mergeWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
const useIncoming = | ||
// useIncoming should not be used with legacy optimistic | ||
schema.useIncoming && incomingMeta.fetchedAt ? schema.useIncoming(existingMeta, incomingMeta, existing, incoming) : existingMeta.date <= incomingMeta.date; | ||
if (useIncoming) { | ||
if (typeof incoming !== typeof existing) { | ||
return incoming; | ||
} else { | ||
return schema.merge(existing, incoming); | ||
} | ||
} else { | ||
return existing; | ||
} | ||
} | ||
// TODO(breaking): remove this in 1 breaking releases | ||
/** @deprecated use Entity.mergeMetaWithStore() instead */ | ||
function mergeMetaWithStore(schema, existingMeta, incomingMeta, existing, incoming) { | ||
return { | ||
expiresAt: Math.max(schema.expiresAt ? schema.expiresAt(incomingMeta, incoming) : incomingMeta.expiresAt, existingMeta.expiresAt), | ||
date: Math.max(incomingMeta.date, existingMeta.date), | ||
fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt) | ||
}; | ||
} | ||
function expectedSchemaType(schema) { | ||
@@ -156,3 +123,3 @@ return ['object', 'function'].includes(typeof schema) ? 'object' : typeof schema; | ||
the JSON. By default, this only happens if "content-type" header includes "json". | ||
See https://resthooks.io/rest/api/RestEndpoint#parseResponse for more information | ||
See https://dataclient.io/rest/api/RestEndpoint#parseResponse for more information | ||
@@ -192,2 +159,2 @@ Schema: ${JSON.stringify(schema, undefined, 2)} | ||
}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["normalize","arrayNormalize","objectNormalize","DELETED","visit","value","parent","key","schema","addEntity","visitedEntities","storeEntities","args","method","Array","isArray","addEntities","entities","indexes","storeIndexes","storeEntityMeta","meta","processedEntity","id","schemaKey","existingEntity","merge","inStoreEntity","inStoreMeta","mergeWithStore","mergeMetaWithStore","expiresAt","date","fetchedAt","handleIndexes","schemaIndexes","entity","index","indexMap","process","env","NODE_ENV","console","warn","JSON","stringify","undefined","existingMeta","incomingMeta","existing","incoming","useIncoming","Math","max","expectedSchemaType","includes","input","Date","now","Infinity","result","entityMeta","schemaType","pk","parseWorks","parse","e","Error","newEntities","newIndexes"],"sources":["../src/normalize.ts"],"sourcesContent":["import type { EntityInterface, Schema, NormalizedIndex } from './interface.js';\nimport { normalize as arrayNormalize } from './schemas/Array.js';\nimport { normalize as objectNormalize } from './schemas/Object.js';\nimport { DELETED } from './special.js';\nimport type { NormalizeNullable, NormalizedSchema } from './types.js';\n\nconst visit = (\n  value: any,\n  parent: any,\n  key: any,\n  schema: any,\n  addEntity: (\n    schema: EntityInterface,\n    processedEntity: any,\n    id: string,\n  ) => void,\n  visitedEntities: any,\n  storeEntities: any,\n  args: any[],\n) => {\n  if (!value || !schema) {\n    return value;\n  }\n\n  if (schema.normalize && typeof schema.normalize === 'function') {\n    if (typeof value !== 'object') return value;\n    return schema.normalize(\n      value,\n      parent,\n      key,\n      visit,\n      addEntity,\n      visitedEntities,\n      storeEntities,\n      args,\n    );\n  }\n\n  // serializable\n  if (typeof schema === 'function') {\n    return new schema(value);\n  }\n\n  if (typeof value !== 'object' || typeof schema !== 'object') return value;\n\n  const method = Array.isArray(schema) ? arrayNormalize : objectNormalize;\n  return method(\n    schema,\n    value,\n    parent,\n    key,\n    visit,\n    addEntity,\n    visitedEntities,\n    storeEntities,\n    args,\n  );\n};\n\nconst addEntities =\n  (\n    entities: Record<string, any>,\n    indexes: Record<string, any>,\n    storeEntities: Record<string, any>,\n    storeIndexes: Record<string, any>,\n    storeEntityMeta: {\n      [entityKey: string]: {\n        [pk: string]: {\n          date: number;\n          expiresAt: number;\n          fetchedAt: number;\n        };\n      };\n    },\n    meta: { expiresAt: number; date: number; fetchedAt: number },\n  ) =>\n  (schema: EntityInterface, processedEntity: any, id: string) => {\n    const schemaKey = schema.key;\n    if (!(schemaKey in entities)) {\n      entities[schemaKey] = {};\n      storeEntities[schemaKey] = { ...storeEntities[schemaKey] };\n      storeEntityMeta[schemaKey] = { ...storeEntityMeta[schemaKey] };\n    }\n\n    const existingEntity = entities[schemaKey][id];\n    if (existingEntity) {\n      entities[schemaKey][id] = schema.merge(existingEntity, processedEntity);\n    } else {\n      const inStoreEntity = storeEntities[schemaKey][id];\n      let inStoreMeta: {\n        date: number;\n        expiresAt: number;\n        fetchedAt: number;\n      };\n      // this case we already have this entity in store\n      if (inStoreEntity && (inStoreMeta = storeEntityMeta[schemaKey][id])) {\n        entities[schemaKey][id] = schema.mergeWithStore\n          ? schema.mergeWithStore(\n              inStoreMeta,\n              meta,\n              inStoreEntity,\n              processedEntity,\n            )\n          : mergeWithStore(\n              schema,\n              inStoreMeta,\n              meta,\n              inStoreEntity,\n              processedEntity,\n            );\n        storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore\n          ? schema.mergeMetaWithStore(\n              inStoreMeta,\n              meta,\n              inStoreEntity,\n              processedEntity,\n            )\n          : mergeMetaWithStore(\n              schema,\n              inStoreMeta,\n              meta,\n              inStoreEntity,\n              processedEntity,\n            );\n      } else {\n        entities[schemaKey][id] = processedEntity;\n        storeEntityMeta[schemaKey][id] = {\n          // TODO(breaking): Remove schema.expiresat\n          expiresAt: schema.expiresAt\n            ? schema.expiresAt(meta, processedEntity)\n            : meta.expiresAt,\n          date: meta.date,\n          fetchedAt: meta.fetchedAt,\n        };\n      }\n    }\n\n    // update index\n    if (schema.indexes) {\n      if (!(schemaKey in indexes)) {\n        indexes[schemaKey] = {};\n        storeIndexes[schemaKey] = { ...storeIndexes[schemaKey] };\n      }\n      handleIndexes(\n        id,\n        schema.indexes,\n        indexes[schemaKey],\n        storeIndexes[schemaKey],\n        entities[schemaKey][id],\n        storeEntities[schemaKey],\n      );\n    }\n    // set this after index updates so we know what indexes to remove from\n    storeEntities[schemaKey][id] = entities[schemaKey][id];\n  };\n\nfunction handleIndexes(\n  id: string,\n  schemaIndexes: string[],\n  indexes: Record<string, any>,\n  storeIndexes: Record<string, any>,\n  entity: any,\n  storeEntities: Record<string, any>,\n) {\n  for (const index of schemaIndexes) {\n    if (!(index in indexes)) {\n      storeIndexes[index] = indexes[index] = {};\n    }\n    const indexMap = indexes[index];\n    if (storeEntities[id]) {\n      delete indexMap[storeEntities[id][index]];\n    }\n    // entity already in cache but the index changed\n    if (\n      storeEntities &&\n      storeEntities[id] &&\n      storeEntities[id][index] !== entity[index]\n    ) {\n      indexMap[storeEntities[id][index]] = DELETED;\n    }\n    if (index in entity) {\n      indexMap[entity[index]] = id;\n    } /* istanbul ignore next */ else if (\n      // eslint-disable-next-line no-undef\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.warn(`Index not found in entity. Indexes must be top-level members of your entity.\nIndex: ${index}\nEntity: ${JSON.stringify(entity, undefined, 2)}`);\n    }\n  }\n}\n\n// TODO(breaking): remove this in 1 breaking releases\n/** @deprecated use Entity.mergeStore() instead */\nfunction mergeWithStore(\n  schema: EntityInterface<any>,\n  existingMeta: {\n    date: number;\n    expiresAt: number;\n    fetchedAt: number;\n  },\n  incomingMeta: {\n    expiresAt: number;\n    date: number;\n    fetchedAt?: number | undefined;\n  },\n  existing: any,\n  incoming: any,\n) {\n  const useIncoming =\n    // useIncoming should not be used with legacy optimistic\n    schema.useIncoming && incomingMeta.fetchedAt\n      ? schema.useIncoming(existingMeta, incomingMeta, existing, incoming)\n      : existingMeta.date <= incomingMeta.date;\n  if (useIncoming) {\n    if (typeof incoming !== typeof existing) {\n      return incoming;\n    } else {\n      return schema.merge(existing, incoming);\n    }\n  } else {\n    return existing;\n  }\n}\n\n// TODO(breaking): remove this in 1 breaking releases\n/** @deprecated use Entity.mergeMetaWithStore() instead */\nfunction mergeMetaWithStore(\n  schema: any,\n  existingMeta: {\n    date: number;\n    expiresAt: number;\n    fetchedAt: number;\n  },\n  incomingMeta: {\n    expiresAt: number;\n    date: number;\n    fetchedAt: number;\n  },\n  existing: any,\n  incoming: any,\n) {\n  return {\n    expiresAt: Math.max(\n      schema.expiresAt\n        ? schema.expiresAt(incomingMeta, incoming)\n        : incomingMeta.expiresAt,\n      existingMeta.expiresAt,\n    ),\n    date: Math.max(incomingMeta.date, existingMeta.date),\n    fetchedAt: Math.max(incomingMeta.fetchedAt, existingMeta.fetchedAt),\n  };\n}\n\nfunction expectedSchemaType(schema: Schema) {\n  return ['object', 'function'].includes(typeof schema)\n    ? 'object'\n    : typeof schema;\n}\n\n// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\nexport const normalize = <\n  S extends Schema = Schema,\n  E extends Record<string, Record<string, any> | undefined> = Record<\n    string,\n    Record<string, any>\n  >,\n  R = NormalizeNullable<S>,\n>(\n  input: any,\n  schema?: S,\n  args: any[] = [],\n  storeEntities: Readonly<E> = {} as any,\n  storeIndexes: Readonly<NormalizedIndex> = {},\n  storeEntityMeta: {\n    readonly [entityKey: string]: {\n      readonly [pk: string]: {\n        readonly date: number;\n        readonly expiresAt: number;\n        readonly fetchedAt: number;\n      };\n    };\n  } = {},\n  meta: { expiresAt: number; date: number; fetchedAt: number } = {\n    date: Date.now(),\n    expiresAt: Infinity,\n    fetchedAt: 0,\n  },\n): NormalizedSchema<E, R> => {\n  // no schema means we don't process at all\n  if (schema === undefined || schema === null)\n    return {\n      entities: storeEntities,\n      indexes: storeIndexes,\n      result: input,\n      entityMeta: storeEntityMeta,\n    };\n\n  const schemaType = expectedSchemaType(schema);\n  if (\n    input === null ||\n    (typeof input !== schemaType &&\n      // we will allow a Delete schema to be a string or object\n      !(\n        (schema as any).key !== undefined &&\n        (schema as any).pk === undefined &&\n        typeof input === 'string'\n      ))\n  ) {\n    /* istanbul ignore else */\n    if (process.env.NODE_ENV !== 'production') {\n      const parseWorks = (input: string) => {\n        try {\n          return typeof JSON.parse(input) !== 'string';\n        } catch (e) {\n          return false;\n        }\n      };\n      if (typeof input === 'string' && parseWorks(input)) {\n        throw new Error(`Normalizing a string, but this does match schema.\n\nParsing this input string as JSON worked. This likely indicates fetch function did not parse\nthe JSON. By default, this only happens if \"content-type\" header includes \"json\".\nSee https://resthooks.io/rest/api/RestEndpoint#parseResponse for more information\n\n  Schema: ${JSON.stringify(schema, undefined, 2)}\n  Input: \"${input}\"`);\n      } else {\n        throw new Error(\n          `Unexpected input given to normalize. Expected type to be \"${schemaType}\", found \"${\n            input === null ? 'null' : typeof input\n          }\".\n\n          Schema: ${JSON.stringify(schema, undefined, 2)}\n          Input: \"${input}\"`,\n        );\n      }\n    } else {\n      throw new Error(\n        `Unexpected input given to normalize. Expected type to be \"${schemaType}\", found \"${\n          input === null ? 'null' : typeof input\n        }\".`,\n      );\n    }\n  }\n\n  const newEntities: E = {} as any;\n  const newIndexes: NormalizedIndex = {} as any;\n  const entities: E = { ...storeEntities } as any;\n  const indexes: NormalizedIndex = { ...storeIndexes };\n  const entityMeta: any = { ...storeEntityMeta };\n  const addEntity = addEntities(\n    newEntities,\n    newIndexes,\n    entities,\n    indexes,\n    entityMeta,\n    meta,\n  );\n  const visitedEntities = {};\n\n  const result = visit(\n    input,\n    input,\n    undefined,\n    schema,\n    addEntity,\n    visitedEntities,\n    storeEntities,\n    args,\n  );\n  return { entities, indexes, result, entityMeta };\n};\n"],"mappings":"AACA,SAASA,SAAS,IAAIC,cAAc,QAAQ,oBAAoB;AAChE,SAASD,SAAS,IAAIE,eAAe,QAAQ,qBAAqB;AAClE,SAASC,OAAO,QAAQ,cAAc;AAGtC,MAAMC,KAAK,GAAGA,CACZC,KAAU,EACVC,MAAW,EACXC,GAAQ,EACRC,MAAW,EACXC,SAIS,EACTC,eAAoB,EACpBC,aAAkB,EAClBC,IAAW,KACR;EACH,IAAI,CAACP,KAAK,IAAI,CAACG,MAAM,EAAE;IACrB,OAAOH,KAAK;EACd;EAEA,IAAIG,MAAM,CAACR,SAAS,IAAI,OAAOQ,MAAM,CAACR,SAAS,KAAK,UAAU,EAAE;IAC9D,IAAI,OAAOK,KAAK,KAAK,QAAQ,EAAE,OAAOA,KAAK;IAC3C,OAAOG,MAAM,CAACR,SAAS,CACrBK,KAAK,EACLC,MAAM,EACNC,GAAG,EACHH,KAAK,EACLK,SAAS,EACTC,eAAe,EACfC,aAAa,EACbC,IACF,CAAC;EACH;;EAEA;EACA,IAAI,OAAOJ,MAAM,KAAK,UAAU,EAAE;IAChC,OAAO,IAAIA,MAAM,CAACH,KAAK,CAAC;EAC1B;EAEA,IAAI,OAAOA,KAAK,KAAK,QAAQ,IAAI,OAAOG,MAAM,KAAK,QAAQ,EAAE,OAAOH,KAAK;EAEzE,MAAMQ,MAAM,GAAGC,KAAK,CAACC,OAAO,CAACP,MAAM,CAAC,GAAGP,cAAc,GAAGC,eAAe;EACvE,OAAOW,MAAM,CACXL,MAAM,EACNH,KAAK,EACLC,MAAM,EACNC,GAAG,EACHH,KAAK,EACLK,SAAS,EACTC,eAAe,EACfC,aAAa,EACbC,IACF,CAAC;AACH,CAAC;AAED,MAAMI,WAAW,GACfA,CACEC,QAA6B,EAC7BC,OAA4B,EAC5BP,aAAkC,EAClCQ,YAAiC,EACjCC,eAQC,EACDC,IAA4D,KAE9D,CAACb,MAAuB,EAAEc,eAAoB,EAAEC,EAAU,KAAK;EAC7D,MAAMC,SAAS,GAAGhB,MAAM,CAACD,GAAG;EAC5B,IAAI,EAAEiB,SAAS,IAAIP,QAAQ,CAAC,EAAE;IAC5BA,QAAQ,CAACO,SAAS,CAAC,GAAG,CAAC,CAAC;IACxBb,aAAa,CAACa,SAAS,CAAC,GAAG;MAAE,GAAGb,aAAa,CAACa,SAAS;IAAE,CAAC;IAC1DJ,eAAe,CAACI,SAAS,CAAC,GAAG;MAAE,GAAGJ,eAAe,CAACI,SAAS;IAAE,CAAC;EAChE;EAEA,MAAMC,cAAc,GAAGR,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC;EAC9C,IAAIE,cAAc,EAAE;IAClBR,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC,GAAGf,MAAM,CAACkB,KAAK,CAACD,cAAc,EAAEH,eAAe,CAAC;EACzE,CAAC,MAAM;IACL,MAAMK,aAAa,GAAGhB,aAAa,CAACa,SAAS,CAAC,CAACD,EAAE,CAAC;IAClD,IAAIK,WAIH;IACD;IACA,IAAID,aAAa,KAAKC,WAAW,GAAGR,eAAe,CAACI,SAAS,CAAC,CAACD,EAAE,CAAC,CAAC,EAAE;MACnEN,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC,GAAGf,MAAM,CAACqB,cAAc,GAC3CrB,MAAM,CAACqB,cAAc,CACnBD,WAAW,EACXP,IAAI,EACJM,aAAa,EACbL,eACF,CAAC,GACDO,cAAc,CACZrB,MAAM,EACNoB,WAAW,EACXP,IAAI,EACJM,aAAa,EACbL,eACF,CAAC;MACLF,eAAe,CAACI,SAAS,CAAC,CAACD,EAAE,CAAC,GAAGf,MAAM,CAACsB,kBAAkB,GACtDtB,MAAM,CAACsB,kBAAkB,CACvBF,WAAW,EACXP,IAAI,EACJM,aAAa,EACbL,eACF,CAAC,GACDQ,kBAAkB,CAChBtB,MAAM,EACNoB,WAAW,EACXP,IAAI,EACJM,aAAa,EACbL,eACF,CAAC;IACP,CAAC,MAAM;MACLL,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC,GAAGD,eAAe;MACzCF,eAAe,CAACI,SAAS,CAAC,CAACD,EAAE,CAAC,GAAG;QAC/B;QACAQ,SAAS,EAAEvB,MAAM,CAACuB,SAAS,GACvBvB,MAAM,CAACuB,SAAS,CAACV,IAAI,EAAEC,eAAe,CAAC,GACvCD,IAAI,CAACU,SAAS;QAClBC,IAAI,EAAEX,IAAI,CAACW,IAAI;QACfC,SAAS,EAAEZ,IAAI,CAACY;MAClB,CAAC;IACH;EACF;;EAEA;EACA,IAAIzB,MAAM,CAACU,OAAO,EAAE;IAClB,IAAI,EAAEM,SAAS,IAAIN,OAAO,CAAC,EAAE;MAC3BA,OAAO,CAACM,SAAS,CAAC,GAAG,CAAC,CAAC;MACvBL,YAAY,CAACK,SAAS,CAAC,GAAG;QAAE,GAAGL,YAAY,CAACK,SAAS;MAAE,CAAC;IAC1D;IACAU,aAAa,CACXX,EAAE,EACFf,MAAM,CAACU,OAAO,EACdA,OAAO,CAACM,SAAS,CAAC,EAClBL,YAAY,CAACK,SAAS,CAAC,EACvBP,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC,EACvBZ,aAAa,CAACa,SAAS,CACzB,CAAC;EACH;EACA;EACAb,aAAa,CAACa,SAAS,CAAC,CAACD,EAAE,CAAC,GAAGN,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC;AACxD,CAAC;AAEH,SAASW,aAAaA,CACpBX,EAAU,EACVY,aAAuB,EACvBjB,OAA4B,EAC5BC,YAAiC,EACjCiB,MAAW,EACXzB,aAAkC,EAClC;EACA,KAAK,MAAM0B,KAAK,IAAIF,aAAa,EAAE;IACjC,IAAI,EAAEE,KAAK,IAAInB,OAAO,CAAC,EAAE;MACvBC,YAAY,CAACkB,KAAK,CAAC,GAAGnB,OAAO,CAACmB,KAAK,CAAC,GAAG,CAAC,CAAC;IAC3C;IACA,MAAMC,QAAQ,GAAGpB,OAAO,CAACmB,KAAK,CAAC;IAC/B,IAAI1B,aAAa,CAACY,EAAE,CAAC,EAAE;MACrB,OAAOe,QAAQ,CAAC3B,aAAa,CAACY,EAAE,CAAC,CAACc,KAAK,CAAC,CAAC;IAC3C;IACA;IACA,IACE1B,aAAa,IACbA,aAAa,CAACY,EAAE,CAAC,IACjBZ,aAAa,CAACY,EAAE,CAAC,CAACc,KAAK,CAAC,KAAKD,MAAM,CAACC,KAAK,CAAC,EAC1C;MACAC,QAAQ,CAAC3B,aAAa,CAACY,EAAE,CAAC,CAACc,KAAK,CAAC,CAAC,GAAGlC,OAAO;IAC9C;IACA,IAAIkC,KAAK,IAAID,MAAM,EAAE;MACnBE,QAAQ,CAACF,MAAM,CAACC,KAAK,CAAC,CAAC,GAAGd,EAAE;IAC9B,CAAC,CAAC,+BAAgC;IAChC;IACAgB,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EACrC;MACAC,OAAO,CAACC,IAAI,CAAE;AACpB,SAASN,KAAM;AACf,UAAUO,IAAI,CAACC,SAAS,CAACT,MAAM,EAAEU,SAAS,EAAE,CAAC,CAAE,EAAC,CAAC;IAC7C;EACF;AACF;;AAEA;AACA;AACA,SAASjB,cAAcA,CACrBrB,MAA4B,EAC5BuC,YAIC,EACDC,YAIC,EACDC,QAAa,EACbC,QAAa,EACb;EACA,MAAMC,WAAW;EACf;EACA3C,MAAM,CAAC2C,WAAW,IAAIH,YAAY,CAACf,SAAS,GACxCzB,MAAM,CAAC2C,WAAW,CAACJ,YAAY,EAAEC,YAAY,EAAEC,QAAQ,EAAEC,QAAQ,CAAC,GAClEH,YAAY,CAACf,IAAI,IAAIgB,YAAY,CAAChB,IAAI;EAC5C,IAAImB,WAAW,EAAE;IACf,IAAI,OAAOD,QAAQ,KAAK,OAAOD,QAAQ,EAAE;MACvC,OAAOC,QAAQ;IACjB,CAAC,MAAM;MACL,OAAO1C,MAAM,CAACkB,KAAK,CAACuB,QAAQ,EAAEC,QAAQ,CAAC;IACzC;EACF,CAAC,MAAM;IACL,OAAOD,QAAQ;EACjB;AACF;;AAEA;AACA;AACA,SAASnB,kBAAkBA,CACzBtB,MAAW,EACXuC,YAIC,EACDC,YAIC,EACDC,QAAa,EACbC,QAAa,EACb;EACA,OAAO;IACLnB,SAAS,EAAEqB,IAAI,CAACC,GAAG,CACjB7C,MAAM,CAACuB,SAAS,GACZvB,MAAM,CAACuB,SAAS,CAACiB,YAAY,EAAEE,QAAQ,CAAC,GACxCF,YAAY,CAACjB,SAAS,EAC1BgB,YAAY,CAAChB,SACf,CAAC;IACDC,IAAI,EAAEoB,IAAI,CAACC,GAAG,CAACL,YAAY,CAAChB,IAAI,EAAEe,YAAY,CAACf,IAAI,CAAC;IACpDC,SAAS,EAAEmB,IAAI,CAACC,GAAG,CAACL,YAAY,CAACf,SAAS,EAAEc,YAAY,CAACd,SAAS;EACpE,CAAC;AACH;AAEA,SAASqB,kBAAkBA,CAAC9C,MAAc,EAAE;EAC1C,OAAO,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC+C,QAAQ,CAAC,OAAO/C,MAAM,CAAC,GACjD,QAAQ,GACR,OAAOA,MAAM;AACnB;;AAEA;AACA,OAAO,MAAMR,SAAS,GAAGA,CAQvBwD,KAAU,EACVhD,MAAU,EACVI,IAAW,GAAG,EAAE,EAChBD,aAA0B,GAAG,CAAC,CAAQ,EACtCQ,YAAuC,GAAG,CAAC,CAAC,EAC5CC,eAQC,GAAG,CAAC,CAAC,EACNC,IAA4D,GAAG;EAC7DW,IAAI,EAAEyB,IAAI,CAACC,GAAG,CAAC,CAAC;EAChB3B,SAAS,EAAE4B,QAAQ;EACnB1B,SAAS,EAAE;AACb,CAAC,KAC0B;EAC3B;EACA,IAAIzB,MAAM,KAAKsC,SAAS,IAAItC,MAAM,KAAK,IAAI,EACzC,OAAO;IACLS,QAAQ,EAAEN,aAAa;IACvBO,OAAO,EAAEC,YAAY;IACrByC,MAAM,EAAEJ,KAAK;IACbK,UAAU,EAAEzC;EACd,CAAC;EAEH,MAAM0C,UAAU,GAAGR,kBAAkB,CAAC9C,MAAM,CAAC;EAC7C,IACEgD,KAAK,KAAK,IAAI,IACb,OAAOA,KAAK,KAAKM,UAAU;EAC1B;EACA,EACGtD,MAAM,CAASD,GAAG,KAAKuC,SAAS,IAChCtC,MAAM,CAASuD,EAAE,KAAKjB,SAAS,IAChC,OAAOU,KAAK,KAAK,QAAQ,CACzB,EACJ;IACA;IACA,IAAIjB,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;MACzC,MAAMuB,UAAU,GAAIR,KAAa,IAAK;QACpC,IAAI;UACF,OAAO,OAAOZ,IAAI,CAACqB,KAAK,CAACT,KAAK,CAAC,KAAK,QAAQ;QAC9C,CAAC,CAAC,OAAOU,CAAC,EAAE;UACV,OAAO,KAAK;QACd;MACF,CAAC;MACD,IAAI,OAAOV,KAAK,KAAK,QAAQ,IAAIQ,UAAU,CAACR,KAAK,CAAC,EAAE;QAClD,MAAM,IAAIW,KAAK,CAAE;AACzB;AACA;AACA;AACA;AACA;AACA,YAAYvB,IAAI,CAACC,SAAS,CAACrC,MAAM,EAAEsC,SAAS,EAAE,CAAC,CAAE;AACjD,YAAYU,KAAM,GAAE,CAAC;MACf,CAAC,MAAM;QACL,MAAM,IAAIW,KAAK,CACZ,6DAA4DL,UAAW,aACtEN,KAAK,KAAK,IAAI,GAAG,MAAM,GAAG,OAAOA,KAClC;AACX;AACA,oBAAoBZ,IAAI,CAACC,SAAS,CAACrC,MAAM,EAAEsC,SAAS,EAAE,CAAC,CAAE;AACzD,oBAAoBU,KAAM,GAClB,CAAC;MACH;IACF,CAAC,MAAM;MACL,MAAM,IAAIW,KAAK,CACZ,6DAA4DL,UAAW,aACtEN,KAAK,KAAK,IAAI,GAAG,MAAM,GAAG,OAAOA,KAClC,IACH,CAAC;IACH;EACF;EAEA,MAAMY,WAAc,GAAG,CAAC,CAAQ;EAChC,MAAMC,UAA2B,GAAG,CAAC,CAAQ;EAC7C,MAAMpD,QAAW,GAAG;IAAE,GAAGN;EAAc,CAAQ;EAC/C,MAAMO,OAAwB,GAAG;IAAE,GAAGC;EAAa,CAAC;EACpD,MAAM0C,UAAe,GAAG;IAAE,GAAGzC;EAAgB,CAAC;EAC9C,MAAMX,SAAS,GAAGO,WAAW,CAC3BoD,WAAW,EACXC,UAAU,EACVpD,QAAQ,EACRC,OAAO,EACP2C,UAAU,EACVxC,IACF,CAAC;EACD,MAAMX,eAAe,GAAG,CAAC,CAAC;EAE1B,MAAMkD,MAAM,GAAGxD,KAAK,CAClBoD,KAAK,EACLA,KAAK,EACLV,SAAS,EACTtC,MAAM,EACNC,SAAS,EACTC,eAAe,EACfC,aAAa,EACbC,IACF,CAAC;EACD,OAAO;IAAEK,QAAQ;IAAEC,OAAO;IAAE0C,MAAM;IAAEC;EAAW,CAAC;AAClD,CAAC"} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["INVALID","normalize","arrayNormalize","objectNormalize","visit","value","parent","key","schema","addEntity","visitedEntities","storeEntities","args","method","Array","isArray","addEntities","entities","indexes","storeIndexes","storeEntityMeta","meta","processedEntity","id","schemaKey","existingEntity","merge","inStoreEntity","inStoreMeta","mergeWithStore","mergeMetaWithStore","expiresAt","date","fetchedAt","handleIndexes","schemaIndexes","entity","index","indexMap","process","env","NODE_ENV","console","warn","JSON","stringify","undefined","expectedSchemaType","includes","input","Date","now","Infinity","result","entityMeta","schemaType","pk","parseWorks","parse","e","Error","newEntities","newIndexes"],"sources":["../src/normalize.ts"],"sourcesContent":["import { INVALID } from './denormalize/symbol.js';\nimport type { EntityInterface, Schema, NormalizedIndex } from './interface.js';\nimport { normalize as arrayNormalize } from './schemas/Array.js';\nimport { normalize as objectNormalize } from './schemas/Object.js';\nimport type { NormalizeNullable, NormalizedSchema } from './types.js';\n\nconst visit = (\n  value: any,\n  parent: any,\n  key: any,\n  schema: any,\n  addEntity: (\n    schema: EntityInterface,\n    processedEntity: any,\n    id: string,\n  ) => void,\n  visitedEntities: any,\n  storeEntities: any,\n  args: any[],\n) => {\n  if (!value || !schema) {\n    return value;\n  }\n\n  if (schema.normalize && typeof schema.normalize === 'function') {\n    if (typeof value !== 'object') return value;\n    return schema.normalize(\n      value,\n      parent,\n      key,\n      visit,\n      addEntity,\n      visitedEntities,\n      storeEntities,\n      args,\n    );\n  }\n\n  if (typeof value !== 'object' || typeof schema !== 'object') return value;\n\n  const method = Array.isArray(schema) ? arrayNormalize : objectNormalize;\n  return method(\n    schema,\n    value,\n    parent,\n    key,\n    visit,\n    addEntity,\n    visitedEntities,\n    storeEntities,\n    args,\n  );\n};\n\nconst addEntities =\n  (\n    entities: Record<string, any>,\n    indexes: Record<string, any>,\n    storeEntities: Record<string, any>,\n    storeIndexes: Record<string, any>,\n    storeEntityMeta: {\n      [entityKey: string]: {\n        [pk: string]: {\n          date: number;\n          expiresAt: number;\n          fetchedAt: number;\n        };\n      };\n    },\n    meta: { expiresAt: number; date: number; fetchedAt: number },\n  ) =>\n  (schema: EntityInterface, processedEntity: any, id: string) => {\n    const schemaKey = schema.key;\n    if (!(schemaKey in entities)) {\n      entities[schemaKey] = {};\n      storeEntities[schemaKey] = { ...storeEntities[schemaKey] };\n      storeEntityMeta[schemaKey] = { ...storeEntityMeta[schemaKey] };\n    }\n\n    const existingEntity = entities[schemaKey][id];\n    if (existingEntity) {\n      entities[schemaKey][id] = schema.merge(existingEntity, processedEntity);\n    } else {\n      const inStoreEntity = storeEntities[schemaKey][id];\n      let inStoreMeta: {\n        date: number;\n        expiresAt: number;\n        fetchedAt: number;\n      };\n      // this case we already have this entity in store\n      if (inStoreEntity && (inStoreMeta = storeEntityMeta[schemaKey][id])) {\n        entities[schemaKey][id] = schema.mergeWithStore(\n          inStoreMeta,\n          meta,\n          inStoreEntity,\n          processedEntity,\n        );\n        storeEntityMeta[schemaKey][id] = schema.mergeMetaWithStore(\n          inStoreMeta,\n          meta,\n          inStoreEntity,\n          processedEntity,\n        );\n      } else {\n        entities[schemaKey][id] = processedEntity;\n        storeEntityMeta[schemaKey][id] = {\n          expiresAt: meta.expiresAt,\n          date: meta.date,\n          fetchedAt: meta.fetchedAt,\n        };\n      }\n    }\n\n    // update index\n    if (schema.indexes) {\n      if (!(schemaKey in indexes)) {\n        indexes[schemaKey] = {};\n        storeIndexes[schemaKey] = { ...storeIndexes[schemaKey] };\n      }\n      handleIndexes(\n        id,\n        schema.indexes,\n        indexes[schemaKey],\n        storeIndexes[schemaKey],\n        entities[schemaKey][id],\n        storeEntities[schemaKey],\n      );\n    }\n    // set this after index updates so we know what indexes to remove from\n    storeEntities[schemaKey][id] = entities[schemaKey][id];\n  };\n\nfunction handleIndexes(\n  id: string,\n  schemaIndexes: string[],\n  indexes: Record<string, any>,\n  storeIndexes: Record<string, any>,\n  entity: any,\n  storeEntities: Record<string, any>,\n) {\n  for (const index of schemaIndexes) {\n    if (!(index in indexes)) {\n      storeIndexes[index] = indexes[index] = {};\n    }\n    const indexMap = indexes[index];\n    if (storeEntities[id]) {\n      delete indexMap[storeEntities[id][index]];\n    }\n    // entity already in cache but the index changed\n    if (\n      storeEntities &&\n      storeEntities[id] &&\n      storeEntities[id][index] !== entity[index]\n    ) {\n      indexMap[storeEntities[id][index]] = INVALID;\n    }\n    if (index in entity) {\n      indexMap[entity[index]] = id;\n    } /* istanbul ignore next */ else if (\n      // eslint-disable-next-line no-undef\n      process.env.NODE_ENV !== 'production'\n    ) {\n      console.warn(`Index not found in entity. Indexes must be top-level members of your entity.\nIndex: ${index}\nEntity: ${JSON.stringify(entity, undefined, 2)}`);\n    }\n  }\n}\n\nfunction expectedSchemaType(schema: Schema) {\n  return ['object', 'function'].includes(typeof schema)\n    ? 'object'\n    : typeof schema;\n}\n\n// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\nexport const normalize = <\n  S extends Schema = Schema,\n  E extends Record<string, Record<string, any> | undefined> = Record<\n    string,\n    Record<string, any>\n  >,\n  R = NormalizeNullable<S>,\n>(\n  input: any,\n  schema?: S,\n  args: any[] = [],\n  storeEntities: Readonly<E> = {} as any,\n  storeIndexes: Readonly<NormalizedIndex> = {},\n  storeEntityMeta: {\n    readonly [entityKey: string]: {\n      readonly [pk: string]: {\n        readonly date: number;\n        readonly expiresAt: number;\n        readonly fetchedAt: number;\n      };\n    };\n  } = {},\n  meta: { expiresAt: number; date: number; fetchedAt: number } = {\n    date: Date.now(),\n    expiresAt: Infinity,\n    fetchedAt: 0,\n  },\n): NormalizedSchema<E, R> => {\n  // no schema means we don't process at all\n  if (schema === undefined || schema === null)\n    return {\n      entities: storeEntities,\n      indexes: storeIndexes,\n      result: input,\n      entityMeta: storeEntityMeta,\n    };\n\n  const schemaType = expectedSchemaType(schema);\n  if (\n    input === null ||\n    (typeof input !== schemaType &&\n      // we will allow a Delete schema to be a string or object\n      !(\n        (schema as any).key !== undefined &&\n        (schema as any).pk === undefined &&\n        typeof input === 'string'\n      ))\n  ) {\n    /* istanbul ignore else */\n    if (process.env.NODE_ENV !== 'production') {\n      const parseWorks = (input: string) => {\n        try {\n          return typeof JSON.parse(input) !== 'string';\n        } catch (e) {\n          return false;\n        }\n      };\n      if (typeof input === 'string' && parseWorks(input)) {\n        throw new Error(`Normalizing a string, but this does match schema.\n\nParsing this input string as JSON worked. This likely indicates fetch function did not parse\nthe JSON. By default, this only happens if \"content-type\" header includes \"json\".\nSee https://dataclient.io/rest/api/RestEndpoint#parseResponse for more information\n\n  Schema: ${JSON.stringify(schema, undefined, 2)}\n  Input: \"${input}\"`);\n      } else {\n        throw new Error(\n          `Unexpected input given to normalize. Expected type to be \"${schemaType}\", found \"${\n            input === null ? 'null' : typeof input\n          }\".\n\n          Schema: ${JSON.stringify(schema, undefined, 2)}\n          Input: \"${input}\"`,\n        );\n      }\n    } else {\n      throw new Error(\n        `Unexpected input given to normalize. Expected type to be \"${schemaType}\", found \"${\n          input === null ? 'null' : typeof input\n        }\".`,\n      );\n    }\n  }\n\n  const newEntities: E = {} as any;\n  const newIndexes: NormalizedIndex = {} as any;\n  const entities: E = { ...storeEntities } as any;\n  const indexes: NormalizedIndex = { ...storeIndexes };\n  const entityMeta: any = { ...storeEntityMeta };\n  const addEntity = addEntities(\n    newEntities,\n    newIndexes,\n    entities,\n    indexes,\n    entityMeta,\n    meta,\n  );\n  const visitedEntities = {};\n\n  const result = visit(\n    input,\n    input,\n    undefined,\n    schema,\n    addEntity,\n    visitedEntities,\n    storeEntities,\n    args,\n  );\n  return { entities, indexes, result, entityMeta };\n};\n"],"mappings":"AAAA,SAASA,OAAO,QAAQ,yBAAyB;AAEjD,SAASC,SAAS,IAAIC,cAAc,QAAQ,oBAAoB;AAChE,SAASD,SAAS,IAAIE,eAAe,QAAQ,qBAAqB;AAGlE,MAAMC,KAAK,GAAGA,CACZC,KAAU,EACVC,MAAW,EACXC,GAAQ,EACRC,MAAW,EACXC,SAIS,EACTC,eAAoB,EACpBC,aAAkB,EAClBC,IAAW,KACR;EACH,IAAI,CAACP,KAAK,IAAI,CAACG,MAAM,EAAE;IACrB,OAAOH,KAAK;EACd;EAEA,IAAIG,MAAM,CAACP,SAAS,IAAI,OAAOO,MAAM,CAACP,SAAS,KAAK,UAAU,EAAE;IAC9D,IAAI,OAAOI,KAAK,KAAK,QAAQ,EAAE,OAAOA,KAAK;IAC3C,OAAOG,MAAM,CAACP,SAAS,CACrBI,KAAK,EACLC,MAAM,EACNC,GAAG,EACHH,KAAK,EACLK,SAAS,EACTC,eAAe,EACfC,aAAa,EACbC,IACF,CAAC;EACH;EAEA,IAAI,OAAOP,KAAK,KAAK,QAAQ,IAAI,OAAOG,MAAM,KAAK,QAAQ,EAAE,OAAOH,KAAK;EAEzE,MAAMQ,MAAM,GAAGC,KAAK,CAACC,OAAO,CAACP,MAAM,CAAC,GAAGN,cAAc,GAAGC,eAAe;EACvE,OAAOU,MAAM,CACXL,MAAM,EACNH,KAAK,EACLC,MAAM,EACNC,GAAG,EACHH,KAAK,EACLK,SAAS,EACTC,eAAe,EACfC,aAAa,EACbC,IACF,CAAC;AACH,CAAC;AAED,MAAMI,WAAW,GACfA,CACEC,QAA6B,EAC7BC,OAA4B,EAC5BP,aAAkC,EAClCQ,YAAiC,EACjCC,eAQC,EACDC,IAA4D,KAE9D,CAACb,MAAuB,EAAEc,eAAoB,EAAEC,EAAU,KAAK;EAC7D,MAAMC,SAAS,GAAGhB,MAAM,CAACD,GAAG;EAC5B,IAAI,EAAEiB,SAAS,IAAIP,QAAQ,CAAC,EAAE;IAC5BA,QAAQ,CAACO,SAAS,CAAC,GAAG,CAAC,CAAC;IACxBb,aAAa,CAACa,SAAS,CAAC,GAAG;MAAE,GAAGb,aAAa,CAACa,SAAS;IAAE,CAAC;IAC1DJ,eAAe,CAACI,SAAS,CAAC,GAAG;MAAE,GAAGJ,eAAe,CAACI,SAAS;IAAE,CAAC;EAChE;EAEA,MAAMC,cAAc,GAAGR,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC;EAC9C,IAAIE,cAAc,EAAE;IAClBR,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC,GAAGf,MAAM,CAACkB,KAAK,CAACD,cAAc,EAAEH,eAAe,CAAC;EACzE,CAAC,MAAM;IACL,MAAMK,aAAa,GAAGhB,aAAa,CAACa,SAAS,CAAC,CAACD,EAAE,CAAC;IAClD,IAAIK,WAIH;IACD;IACA,IAAID,aAAa,KAAKC,WAAW,GAAGR,eAAe,CAACI,SAAS,CAAC,CAACD,EAAE,CAAC,CAAC,EAAE;MACnEN,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC,GAAGf,MAAM,CAACqB,cAAc,CAC7CD,WAAW,EACXP,IAAI,EACJM,aAAa,EACbL,eACF,CAAC;MACDF,eAAe,CAACI,SAAS,CAAC,CAACD,EAAE,CAAC,GAAGf,MAAM,CAACsB,kBAAkB,CACxDF,WAAW,EACXP,IAAI,EACJM,aAAa,EACbL,eACF,CAAC;IACH,CAAC,MAAM;MACLL,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC,GAAGD,eAAe;MACzCF,eAAe,CAACI,SAAS,CAAC,CAACD,EAAE,CAAC,GAAG;QAC/BQ,SAAS,EAAEV,IAAI,CAACU,SAAS;QACzBC,IAAI,EAAEX,IAAI,CAACW,IAAI;QACfC,SAAS,EAAEZ,IAAI,CAACY;MAClB,CAAC;IACH;EACF;;EAEA;EACA,IAAIzB,MAAM,CAACU,OAAO,EAAE;IAClB,IAAI,EAAEM,SAAS,IAAIN,OAAO,CAAC,EAAE;MAC3BA,OAAO,CAACM,SAAS,CAAC,GAAG,CAAC,CAAC;MACvBL,YAAY,CAACK,SAAS,CAAC,GAAG;QAAE,GAAGL,YAAY,CAACK,SAAS;MAAE,CAAC;IAC1D;IACAU,aAAa,CACXX,EAAE,EACFf,MAAM,CAACU,OAAO,EACdA,OAAO,CAACM,SAAS,CAAC,EAClBL,YAAY,CAACK,SAAS,CAAC,EACvBP,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC,EACvBZ,aAAa,CAACa,SAAS,CACzB,CAAC;EACH;EACA;EACAb,aAAa,CAACa,SAAS,CAAC,CAACD,EAAE,CAAC,GAAGN,QAAQ,CAACO,SAAS,CAAC,CAACD,EAAE,CAAC;AACxD,CAAC;AAEH,SAASW,aAAaA,CACpBX,EAAU,EACVY,aAAuB,EACvBjB,OAA4B,EAC5BC,YAAiC,EACjCiB,MAAW,EACXzB,aAAkC,EAClC;EACA,KAAK,MAAM0B,KAAK,IAAIF,aAAa,EAAE;IACjC,IAAI,EAAEE,KAAK,IAAInB,OAAO,CAAC,EAAE;MACvBC,YAAY,CAACkB,KAAK,CAAC,GAAGnB,OAAO,CAACmB,KAAK,CAAC,GAAG,CAAC,CAAC;IAC3C;IACA,MAAMC,QAAQ,GAAGpB,OAAO,CAACmB,KAAK,CAAC;IAC/B,IAAI1B,aAAa,CAACY,EAAE,CAAC,EAAE;MACrB,OAAOe,QAAQ,CAAC3B,aAAa,CAACY,EAAE,CAAC,CAACc,KAAK,CAAC,CAAC;IAC3C;IACA;IACA,IACE1B,aAAa,IACbA,aAAa,CAACY,EAAE,CAAC,IACjBZ,aAAa,CAACY,EAAE,CAAC,CAACc,KAAK,CAAC,KAAKD,MAAM,CAACC,KAAK,CAAC,EAC1C;MACAC,QAAQ,CAAC3B,aAAa,CAACY,EAAE,CAAC,CAACc,KAAK,CAAC,CAAC,GAAGrC,OAAO;IAC9C;IACA,IAAIqC,KAAK,IAAID,MAAM,EAAE;MACnBE,QAAQ,CAACF,MAAM,CAACC,KAAK,CAAC,CAAC,GAAGd,EAAE;IAC9B,CAAC,CAAC,+BAAgC;IAChC;IACAgB,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EACrC;MACAC,OAAO,CAACC,IAAI,CAAE;AACpB,SAASN,KAAM;AACf,UAAUO,IAAI,CAACC,SAAS,CAACT,MAAM,EAAEU,SAAS,EAAE,CAAC,CAAE,EAAC,CAAC;IAC7C;EACF;AACF;AAEA,SAASC,kBAAkBA,CAACvC,MAAc,EAAE;EAC1C,OAAO,CAAC,QAAQ,EAAE,UAAU,CAAC,CAACwC,QAAQ,CAAC,OAAOxC,MAAM,CAAC,GACjD,QAAQ,GACR,OAAOA,MAAM;AACnB;;AAEA;AACA,OAAO,MAAMP,SAAS,GAAGA,CAQvBgD,KAAU,EACVzC,MAAU,EACVI,IAAW,GAAG,EAAE,EAChBD,aAA0B,GAAG,CAAC,CAAQ,EACtCQ,YAAuC,GAAG,CAAC,CAAC,EAC5CC,eAQC,GAAG,CAAC,CAAC,EACNC,IAA4D,GAAG;EAC7DW,IAAI,EAAEkB,IAAI,CAACC,GAAG,CAAC,CAAC;EAChBpB,SAAS,EAAEqB,QAAQ;EACnBnB,SAAS,EAAE;AACb,CAAC,KAC0B;EAC3B;EACA,IAAIzB,MAAM,KAAKsC,SAAS,IAAItC,MAAM,KAAK,IAAI,EACzC,OAAO;IACLS,QAAQ,EAAEN,aAAa;IACvBO,OAAO,EAAEC,YAAY;IACrBkC,MAAM,EAAEJ,KAAK;IACbK,UAAU,EAAElC;EACd,CAAC;EAEH,MAAMmC,UAAU,GAAGR,kBAAkB,CAACvC,MAAM,CAAC;EAC7C,IACEyC,KAAK,KAAK,IAAI,IACb,OAAOA,KAAK,KAAKM,UAAU;EAC1B;EACA,EACG/C,MAAM,CAASD,GAAG,KAAKuC,SAAS,IAChCtC,MAAM,CAASgD,EAAE,KAAKV,SAAS,IAChC,OAAOG,KAAK,KAAK,QAAQ,CACzB,EACJ;IACA;IACA,IAAIV,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,YAAY,EAAE;MACzC,MAAMgB,UAAU,GAAIR,KAAa,IAAK;QACpC,IAAI;UACF,OAAO,OAAOL,IAAI,CAACc,KAAK,CAACT,KAAK,CAAC,KAAK,QAAQ;QAC9C,CAAC,CAAC,OAAOU,CAAC,EAAE;UACV,OAAO,KAAK;QACd;MACF,CAAC;MACD,IAAI,OAAOV,KAAK,KAAK,QAAQ,IAAIQ,UAAU,CAACR,KAAK,CAAC,EAAE;QAClD,MAAM,IAAIW,KAAK,CAAE;AACzB;AACA;AACA;AACA;AACA;AACA,YAAYhB,IAAI,CAACC,SAAS,CAACrC,MAAM,EAAEsC,SAAS,EAAE,CAAC,CAAE;AACjD,YAAYG,KAAM,GAAE,CAAC;MACf,CAAC,MAAM;QACL,MAAM,IAAIW,KAAK,CACZ,6DAA4DL,UAAW,aACtEN,KAAK,KAAK,IAAI,GAAG,MAAM,GAAG,OAAOA,KAClC;AACX;AACA,oBAAoBL,IAAI,CAACC,SAAS,CAACrC,MAAM,EAAEsC,SAAS,EAAE,CAAC,CAAE;AACzD,oBAAoBG,KAAM,GAClB,CAAC;MACH;IACF,CAAC,MAAM;MACL,MAAM,IAAIW,KAAK,CACZ,6DAA4DL,UAAW,aACtEN,KAAK,KAAK,IAAI,GAAG,MAAM,GAAG,OAAOA,KAClC,IACH,CAAC;IACH;EACF;EAEA,MAAMY,WAAc,GAAG,CAAC,CAAQ;EAChC,MAAMC,UAA2B,GAAG,CAAC,CAAQ;EAC7C,MAAM7C,QAAW,GAAG;IAAE,GAAGN;EAAc,CAAQ;EAC/C,MAAMO,OAAwB,GAAG;IAAE,GAAGC;EAAa,CAAC;EACpD,MAAMmC,UAAe,GAAG;IAAE,GAAGlC;EAAgB,CAAC;EAC9C,MAAMX,SAAS,GAAGO,WAAW,CAC3B6C,WAAW,EACXC,UAAU,EACV7C,QAAQ,EACRC,OAAO,EACPoC,UAAU,EACVjC,IACF,CAAC;EACD,MAAMX,eAAe,GAAG,CAAC,CAAC;EAE1B,MAAM2C,MAAM,GAAGjD,KAAK,CAClB6C,KAAK,EACLA,KAAK,EACLH,SAAS,EACTtC,MAAM,EACNC,SAAS,EACTC,eAAe,EACfC,aAAa,EACbC,IACF,CAAC;EACD,OAAO;IAAEK,QAAQ;IAAEC,OAAO;IAAEmC,MAAM;IAAEC;EAAW,CAAC;AAClD,CAAC"} |
@@ -48,9 +48,6 @@ import type { Schema, Serializable, EntityInterface, NormalizedIndex } from './interface.js'; | ||
export type DenormalizeNullableNestedSchema<S extends NestedSchemaClass> = keyof S['schema'] extends never ? S['prototype'] : string extends keyof S['schema'] ? S['prototype'] : S['prototype']; | ||
export type DenormalizeReturnType<T> = T extends (input: any, unvisit: any) => [infer R, any, any] ? R : never; | ||
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 { | ||
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 { | ||
} ? ReturnType<S['denormalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] : S extends { | ||
[K: string]: any; | ||
@@ -60,3 +57,3 @@ } ? DenormalizeObject<S> : S; | ||
_denormalizeNullable: (...args: any) => any; | ||
} ? DenormalizeReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
} ? ReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
[K: string]: any; | ||
@@ -63,0 +60,0 @@ } ? DenormalizeNullableObject<S> : S; |
export {}; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtcbiAgU2NoZW1hLFxuICBTZXJpYWxpemFibGUsXG4gIEVudGl0eUludGVyZmFjZSxcbiAgTm9ybWFsaXplZEluZGV4LFxuICBTY2hlbWFDbGFzcyxcbn0gZnJvbSAnLi9pbnRlcmZhY2UuanMnO1xuaW1wb3J0IHR5cGUgV2Vha0VudGl0eU1hcCBmcm9tICcuL1dlYWtFbnRpdHlNYXAuanMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBhdGgge1xuICBrZXk6IHN0cmluZztcbiAgcGs6IHN0cmluZztcbn1cblxuLy8gVHlwZVNjcmlwdCA8NC4yIEluc3RhbmNlVHlwZTw+IGRvZXMgbm90IHdvcmsgb24gYWJzdHJhY3QgY2xhc3Nlc1xuZXhwb3J0IHR5cGUgQWJzdHJhY3RJbnN0YW5jZVR5cGU8VD4gPSBUIGV4dGVuZHMgbmV3ICguLi5hcmdzOiBhbnkpID0+IGluZmVyIFVcbiAgPyBVXG4gIDogVCBleHRlbmRzIHsgcHJvdG90eXBlOiBpbmZlciBVIH1cbiAgPyBVXG4gIDogbmV2ZXI7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRFbnRpdHk8VD4gPSBUIGV4dGVuZHMge1xuICBwcm90b3R5cGU6IGluZmVyIFU7XG4gIHNjaGVtYTogaW5mZXIgUztcbn1cbiAgPyB7IFtLIGluIEV4Y2x1ZGU8a2V5b2YgVSwga2V5b2YgUz5dOiBVW0tdIH0gJiB7IFtLIGluIGtleW9mIFNdOiBzdHJpbmcgfVxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemU8U1tLXT4gOiBTW0tdO1xufTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVOdWxsYWJsZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemVOdWxsYWJsZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZU51bGxhYmxlPFNbS10+IDogU1tLXTtcbn07XG5cbmludGVyZmFjZSBOZXN0ZWRTY2hlbWFDbGFzczxUID0gYW55PiB7XG4gIHNjaGVtYTogUmVjb3JkPHN0cmluZywgU2NoZW1hPjtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlY29yZENsYXNzPFQgPSBhbnk+IGV4dGVuZHMgTmVzdGVkU2NoZW1hQ2xhc3M8VD4ge1xuICBmcm9tSlM6ICguLi5hcmdzOiBhbnkpID0+IEFic3RyYWN0SW5zdGFuY2VUeXBlPFQ+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlbm9ybWFsaXplQ2FjaGUge1xuICBlbnRpdGllczoge1xuICAgIFtrZXk6IHN0cmluZ106IHtcbiAgICAgIFtwazogc3RyaW5nXTogV2Vha01hcDxFbnRpdHlJbnRlcmZhY2UsIFdlYWtFbnRpdHlNYXA8b2JqZWN0LCBhbnk+PjtcbiAgICB9O1xuICB9O1xuICByZXN1bHRzOiB7XG4gICAgW2tleTogc3RyaW5nXTogV2Vha0VudGl0eU1hcDxvYmplY3QsIGFueT47XG4gIH07XG59XG5cbmV4cG9ydCB0eXBlIERlbm9ybWFsaXplTnVsbGFibGVOZXN0ZWRTY2hlbWE8UyBleHRlbmRzIE5lc3RlZFNjaGVtYUNsYXNzPiA9XG4gIGtleW9mIFNbJ3NjaGVtYSddIGV4dGVuZHMgbmV2ZXJcbiAgICA/IFNbJ3Byb3RvdHlwZSddIC8vIHRoaXMgaXMgdGhlIGNhc2Ugb2YgYSBub24tc2V0IHNjaGVtYSwgd2hpY2ggbWVhbnMgaXQgYWN0dWFsbHkgaGFzIG5vIG1lbWJlcnNcbiAgICA6IHN0cmluZyBleHRlbmRzIGtleW9mIFNbJ3NjaGVtYSddXG4gICAgPyBTWydwcm90b3R5cGUnXVxuICAgIDogU1sncHJvdG90eXBlJ10gLyomIHtcbiAgICAgICAgW0sgaW4ga2V5b2YgU1snc2NoZW1hJ11dOiBEZW5vcm1hbGl6ZU51bGxhYmxlPFNbJ3NjaGVtYSddW0tdPjtcbiAgICAgIH0qLztcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVSZXR1cm5UeXBlPFQ+ID0gVCBleHRlbmRzIChcbiAgaW5wdXQ6IGFueSxcbiAgdW52aXNpdDogYW55LFxuKSA9PiBbaW5mZXIgUiwgYW55LCBhbnldXG4gID8gUlxuICA6IG5ldmVyO1xuZXhwb3J0IHR5cGUgTm9ybWFsaXplUmV0dXJuVHlwZTxUPiA9IFQgZXh0ZW5kcyAoLi4uYXJnczogYW55KSA9PiBpbmZlciBSXG4gID8gUlxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2U8aW5mZXIgVT5cbiAgPyBVXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gQWJzdHJhY3RJbnN0YW5jZVR5cGU8Uz5cbiAgOiBTIGV4dGVuZHMgeyBkZW5vcm1hbGl6ZU9ubHk6ICguLi5hcmdzOiBhbnkpID0+IGFueSB9XG4gID8gUmV0dXJuVHlwZTxTWydkZW5vcm1hbGl6ZU9ubHknXT5cbiAgOiBTIGV4dGVuZHMgeyBkZW5vcm1hbGl6ZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBEZW5vcm1hbGl6ZVJldHVyblR5cGU8U1snZGVub3JtYWxpemUnXT5cbiAgOiBTIGV4dGVuZHMgU2VyaWFsaXphYmxlPGluZmVyIFQ+XG4gID8gVFxuICA6IFMgZXh0ZW5kcyBBcnJheTxpbmZlciBGPlxuICA/IERlbm9ybWFsaXplPEY+W11cbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBEZW5vcm1hbGl6ZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIERlbm9ybWFsaXplTnVsbGFibGU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlPGFueT5cbiAgPyBEZW5vcm1hbGl6ZU51bGxhYmxlTmVzdGVkU2NoZW1hPFM+IHwgdW5kZWZpbmVkXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gRGVub3JtYWxpemVOdWxsYWJsZU5lc3RlZFNjaGVtYTxTPlxuICA6IFMgZXh0ZW5kcyB7IF9kZW5vcm1hbGl6ZU51bGxhYmxlOiAoLi4uYXJnczogYW55KSA9PiBhbnkgfVxuICA/IERlbm9ybWFsaXplUmV0dXJuVHlwZTxTWydfZGVub3JtYWxpemVOdWxsYWJsZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gRGVub3JtYWxpemU8Rj5bXSB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IERlbm9ybWFsaXplTnVsbGFibGVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemU8Uz4gPSBTIGV4dGVuZHMgRW50aXR5SW50ZXJmYWNlXG4gID8gc3RyaW5nXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gTm9ybWFsaXplT2JqZWN0PFNbJ3NjaGVtYSddPlxuICA6IFMgZXh0ZW5kcyB7IG5vcm1hbGl6ZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBOb3JtYWxpemVSZXR1cm5UeXBlPFNbJ25vcm1hbGl6ZSddPlxuICA6IFMgZXh0ZW5kcyBTZXJpYWxpemFibGU8aW5mZXIgVD5cbiAgPyBUXG4gIDogUyBleHRlbmRzIEFycmF5PGluZmVyIEY+XG4gID8gTm9ybWFsaXplPEY+W11cbiAgOiBTIGV4dGVuZHMgeyBbSzogc3RyaW5nXTogYW55IH1cbiAgPyBOb3JtYWxpemVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVOdWxsYWJsZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2VcbiAgPyBzdHJpbmcgfCB1bmRlZmluZWRcbiAgOiBTIGV4dGVuZHMgUmVjb3JkQ2xhc3NcbiAgPyBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8U1snc2NoZW1hJ10+XG4gIDogUyBleHRlbmRzIHsgX25vcm1hbGl6ZU51bGxhYmxlOiAoLi4uYXJnczogYW55KSA9PiBhbnkgfVxuICA/IE5vcm1hbGl6ZVJldHVyblR5cGU8U1snX25vcm1hbGl6ZU51bGxhYmxlJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBOb3JtYWxpemU8Rj5bXSB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IE5vcm1hbGl6ZWROdWxsYWJsZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRTY2hlbWE8RSwgUj4gPSB7XG4gIGVudGl0aWVzOiBFO1xuICByZXN1bHQ6IFI7XG4gIGluZGV4ZXM6IE5vcm1hbGl6ZWRJbmRleDtcbiAgZW50aXR5TWV0YToge1xuICAgIHJlYWRvbmx5IFtlbnRpdHlLZXk6IHN0cmluZ106IHtcbiAgICAgIHJlYWRvbmx5IFtwazogc3RyaW5nXToge1xuICAgICAgICByZWFkb25seSBkYXRlOiBudW1iZXI7XG4gICAgICAgIHJlYWRvbmx5IGV4cGlyZXNBdDogbnVtYmVyO1xuICAgICAgICByZWFkb25seSBmZXRjaGVkQXQ6IG51bWJlcjtcbiAgICAgIH07XG4gICAgfTtcbiAgfTtcbn07XG5cbmV4cG9ydCB0eXBlIEVudGl0eU1hcDxUID0gYW55PiA9IFJlY29yZDxzdHJpbmcsIEVudGl0eUludGVyZmFjZTxUPj47XG4iXSwibWFwcGluZ3MiOiIifQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vc3JjL3R5cGVzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtcbiAgU2NoZW1hLFxuICBTZXJpYWxpemFibGUsXG4gIEVudGl0eUludGVyZmFjZSxcbiAgTm9ybWFsaXplZEluZGV4LFxuICBTY2hlbWFDbGFzcyxcbn0gZnJvbSAnLi9pbnRlcmZhY2UuanMnO1xuaW1wb3J0IHR5cGUgV2Vha0VudGl0eU1hcCBmcm9tICcuL1dlYWtFbnRpdHlNYXAuanMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFBhdGgge1xuICBrZXk6IHN0cmluZztcbiAgcGs6IHN0cmluZztcbn1cblxuLy8gVHlwZVNjcmlwdCA8NC4yIEluc3RhbmNlVHlwZTw+IGRvZXMgbm90IHdvcmsgb24gYWJzdHJhY3QgY2xhc3Nlc1xuZXhwb3J0IHR5cGUgQWJzdHJhY3RJbnN0YW5jZVR5cGU8VD4gPSBUIGV4dGVuZHMgbmV3ICguLi5hcmdzOiBhbnkpID0+IGluZmVyIFVcbiAgPyBVXG4gIDogVCBleHRlbmRzIHsgcHJvdG90eXBlOiBpbmZlciBVIH1cbiAgPyBVXG4gIDogbmV2ZXI7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZWRFbnRpdHk8VD4gPSBUIGV4dGVuZHMge1xuICBwcm90b3R5cGU6IGluZmVyIFU7XG4gIHNjaGVtYTogaW5mZXIgUztcbn1cbiAgPyB7IFtLIGluIEV4Y2x1ZGU8a2V5b2YgVSwga2V5b2YgUz5dOiBVW0tdIH0gJiB7IFtLIGluIGtleW9mIFNdOiBzdHJpbmcgfVxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemU8U1tLXT4gOiBTW0tdO1xufTtcblxuZXhwb3J0IHR5cGUgRGVub3JtYWxpemVOdWxsYWJsZU9iamVjdDxTIGV4dGVuZHMgUmVjb3JkPHN0cmluZywgYW55Pj4gPSB7XG4gIFtLIGluIGtleW9mIFNdOiBTW0tdIGV4dGVuZHMgU2NoZW1hID8gRGVub3JtYWxpemVOdWxsYWJsZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZTxTW0tdPiA6IFNbS107XG59O1xuXG5leHBvcnQgdHlwZSBOb3JtYWxpemVkTnVsbGFibGVPYmplY3Q8UyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0ge1xuICBbSyBpbiBrZXlvZiBTXTogU1tLXSBleHRlbmRzIFNjaGVtYSA/IE5vcm1hbGl6ZU51bGxhYmxlPFNbS10+IDogU1tLXTtcbn07XG5cbmludGVyZmFjZSBOZXN0ZWRTY2hlbWFDbGFzczxUID0gYW55PiB7XG4gIHNjaGVtYTogUmVjb3JkPHN0cmluZywgU2NoZW1hPjtcbiAgcHJvdG90eXBlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlY29yZENsYXNzPFQgPSBhbnk+IGV4dGVuZHMgTmVzdGVkU2NoZW1hQ2xhc3M8VD4ge1xuICBmcm9tSlM6ICguLi5hcmdzOiBhbnkpID0+IEFic3RyYWN0SW5zdGFuY2VUeXBlPFQ+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERlbm9ybWFsaXplQ2FjaGUge1xuICBlbnRpdGllczoge1xuICAgIFtrZXk6IHN0cmluZ106IHtcbiAgICAgIFtwazogc3RyaW5nXTogV2Vha01hcDxFbnRpdHlJbnRlcmZhY2UsIFdlYWtFbnRpdHlNYXA8b2JqZWN0LCBhbnk+PjtcbiAgICB9O1xuICB9O1xuICByZXN1bHRzOiB7XG4gICAgW2tleTogc3RyaW5nXTogV2Vha0VudGl0eU1hcDxvYmplY3QsIGFueT47XG4gIH07XG59XG5cbmV4cG9ydCB0eXBlIERlbm9ybWFsaXplTnVsbGFibGVOZXN0ZWRTY2hlbWE8UyBleHRlbmRzIE5lc3RlZFNjaGVtYUNsYXNzPiA9XG4gIGtleW9mIFNbJ3NjaGVtYSddIGV4dGVuZHMgbmV2ZXJcbiAgICA/IFNbJ3Byb3RvdHlwZSddIC8vIHRoaXMgaXMgdGhlIGNhc2Ugb2YgYSBub24tc2V0IHNjaGVtYSwgd2hpY2ggbWVhbnMgaXQgYWN0dWFsbHkgaGFzIG5vIG1lbWJlcnNcbiAgICA6IHN0cmluZyBleHRlbmRzIGtleW9mIFNbJ3NjaGVtYSddXG4gICAgPyBTWydwcm90b3R5cGUnXVxuICAgIDogU1sncHJvdG90eXBlJ10gLyomIHtcbiAgICAgICAgW0sgaW4ga2V5b2YgU1snc2NoZW1hJ11dOiBEZW5vcm1hbGl6ZU51bGxhYmxlPFNbJ3NjaGVtYSddW0tdPjtcbiAgICAgIH0qLztcblxuZXhwb3J0IHR5cGUgTm9ybWFsaXplUmV0dXJuVHlwZTxUPiA9IFQgZXh0ZW5kcyAoLi4uYXJnczogYW55KSA9PiBpbmZlciBSXG4gID8gUlxuICA6IG5ldmVyO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2U8aW5mZXIgVT5cbiAgPyBVXG4gIDogUyBleHRlbmRzIFJlY29yZENsYXNzXG4gID8gQWJzdHJhY3RJbnN0YW5jZVR5cGU8Uz5cbiAgOiBTIGV4dGVuZHMgeyBkZW5vcm1hbGl6ZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBSZXR1cm5UeXBlPFNbJ2Rlbm9ybWFsaXplJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBEZW5vcm1hbGl6ZTxGPltdXG4gIDogUyBleHRlbmRzIHsgW0s6IHN0cmluZ106IGFueSB9XG4gID8gRGVub3JtYWxpemVPYmplY3Q8Uz5cbiAgOiBTO1xuXG5leHBvcnQgdHlwZSBEZW5vcm1hbGl6ZU51bGxhYmxlPFM+ID0gUyBleHRlbmRzIEVudGl0eUludGVyZmFjZTxhbnk+XG4gID8gRGVub3JtYWxpemVOdWxsYWJsZU5lc3RlZFNjaGVtYTxTPiB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyBSZWNvcmRDbGFzc1xuICA/IERlbm9ybWFsaXplTnVsbGFibGVOZXN0ZWRTY2hlbWE8Uz5cbiAgOiBTIGV4dGVuZHMgeyBfZGVub3JtYWxpemVOdWxsYWJsZTogKC4uLmFyZ3M6IGFueSkgPT4gYW55IH1cbiAgPyBSZXR1cm5UeXBlPFNbJ19kZW5vcm1hbGl6ZU51bGxhYmxlJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBEZW5vcm1hbGl6ZTxGPltdIHwgdW5kZWZpbmVkXG4gIDogUyBleHRlbmRzIHsgW0s6IHN0cmluZ106IGFueSB9XG4gID8gRGVub3JtYWxpemVOdWxsYWJsZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZTxTPiA9IFMgZXh0ZW5kcyBFbnRpdHlJbnRlcmZhY2VcbiAgPyBzdHJpbmdcbiAgOiBTIGV4dGVuZHMgUmVjb3JkQ2xhc3NcbiAgPyBOb3JtYWxpemVPYmplY3Q8U1snc2NoZW1hJ10+XG4gIDogUyBleHRlbmRzIHsgbm9ybWFsaXplOiAoLi4uYXJnczogYW55KSA9PiBhbnkgfVxuICA/IE5vcm1hbGl6ZVJldHVyblR5cGU8U1snbm9ybWFsaXplJ10+XG4gIDogUyBleHRlbmRzIFNlcmlhbGl6YWJsZTxpbmZlciBUPlxuICA/IFRcbiAgOiBTIGV4dGVuZHMgQXJyYXk8aW5mZXIgRj5cbiAgPyBOb3JtYWxpemU8Rj5bXVxuICA6IFMgZXh0ZW5kcyB7IFtLOiBzdHJpbmddOiBhbnkgfVxuICA/IE5vcm1hbGl6ZU9iamVjdDxTPlxuICA6IFM7XG5cbmV4cG9ydCB0eXBlIE5vcm1hbGl6ZU51bGxhYmxlPFM+ID0gUyBleHRlbmRzIEVudGl0eUludGVyZmFjZVxuICA/IHN0cmluZyB8IHVuZGVmaW5lZFxuICA6IFMgZXh0ZW5kcyBSZWNvcmRDbGFzc1xuICA/IE5vcm1hbGl6ZWROdWxsYWJsZU9iamVjdDxTWydzY2hlbWEnXT5cbiAgOiBTIGV4dGVuZHMgeyBfbm9ybWFsaXplTnVsbGFibGU6ICguLi5hcmdzOiBhbnkpID0+IGFueSB9XG4gID8gTm9ybWFsaXplUmV0dXJuVHlwZTxTWydfbm9ybWFsaXplTnVsbGFibGUnXT5cbiAgOiBTIGV4dGVuZHMgU2VyaWFsaXphYmxlPGluZmVyIFQ+XG4gID8gVFxuICA6IFMgZXh0ZW5kcyBBcnJheTxpbmZlciBGPlxuICA/IE5vcm1hbGl6ZTxGPltdIHwgdW5kZWZpbmVkXG4gIDogUyBleHRlbmRzIHsgW0s6IHN0cmluZ106IGFueSB9XG4gID8gTm9ybWFsaXplZE51bGxhYmxlT2JqZWN0PFM+XG4gIDogUztcblxuZXhwb3J0IHR5cGUgTm9ybWFsaXplZFNjaGVtYTxFLCBSPiA9IHtcbiAgZW50aXRpZXM6IEU7XG4gIHJlc3VsdDogUjtcbiAgaW5kZXhlczogTm9ybWFsaXplZEluZGV4O1xuICBlbnRpdHlNZXRhOiB7XG4gICAgcmVhZG9ubHkgW2VudGl0eUtleTogc3RyaW5nXToge1xuICAgICAgcmVhZG9ubHkgW3BrOiBzdHJpbmddOiB7XG4gICAgICAgIHJlYWRvbmx5IGRhdGU6IG51bWJlcjtcbiAgICAgICAgcmVhZG9ubHkgZXhwaXJlc0F0OiBudW1iZXI7XG4gICAgICAgIHJlYWRvbmx5IGZldGNoZWRBdDogbnVtYmVyO1xuICAgICAgfTtcbiAgICB9O1xuICB9O1xufTtcblxuZXhwb3J0IHR5cGUgRW50aXR5TWFwPFQgPSBhbnk+ID0gUmVjb3JkPHN0cmluZywgRW50aXR5SW50ZXJmYWNlPFQ+PjtcbiJdLCJtYXBwaW5ncyI6IiJ9 |
{ | ||
"name": "@data-client/normalizr", | ||
"version": "0.2.2", | ||
"version": "0.8.0", | ||
"description": "Normalizes and denormalizes JSON according to schema for Redux and Flux applications", | ||
"homepage": "https://resthooks.io/docs/concepts/normalization", | ||
"homepage": "https://dataclient.io/docs/concepts/normalization", | ||
"bugs": { | ||
@@ -7,0 +7,0 @@ "url": "https://github.com/data-client/data-client/issues" |
@@ -29,8 +29,8 @@ # normalizr | ||
- [Introduction](https://resthooks.io/docs/concepts/normalization) | ||
- [Quick Start](https://resthooks.io/rest/api/schema) | ||
- [API](https://resthooks.io/rest/api/Entity) | ||
- [Introduction](https://dataclient.io/docs/concepts/normalization) | ||
- [Quick Start](https://dataclient.io/rest/api/schema) | ||
- [API](https://dataclient.io/rest/api/Entity) | ||
- [normalize](./docs/api.md#normalizedata-schema) | ||
- [denormalize](./docs/api.md#denormalizeinput-schema-entities) | ||
- [schema](https://resthooks.io/rest/api/schema) | ||
- [schema](https://dataclient.io/rest/api/schema) | ||
@@ -37,0 +37,0 @@ ## Examples |
@@ -7,10 +7,8 @@ import { denormalize } from './denormalize/denormalize.js'; | ||
export { default as inferResults, validateInference } from './inferResults.js'; | ||
export { DELETED } from './special.js'; | ||
export { AbstractInstanceType, NormalizeReturnType, NormalizedSchema, DenormalizeReturnType, DenormalizeCache, Path, } from './types.js'; | ||
export { AbstractInstanceType, NormalizeReturnType, NormalizedSchema, DenormalizeCache, Path, Denormalize, DenormalizeNullable, Normalize, NormalizeNullable, } from './types.js'; | ||
export * from './endpoint/types.js'; | ||
export * from './interface.js'; | ||
export * from './Expiry.js'; | ||
export * from './normal.js'; | ||
export { INVALID } from './denormalize/symbol.js'; | ||
export { denormalize, denormalizeCached, normalize, isEntity, WeakEntityMap }; | ||
//# sourceMappingURL=index.d.ts.map |
@@ -8,13 +8,6 @@ export type Schema = null | string | { | ||
toJSON(): string; | ||
}> = { | ||
prototype: T; | ||
}; | ||
}> = (value: any) => T; | ||
export interface SchemaSimple<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; | ||
denormalize?(input: {}, unvisit: UnvisitFunction): [ | ||
/*denormalized*/ T, | ||
/*found*/ boolean, | ||
/*suspend*/ boolean | ||
]; | ||
denormalizeOnly?(input: {}, args: any, unvisit: (input: any, schema: any) => any): T; | ||
denormalize(input: {}, args: any, unvisit: (input: any, schema: any) => any): T; | ||
infer(args: readonly any[], indexes: NormalizedIndex, recurse: (...args: any) => any, entities: EntityTable): any; | ||
@@ -24,19 +17,11 @@ } | ||
_normalizeNullable(): any; | ||
_denormalizeNullable(): [ | ||
N, | ||
boolean, | ||
boolean | ||
]; | ||
_denormalizeNullable(): N; | ||
} | ||
export interface EntityInterface<T = any> extends SchemaSimple { | ||
createIfValid?(props: any): any; | ||
createIfValid(props: any): any; | ||
pk(params: any, parent?: any, key?: string, args?: readonly any[]): string | undefined; | ||
readonly key: string; | ||
merge(existing: any, incoming: any): any; | ||
/** @deprecated use mergeWithStore instead (which can call this) */ | ||
expiresAt?(meta: any, input: any): number; | ||
mergeWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
mergeMetaWithStore?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
/** @deprecated use mergeWithStore instead (which can call this) */ | ||
useIncoming?(existingMeta: any, incomingMeta: any, existing: any, incoming: any): boolean; | ||
mergeWithStore(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
mergeMetaWithStore(existingMeta: any, incomingMeta: any, existing: any, incoming: any): any; | ||
indexes?: any; | ||
@@ -47,11 +32,2 @@ schema: Record<string, Schema>; | ||
} | ||
export interface UnvisitFunction { | ||
(input: any, schema: any): [ | ||
any, | ||
boolean, | ||
boolean | ||
] | any; | ||
og?: UnvisitFunction; | ||
setLocal?: (entity: any) => void; | ||
} | ||
export interface NormalizedIndex { | ||
@@ -58,0 +34,0 @@ readonly [entityKey: string]: { |
@@ -48,13 +48,6 @@ import { Schema, Serializable, EntityInterface, NormalizedIndex } from './interface.js'; | ||
export type DenormalizeNullableNestedSchema<S extends NestedSchemaClass> = keyof S['schema'] extends never ? S['prototype'] : string extends keyof S['schema'] ? S['prototype'] : S['prototype']; | ||
export type DenormalizeReturnType<T> = T extends (input: any, unvisit: any) => [ | ||
infer R, | ||
any, | ||
any | ||
] ? R : never; | ||
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 { | ||
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 { | ||
} ? ReturnType<S['denormalize']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] : S extends { | ||
[K: string]: any; | ||
@@ -64,3 +57,3 @@ } ? DenormalizeObject<S> : S; | ||
_denormalizeNullable: (...args: any) => any; | ||
} ? DenormalizeReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
} ? ReturnType<S['_denormalizeNullable']> : S extends Serializable<infer T> ? T : S extends Array<infer F> ? Denormalize<F>[] | undefined : S extends { | ||
[K: string]: any; | ||
@@ -67,0 +60,0 @@ } ? DenormalizeNullableObject<S> : S; |
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
411435
130
4734