payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
344 lines (343 loc) • 48.7 kB
JavaScript
/* eslint-disable no-param-reassign */ "use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "addFieldStatePromise", {
enumerable: true,
get: function() {
return addFieldStatePromise;
}
});
const _bsonobjectid = /*#__PURE__*/ _interop_require_default(require("bson-objectid"));
const _types = require("../../../../../fields/config/types");
const _getDefaultValue = /*#__PURE__*/ _interop_require_default(require("../../../../../fields/getDefaultValue"));
const _iterateFields = require("./iterateFields");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
const addFieldStatePromise = async (args)=>{
const { id, anyParentLocalized = false, config, data, field, filter, forceFullValue = false, fullData, includeSchema = false, locale, omitParents = false, operation, passesCondition, path, preferences, skipConditionChecks = false, skipValidation = false, state, t, user } = args;
if ((0, _types.fieldAffectsData)(field)) {
const fieldState = {
condition: field.admin?.condition,
fieldSchema: includeSchema ? field : undefined,
initialValue: undefined,
passesCondition,
valid: true,
validate: field.validate,
value: undefined
};
const valueWithDefault = await (0, _getDefaultValue.default)({
defaultValue: field.defaultValue,
locale,
user,
value: data?.[field.name]
});
if (data?.[field.name]) {
data[field.name] = valueWithDefault;
}
let validationResult = true;
if (typeof fieldState.validate === 'function' && !skipValidation) {
validationResult = await fieldState.validate(data?.[field.name], {
...field,
id,
config,
data: fullData,
operation,
siblingData: data,
t,
user
});
}
if (typeof validationResult === 'string') {
fieldState.errorMessage = validationResult;
fieldState.valid = false;
} else {
fieldState.valid = true;
}
switch(field.type){
case 'array':
{
const arrayValue = Array.isArray(valueWithDefault) ? valueWithDefault : [];
const { promises, rowMetadata } = arrayValue.reduce((acc, row, i)=>{
const rowPath = `${path}${field.name}.${i}.`;
row.id = row?.id || new _bsonobjectid.default().toHexString();
if (!omitParents && (!filter || filter(args))) {
state[`${rowPath}id`] = {
fieldSchema: includeSchema ? field.fields.find((field)=>'name' in field && field.name === 'id') : undefined,
initialValue: row.id,
valid: true,
value: row.id
};
}
acc.promises.push((0, _iterateFields.iterateFields)({
id,
anyParentLocalized: field.localized || anyParentLocalized,
config,
data: row,
fields: field.fields,
filter,
forceFullValue,
fullData,
includeSchema,
locale,
omitParents,
operation,
parentPassesCondition: passesCondition,
path: rowPath,
preferences,
skipConditionChecks,
skipValidation,
state,
t,
user
}));
const collapsedRowIDs = preferences?.fields?.[`${path}${field.name}`]?.collapsed;
acc.rowMetadata.push({
id: row.id,
childErrorPaths: new Set(),
collapsed: collapsedRowIDs === undefined ? field.admin.initCollapsed : collapsedRowIDs.includes(row.id)
});
return acc;
}, {
promises: [],
rowMetadata: []
});
await Promise.all(promises);
// Add values to field state
if (valueWithDefault === null) {
fieldState.value = null;
fieldState.initialValue = null;
} else {
fieldState.value = forceFullValue ? arrayValue : arrayValue.length;
fieldState.initialValue = forceFullValue ? arrayValue : arrayValue.length;
if (arrayValue.length > 0) {
fieldState.disableFormData = true;
}
}
fieldState.rows = rowMetadata;
// Add field to state
if (!omitParents && (!filter || filter(args))) {
state[`${path}${field.name}`] = fieldState;
}
break;
}
case 'blocks':
{
const blocksValue = Array.isArray(valueWithDefault) ? valueWithDefault : [];
const { promises, rowMetadata } = blocksValue.reduce((acc, row, i)=>{
const block = field.blocks.find((blockType)=>blockType.slug === row.blockType);
const rowPath = `${path}${field.name}.${i}.`;
if (block) {
row.id = row?.id || new _bsonobjectid.default().toHexString();
if (!omitParents && (!filter || filter(args))) {
state[`${rowPath}id`] = {
fieldSchema: includeSchema ? block.fields.find((blockField)=>'name' in blockField && blockField.name === 'id') : undefined,
initialValue: row.id,
valid: true,
value: row.id
};
state[`${rowPath}blockType`] = {
fieldSchema: includeSchema ? block.fields.find((blockField)=>'name' in blockField && blockField.name === 'blockType') : undefined,
initialValue: row.blockType,
valid: true,
value: row.blockType
};
state[`${rowPath}blockName`] = {
fieldSchema: includeSchema ? block.fields.find((blockField)=>'name' in blockField && blockField.name === 'blockName') : undefined,
initialValue: row.blockName,
valid: true,
value: row.blockName
};
}
acc.promises.push((0, _iterateFields.iterateFields)({
id,
anyParentLocalized: field.localized || anyParentLocalized,
config,
data: row,
fields: block.fields,
filter,
forceFullValue,
fullData,
includeSchema,
locale,
omitParents,
operation,
parentPassesCondition: passesCondition,
path: rowPath,
preferences,
skipConditionChecks,
skipValidation,
state,
t,
user
}));
const collapsedRowIDs = preferences?.fields?.[`${path}${field.name}`]?.collapsed;
acc.rowMetadata.push({
id: row.id,
blockType: row.blockType,
childErrorPaths: new Set(),
collapsed: collapsedRowIDs === undefined ? field.admin.initCollapsed : collapsedRowIDs.includes(row.id)
});
}
return acc;
}, {
promises: [],
rowMetadata: []
});
await Promise.all(promises);
// Add values to field state
if (valueWithDefault === null) {
fieldState.value = null;
fieldState.initialValue = null;
} else {
fieldState.value = forceFullValue ? blocksValue : blocksValue.length;
fieldState.initialValue = forceFullValue ? blocksValue : blocksValue.length;
if (blocksValue.length > 0) {
fieldState.disableFormData = true;
}
}
fieldState.rows = rowMetadata;
// Add field to state
if (!omitParents && (!filter || filter(args))) {
state[`${path}${field.name}`] = fieldState;
}
break;
}
case 'group':
{
await (0, _iterateFields.iterateFields)({
id,
anyParentLocalized: field.localized || anyParentLocalized,
config,
data: data?.[field.name] || {},
fields: field.fields,
filter,
forceFullValue,
fullData,
includeSchema,
locale,
omitParents,
operation,
parentPassesCondition: passesCondition,
path: `${path}${field.name}.`,
preferences,
skipConditionChecks,
skipValidation,
state,
t,
user
});
break;
}
case 'relationship':
{
if (field.hasMany) {
const relationshipValue = Array.isArray(valueWithDefault) ? valueWithDefault.map((relationship)=>{
if (Array.isArray(field.relationTo)) {
return {
relationTo: relationship.relationTo,
value: relationship.value && typeof relationship.value === 'object' ? relationship.value?.id : relationship.value
};
}
if (typeof relationship === 'object' && relationship !== null) {
return relationship.id;
}
return relationship;
}) : undefined;
fieldState.value = relationshipValue;
fieldState.initialValue = relationshipValue;
} else if (Array.isArray(field.relationTo)) {
if (valueWithDefault && typeof valueWithDefault === 'object' && 'relationTo' in valueWithDefault && 'value' in valueWithDefault) {
const value = typeof valueWithDefault?.value === 'object' && valueWithDefault?.value && 'id' in valueWithDefault.value ? valueWithDefault.value.id : valueWithDefault.value;
const relationshipValue = {
relationTo: valueWithDefault?.relationTo,
value
};
fieldState.value = relationshipValue;
fieldState.initialValue = relationshipValue;
}
} else {
const relationshipValue = valueWithDefault && typeof valueWithDefault === 'object' && 'id' in valueWithDefault ? valueWithDefault.id : valueWithDefault;
fieldState.value = relationshipValue;
fieldState.initialValue = relationshipValue;
}
if (!filter || filter(args)) {
state[`${path}${field.name}`] = fieldState;
}
break;
}
case 'upload':
{
const relationshipValue = valueWithDefault && typeof valueWithDefault === 'object' && 'id' in valueWithDefault ? valueWithDefault.id : valueWithDefault;
fieldState.value = relationshipValue;
fieldState.initialValue = relationshipValue;
if (!filter || filter(args)) {
state[`${path}${field.name}`] = fieldState;
}
break;
}
default:
{
fieldState.value = valueWithDefault;
fieldState.initialValue = valueWithDefault;
// Add field to state
if (!filter || filter(args)) {
state[`${path}${field.name}`] = fieldState;
}
break;
}
}
} else if ((0, _types.fieldHasSubFields)(field)) {
// Handle field types that do not use names (row, etc)
await (0, _iterateFields.iterateFields)({
id,
anyParentLocalized: field.localized || anyParentLocalized,
config,
data,
fields: field.fields,
filter,
forceFullValue,
fullData,
includeSchema,
locale,
omitParents,
operation,
parentPassesCondition: passesCondition,
path,
preferences,
skipConditionChecks,
skipValidation,
state,
t,
user
});
} else if (field.type === 'tabs') {
const promises = field.tabs.map((tab)=>(0, _iterateFields.iterateFields)({
id,
anyParentLocalized: tab.localized || anyParentLocalized,
config,
data: (0, _types.tabHasName)(tab) ? data?.[tab.name] : data,
fields: tab.fields,
filter,
forceFullValue,
fullData,
includeSchema,
locale,
omitParents,
operation,
parentPassesCondition: passesCondition,
path: (0, _types.tabHasName)(tab) ? `${path}${tab.name}.` : path,
preferences,
skipConditionChecks,
skipValidation,
state,
t,
user
}));
await Promise.all(promises);
}
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/admin/components/forms/Form/buildStateFromSchema/addFieldStatePromise.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { TFunction } from 'i18next'\n\nimport ObjectID from 'bson-objectid'\n\nimport type { User } from '../../../../../auth'\nimport type { SanitizedConfig } from '../../../../../config/types'\nimport type { NonPresentationalField } from '../../../../../fields/config/types'\nimport type { Data, Fields, FormField } from '../types'\n\nimport { fieldAffectsData, fieldHasSubFields, tabHasName } from '../../../../../fields/config/types'\nimport getValueWithDefault from '../../../../../fields/getDefaultValue'\nimport { iterateFields } from './iterateFields'\n\nexport type AddFieldStatePromiseArgs = {\n  /**\n   * if all parents are localized, then the field is localized\n   */\n  anyParentLocalized?: boolean\n  config: SanitizedConfig\n  data: Data\n  field: NonPresentationalField\n  /**\n   * You can use this to filter down to only `localized` fields that require transalation (type: text, textarea, etc.). Another plugin might want to look for only `point` type fields to do some GIS function. With the filter function you can go in like a surgeon.\n   */\n  filter?: (args: AddFieldStatePromiseArgs) => boolean\n  /**\n   * Force the value of fields like arrays or blocks to be the full value instead of the length @default false\n   */\n  forceFullValue?: boolean\n  fullData: Data\n  id: number | string\n  /**\n   * Whether the field schema should be included in the state\n   */\n  includeSchema?: boolean\n  locale: string\n  /**\n   * Whether to omit parent fields in the state. @default false\n   */\n  omitParents?: boolean\n  operation: 'create' | 'update'\n  passesCondition: boolean\n  path: string\n  preferences: {\n    [key: string]: unknown\n  }\n  /**\n   * Whether to skip checking the field's condition. @default false\n   */\n  skipConditionChecks?: boolean\n  /**\n   * Whether to skip validating the field. @default false\n   */\n  skipValidation?: boolean\n  state: Fields\n  t: TFunction\n  user: User\n}\n\n/**\n * Flattens the fields schema and fields data.\n * The output is the field path (e.g. array.0.name) mapped to a FormField object.\n */\nexport const addFieldStatePromise = async (args: AddFieldStatePromiseArgs): Promise<void> => {\n  const {\n    id,\n    anyParentLocalized = false,\n    config,\n    data,\n    field,\n    filter,\n    forceFullValue = false,\n    fullData,\n    includeSchema = false,\n    locale,\n    omitParents = false,\n    operation,\n    passesCondition,\n    path,\n    preferences,\n    skipConditionChecks = false,\n    skipValidation = false,\n    state,\n    t,\n    user,\n  } = args\n  if (fieldAffectsData(field)) {\n    const fieldState: FormField = {\n      condition: field.admin?.condition,\n      fieldSchema: includeSchema ? field : undefined,\n      initialValue: undefined,\n      passesCondition,\n      valid: true,\n      validate: field.validate,\n      value: undefined,\n    }\n\n    const valueWithDefault = await getValueWithDefault({\n      defaultValue: field.defaultValue,\n      locale,\n      user,\n      value: data?.[field.name],\n    })\n\n    if (data?.[field.name]) {\n      data[field.name] = valueWithDefault\n    }\n\n    let validationResult: string | true = true\n\n    if (typeof fieldState.validate === 'function' && !skipValidation) {\n      validationResult = await fieldState.validate(data?.[field.name], {\n        ...field,\n        id,\n        config,\n        data: fullData,\n        operation,\n        siblingData: data,\n        t,\n        user,\n      })\n    }\n\n    if (typeof validationResult === 'string') {\n      fieldState.errorMessage = validationResult\n      fieldState.valid = false\n    } else {\n      fieldState.valid = true\n    }\n\n    switch (field.type) {\n      case 'array': {\n        const arrayValue = Array.isArray(valueWithDefault) ? valueWithDefault : []\n        const { promises, rowMetadata } = arrayValue.reduce(\n          (acc, row, i) => {\n            const rowPath = `${path}${field.name}.${i}.`\n            row.id = row?.id || new ObjectID().toHexString()\n\n            if (!omitParents && (!filter || filter(args))) {\n              state[`${rowPath}id`] = {\n                fieldSchema: includeSchema\n                  ? field.fields.find((field) => 'name' in field && field.name === 'id')\n                  : undefined,\n                initialValue: row.id,\n                valid: true,\n                value: row.id,\n              }\n            }\n\n            acc.promises.push(\n              iterateFields({\n                id,\n                anyParentLocalized: field.localized || anyParentLocalized,\n                config,\n                data: row,\n                fields: field.fields,\n                filter,\n                forceFullValue,\n                fullData,\n                includeSchema,\n                locale,\n                omitParents,\n                operation,\n                parentPassesCondition: passesCondition,\n                path: rowPath,\n                preferences,\n                skipConditionChecks,\n                skipValidation,\n                state,\n                t,\n                user,\n              }),\n            )\n\n            const collapsedRowIDs = preferences?.fields?.[`${path}${field.name}`]?.collapsed\n\n            acc.rowMetadata.push({\n              id: row.id,\n              childErrorPaths: new Set(),\n              collapsed:\n                collapsedRowIDs === undefined\n                  ? field.admin.initCollapsed\n                  : collapsedRowIDs.includes(row.id),\n            })\n\n            return acc\n          },\n          {\n            promises: [],\n            rowMetadata: [],\n          },\n        )\n\n        await Promise.all(promises)\n\n        // Add values to field state\n        if (valueWithDefault === null) {\n          fieldState.value = null\n          fieldState.initialValue = null\n        } else {\n          fieldState.value = forceFullValue ? arrayValue : arrayValue.length\n          fieldState.initialValue = forceFullValue ? arrayValue : arrayValue.length\n\n          if (arrayValue.length > 0) {\n            fieldState.disableFormData = true\n          }\n        }\n\n        fieldState.rows = rowMetadata\n\n        // Add field to state\n        if (!omitParents && (!filter || filter(args))) {\n          state[`${path}${field.name}`] = fieldState\n        }\n\n        break\n      }\n\n      case 'blocks': {\n        const blocksValue = Array.isArray(valueWithDefault) ? valueWithDefault : []\n\n        const { promises, rowMetadata } = blocksValue.reduce(\n          (acc, row, i) => {\n            const block = field.blocks.find((blockType) => blockType.slug === row.blockType)\n            const rowPath = `${path}${field.name}.${i}.`\n\n            if (block) {\n              row.id = row?.id || new ObjectID().toHexString()\n\n              if (!omitParents && (!filter || filter(args))) {\n                state[`${rowPath}id`] = {\n                  fieldSchema: includeSchema\n                    ? block.fields.find(\n                        (blockField) => 'name' in blockField && blockField.name === 'id',\n                      )\n                    : undefined,\n                  initialValue: row.id,\n                  valid: true,\n                  value: row.id,\n                }\n\n                state[`${rowPath}blockType`] = {\n                  fieldSchema: includeSchema\n                    ? block.fields.find(\n                        (blockField) => 'name' in blockField && blockField.name === 'blockType',\n                      )\n                    : undefined,\n                  initialValue: row.blockType,\n                  valid: true,\n                  value: row.blockType,\n                }\n\n                state[`${rowPath}blockName`] = {\n                  fieldSchema: includeSchema\n                    ? block.fields.find(\n                        (blockField) => 'name' in blockField && blockField.name === 'blockName',\n                      )\n                    : undefined,\n                  initialValue: row.blockName,\n                  valid: true,\n                  value: row.blockName,\n                }\n              }\n\n              acc.promises.push(\n                iterateFields({\n                  id,\n                  anyParentLocalized: field.localized || anyParentLocalized,\n                  config,\n                  data: row,\n                  fields: block.fields,\n                  filter,\n                  forceFullValue,\n                  fullData,\n                  includeSchema,\n                  locale,\n                  omitParents,\n                  operation,\n                  parentPassesCondition: passesCondition,\n                  path: rowPath,\n                  preferences,\n                  skipConditionChecks,\n                  skipValidation,\n                  state,\n                  t,\n                  user,\n                }),\n              )\n\n              const collapsedRowIDs = preferences?.fields?.[`${path}${field.name}`]?.collapsed\n\n              acc.rowMetadata.push({\n                id: row.id,\n                blockType: row.blockType,\n                childErrorPaths: new Set(),\n                collapsed:\n                  collapsedRowIDs === undefined\n                    ? field.admin.initCollapsed\n                    : collapsedRowIDs.includes(row.id),\n              })\n            }\n\n            return acc\n          },\n          {\n            promises: [],\n            rowMetadata: [],\n          },\n        )\n\n        await Promise.all(promises)\n\n        // Add values to field state\n        if (valueWithDefault === null) {\n          fieldState.value = null\n          fieldState.initialValue = null\n        } else {\n          fieldState.value = forceFullValue ? blocksValue : blocksValue.length\n          fieldState.initialValue = forceFullValue ? blocksValue : blocksValue.length\n\n          if (blocksValue.length > 0) {\n            fieldState.disableFormData = true\n          }\n        }\n\n        fieldState.rows = rowMetadata\n\n        // Add field to state\n        if (!omitParents && (!filter || filter(args))) {\n          state[`${path}${field.name}`] = fieldState\n        }\n\n        break\n      }\n\n      case 'group': {\n        await iterateFields({\n          id,\n          anyParentLocalized: field.localized || anyParentLocalized,\n          config,\n          data: data?.[field.name] || {},\n          fields: field.fields,\n          filter,\n          forceFullValue,\n          fullData,\n          includeSchema,\n          locale,\n          omitParents,\n          operation,\n          parentPassesCondition: passesCondition,\n          path: `${path}${field.name}.`,\n          preferences,\n          skipConditionChecks,\n          skipValidation,\n          state,\n          t,\n          user,\n        })\n\n        break\n      }\n\n      case 'relationship': {\n        if (field.hasMany) {\n          const relationshipValue = Array.isArray(valueWithDefault)\n            ? valueWithDefault.map((relationship) => {\n                if (Array.isArray(field.relationTo)) {\n                  return {\n                    relationTo: relationship.relationTo,\n                    value:\n                      relationship.value && typeof relationship.value === 'object'\n                        ? relationship.value?.id\n                        : relationship.value,\n                  }\n                }\n                if (typeof relationship === 'object' && relationship !== null) {\n                  return relationship.id\n                }\n                return relationship\n              })\n            : undefined\n\n          fieldState.value = relationshipValue\n          fieldState.initialValue = relationshipValue\n        } else if (Array.isArray(field.relationTo)) {\n          if (\n            valueWithDefault &&\n            typeof valueWithDefault === 'object' &&\n            'relationTo' in valueWithDefault &&\n            'value' in valueWithDefault\n          ) {\n            const value =\n              typeof valueWithDefault?.value === 'object' &&\n              valueWithDefault?.value &&\n              'id' in valueWithDefault.value\n                ? valueWithDefault.value.id\n                : valueWithDefault.value\n            const relationshipValue = {\n              relationTo: valueWithDefault?.relationTo,\n              value,\n            }\n            fieldState.value = relationshipValue\n            fieldState.initialValue = relationshipValue\n          }\n        } else {\n          const relationshipValue =\n            valueWithDefault && typeof valueWithDefault === 'object' && 'id' in valueWithDefault\n              ? valueWithDefault.id\n              : valueWithDefault\n          fieldState.value = relationshipValue\n          fieldState.initialValue = relationshipValue\n        }\n\n        if (!filter || filter(args)) {\n          state[`${path}${field.name}`] = fieldState\n        }\n\n        break\n      }\n\n      case 'upload': {\n        const relationshipValue =\n          valueWithDefault && typeof valueWithDefault === 'object' && 'id' in valueWithDefault\n            ? valueWithDefault.id\n            : valueWithDefault\n        fieldState.value = relationshipValue\n        fieldState.initialValue = relationshipValue\n\n        if (!filter || filter(args)) {\n          state[`${path}${field.name}`] = fieldState\n        }\n\n        break\n      }\n\n      default: {\n        fieldState.value = valueWithDefault\n        fieldState.initialValue = valueWithDefault\n\n        // Add field to state\n        if (!filter || filter(args)) {\n          state[`${path}${field.name}`] = fieldState\n        }\n\n        break\n      }\n    }\n  } else if (fieldHasSubFields(field)) {\n    // Handle field types that do not use names (row, etc)\n    await iterateFields({\n      id,\n      anyParentLocalized: field.localized || anyParentLocalized,\n      config,\n      data,\n      fields: field.fields,\n      filter,\n      forceFullValue,\n      fullData,\n      includeSchema,\n      locale,\n      omitParents,\n      operation,\n      parentPassesCondition: passesCondition,\n      path,\n      preferences,\n      skipConditionChecks,\n      skipValidation,\n      state,\n      t,\n      user,\n    })\n  } else if (field.type === 'tabs') {\n    const promises = field.tabs.map((tab) =>\n      iterateFields({\n        id,\n        anyParentLocalized: tab.localized || anyParentLocalized,\n        config,\n        data: tabHasName(tab) ? data?.[tab.name] : data,\n        fields: tab.fields,\n        filter,\n        forceFullValue,\n        fullData,\n        includeSchema,\n        locale,\n        omitParents,\n        operation,\n        parentPassesCondition: passesCondition,\n        path: tabHasName(tab) ? `${path}${tab.name}.` : path,\n        preferences,\n        skipConditionChecks,\n        skipValidation,\n        state,\n        t,\n        user,\n      }),\n    )\n\n    await Promise.all(promises)\n  }\n}\n"],"names":["addFieldStatePromise","args","id","anyParentLocalized","config","data","field","filter","forceFullValue","fullData","includeSchema","locale","omitParents","operation","passesCondition","path","preferences","skipConditionChecks","skipValidation","state","t","user","fieldAffectsData","fieldState","condition","admin","fieldSchema","undefined","initialValue","valid","validate","value","valueWithDefault","getValueWithDefault","defaultValue","name","validationResult","siblingData","errorMessage","type","arrayValue","Array","isArray","promises","rowMetadata","reduce","acc","row","i","rowPath","ObjectID","toHexString","fields","find","push","iterateFields","localized","parentPassesCondition","collapsedRowIDs","collapsed","childErrorPaths","Set","initCollapsed","includes","Promise","all","length","disableFormData","rows","blocksValue","block","blocks","blockType","slug","blockField","blockName","hasMany","relationshipValue","map","relationship","relationTo","fieldHasSubFields","tabs","tab","tabHasName"],"mappings":"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"}