payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
198 lines (197 loc) • 20.2 kB
JavaScript
/* eslint-disable no-param-reassign */ "use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "promise", {
enumerable: true,
get: function() {
return promise;
}
});
const _types = require("../../config/types");
const _traverseFields = require("./traverseFields");
const promise = async ({ collection, context, data, doc, field, global, operation, previousDoc, previousSiblingDoc, req, siblingData, siblingDoc })=>{
if ((0, _types.fieldAffectsData)(field)) {
// Execute hooks
if (field.hooks?.afterChange) {
await field.hooks.afterChange.reduce(async (priorHook, currentHook)=>{
await priorHook;
const hookedValue = await currentHook({
collection,
context,
data,
field,
global,
operation,
originalDoc: doc,
previousDoc,
previousSiblingDoc,
previousValue: previousDoc[field.name],
req,
siblingData,
value: siblingData[field.name]
});
if (hookedValue !== undefined) {
siblingDoc[field.name] = hookedValue;
}
}, Promise.resolve());
}
}
// Traverse subfields
switch(field.type){
case 'group':
{
await (0, _traverseFields.traverseFields)({
collection,
context,
data,
doc,
fields: field.fields,
global,
operation,
previousDoc,
previousSiblingDoc: previousDoc[field.name],
req,
siblingData: siblingData?.[field.name] || {},
siblingDoc: siblingDoc[field.name]
});
break;
}
case 'array':
{
const rows = siblingDoc[field.name];
if (Array.isArray(rows)) {
const promises = [];
rows.forEach((row, i)=>{
promises.push((0, _traverseFields.traverseFields)({
collection,
context,
data,
doc,
fields: field.fields,
global,
operation,
previousDoc,
previousSiblingDoc: previousDoc?.[field.name]?.[i] || {},
req,
siblingData: siblingData?.[field.name]?.[i] || {},
siblingDoc: {
...row
} || {}
}));
});
await Promise.all(promises);
}
break;
}
case 'blocks':
{
const rows = siblingDoc[field.name];
if (Array.isArray(rows)) {
const promises = [];
rows.forEach((row, i)=>{
const block = field.blocks.find((blockType)=>blockType.slug === row.blockType);
if (block) {
promises.push((0, _traverseFields.traverseFields)({
collection,
context,
data,
doc,
fields: block.fields,
global,
operation,
previousDoc,
previousSiblingDoc: previousDoc?.[field.name]?.[i] || {},
req,
siblingData: siblingData?.[field.name]?.[i] || {},
siblingDoc: {
...row
} || {}
}));
}
});
await Promise.all(promises);
}
break;
}
case 'row':
case 'collapsible':
{
await (0, _traverseFields.traverseFields)({
collection,
context,
data,
doc,
fields: field.fields,
global,
operation,
previousDoc,
previousSiblingDoc: {
...previousSiblingDoc
},
req,
siblingData: siblingData || {},
siblingDoc: {
...siblingDoc
}
});
break;
}
case 'tab':
{
let tabSiblingData = siblingData;
let tabSiblingDoc = siblingDoc;
let tabPreviousSiblingDoc = siblingDoc;
if ((0, _types.tabHasName)(field)) {
tabSiblingData = siblingData[field.name];
tabSiblingDoc = siblingDoc[field.name];
tabPreviousSiblingDoc = previousDoc[field.name];
}
await (0, _traverseFields.traverseFields)({
collection,
context,
data,
doc,
fields: field.fields,
global,
operation,
previousDoc,
previousSiblingDoc: tabPreviousSiblingDoc,
req,
siblingData: tabSiblingData,
siblingDoc: tabSiblingDoc
});
break;
}
case 'tabs':
{
await (0, _traverseFields.traverseFields)({
collection,
context,
data,
doc,
fields: field.tabs.map((tab)=>({
...tab,
type: 'tab'
})),
global,
operation,
previousDoc,
previousSiblingDoc: {
...previousSiblingDoc
},
req,
siblingData: siblingData || {},
siblingDoc: {
...siblingDoc
}
});
break;
}
default:
{
break;
}
}
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../src/fields/hooks/afterChange/promise.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { SanitizedCollectionConfig } from '../../../collections/config/types'\nimport type { PayloadRequest, RequestContext } from '../../../express/types'\nimport type { SanitizedGlobalConfig } from '../../../globals/config/types'\nimport type { Field, TabAsField } from '../../config/types'\n\nimport { fieldAffectsData, tabHasName } from '../../config/types'\nimport { traverseFields } from './traverseFields'\n\ntype Args = {\n  collection: SanitizedCollectionConfig | null\n  context: RequestContext\n  data: Record<string, unknown>\n  doc: Record<string, unknown>\n  field: Field | TabAsField\n  global: SanitizedGlobalConfig | null\n  operation: 'create' | 'update'\n  previousDoc: Record<string, unknown>\n  previousSiblingDoc: Record<string, unknown>\n  req: PayloadRequest\n  siblingData: Record<string, unknown>\n  siblingDoc: Record<string, unknown>\n}\n\n// This function is responsible for the following actions, in order:\n// - Execute field hooks\n\nexport const promise = async ({\n  collection,\n  context,\n  data,\n  doc,\n  field,\n  global,\n  operation,\n  previousDoc,\n  previousSiblingDoc,\n  req,\n  siblingData,\n  siblingDoc,\n}: Args): Promise<void> => {\n  if (fieldAffectsData(field)) {\n    // Execute hooks\n    if (field.hooks?.afterChange) {\n      await field.hooks.afterChange.reduce(async (priorHook, currentHook) => {\n        await priorHook\n\n        const hookedValue = await currentHook({\n          collection,\n          context,\n          data,\n          field,\n          global,\n          operation,\n          originalDoc: doc,\n          previousDoc,\n          previousSiblingDoc,\n          previousValue: previousDoc[field.name],\n          req,\n          siblingData,\n          value: siblingData[field.name],\n        })\n\n        if (hookedValue !== undefined) {\n          siblingDoc[field.name] = hookedValue\n        }\n      }, Promise.resolve())\n    }\n  }\n\n  // Traverse subfields\n  switch (field.type) {\n    case 'group': {\n      await traverseFields({\n        collection,\n        context,\n        data,\n        doc,\n        fields: field.fields,\n        global,\n        operation,\n        previousDoc,\n        previousSiblingDoc: previousDoc[field.name] as Record<string, unknown>,\n        req,\n        siblingData: (siblingData?.[field.name] as Record<string, unknown>) || {},\n        siblingDoc: siblingDoc[field.name] as Record<string, unknown>,\n      })\n\n      break\n    }\n\n    case 'array': {\n      const rows = siblingDoc[field.name]\n\n      if (Array.isArray(rows)) {\n        const promises = []\n        rows.forEach((row, i) => {\n          promises.push(\n            traverseFields({\n              collection,\n              context,\n              data,\n              doc,\n              fields: field.fields,\n              global,\n              operation,\n              previousDoc,\n              previousSiblingDoc: previousDoc?.[field.name]?.[i] || ({} as Record<string, unknown>),\n              req,\n              siblingData: siblingData?.[field.name]?.[i] || {},\n              siblingDoc: { ...row } || {},\n            }),\n          )\n        })\n        await Promise.all(promises)\n      }\n      break\n    }\n\n    case 'blocks': {\n      const rows = siblingDoc[field.name]\n\n      if (Array.isArray(rows)) {\n        const promises = []\n        rows.forEach((row, i) => {\n          const block = field.blocks.find((blockType) => blockType.slug === row.blockType)\n\n          if (block) {\n            promises.push(\n              traverseFields({\n                collection,\n                context,\n                data,\n                doc,\n                fields: block.fields,\n                global,\n                operation,\n                previousDoc,\n                previousSiblingDoc:\n                  previousDoc?.[field.name]?.[i] || ({} as Record<string, unknown>),\n                req,\n                siblingData: siblingData?.[field.name]?.[i] || {},\n                siblingDoc: { ...row } || {},\n              }),\n            )\n          }\n        })\n        await Promise.all(promises)\n      }\n\n      break\n    }\n\n    case 'row':\n    case 'collapsible': {\n      await traverseFields({\n        collection,\n        context,\n        data,\n        doc,\n        fields: field.fields,\n        global,\n        operation,\n        previousDoc,\n        previousSiblingDoc: { ...previousSiblingDoc },\n        req,\n        siblingData: siblingData || {},\n        siblingDoc: { ...siblingDoc },\n      })\n\n      break\n    }\n\n    case 'tab': {\n      let tabSiblingData = siblingData\n      let tabSiblingDoc = siblingDoc\n      let tabPreviousSiblingDoc = siblingDoc\n\n      if (tabHasName(field)) {\n        tabSiblingData = siblingData[field.name] as Record<string, unknown>\n        tabSiblingDoc = siblingDoc[field.name] as Record<string, unknown>\n        tabPreviousSiblingDoc = previousDoc[field.name] as Record<string, unknown>\n      }\n\n      await traverseFields({\n        collection,\n        context,\n        data,\n        doc,\n        fields: field.fields,\n        global,\n        operation,\n        previousDoc,\n        previousSiblingDoc: tabPreviousSiblingDoc,\n        req,\n        siblingData: tabSiblingData,\n        siblingDoc: tabSiblingDoc,\n      })\n\n      break\n    }\n\n    case 'tabs': {\n      await traverseFields({\n        collection,\n        context,\n        data,\n        doc,\n        fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n        global,\n        operation,\n        previousDoc,\n        previousSiblingDoc: { ...previousSiblingDoc },\n        req,\n        siblingData: siblingData || {},\n        siblingDoc: { ...siblingDoc },\n      })\n      break\n    }\n\n    default: {\n      break\n    }\n  }\n}\n"],"names":["promise","collection","context","data","doc","field","global","operation","previousDoc","previousSiblingDoc","req","siblingData","siblingDoc","fieldAffectsData","hooks","afterChange","reduce","priorHook","currentHook","hookedValue","originalDoc","previousValue","name","value","undefined","Promise","resolve","type","traverseFields","fields","rows","Array","isArray","promises","forEach","row","i","push","all","block","blocks","find","blockType","slug","tabSiblingData","tabSiblingDoc","tabPreviousSiblingDoc","tabHasName","tabs","map","tab"],"mappings":"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"}