UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

154 lines (153 loc) • 21.3 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "sanitizeFields", { enumerable: true, get: function() { return sanitizeFields; } }); const _withCondition = /*#__PURE__*/ _interop_require_default(require("../../admin/components/forms/withCondition")); const _errors = require("../../errors"); const _formatLabels = require("../../utilities/formatLabels"); const _baseBlockFields = require("../baseFields/baseBlockFields"); const _baseIDField = require("../baseFields/baseIDField"); const _validations = /*#__PURE__*/ _interop_require_default(require("../validations")); const _types = require("./types"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const sanitizeFields = ({ config, existingFieldNames = new Set(), fields, validRelationships })=>{ if (!fields) return []; return fields.map((unsanitizedField)=>{ const field = { ...unsanitizedField }; if (!field.type) throw new _errors.MissingFieldType(field); // assert that field names do not contain forbidden characters if ((0, _types.fieldAffectsData)(field) && field.name.includes('.')) { throw new _errors.InvalidFieldName(field, field.name); } // Make sure that the richText field has an editor if (field.type === 'richText' && !field.editor && config.editor) { field.editor = config.editor; } // Auto-label if ('name' in field && field.name && typeof field.label !== 'object' && typeof field.label !== 'string' && field.label !== false) { field.label = (0, _formatLabels.toWords)(field.name); } if (field.type === 'checkbox' && typeof field.defaultValue === 'undefined' && field.required === true) { field.defaultValue = false; } if (field.type === 'relationship' || field.type === 'upload') { if (validRelationships) { const relationships = Array.isArray(field.relationTo) ? field.relationTo : [ field.relationTo ]; relationships.forEach((relationship)=>{ if (!validRelationships.includes(relationship)) { throw new _errors.InvalidFieldRelationship(field, relationship); } }); } if (field.type === 'relationship') { if (field.min && !field.minRows) { console.warn(`(payload): The "min" property is deprecated for the Relationship field "${field.name}" and will be removed in a future version. Please use "minRows" instead.`); } if (field.max && !field.maxRows) { console.warn(`(payload): The "max" property is deprecated for the Relationship field "${field.name}" and will be removed in a future version. Please use "maxRows" instead.`); } field.minRows = field.minRows || field.min; field.maxRows = field.maxRows || field.max; } } if (field.type === 'blocks' && field.blocks) { field.blocks = field.blocks.map((block)=>({ ...block, fields: block.fields.concat(_baseBlockFields.baseBlockFields) })); } if (field.type === 'array' && field.fields) { field.fields.push(_baseIDField.baseIDField); } if ((field.type === 'blocks' || field.type === 'array') && field.label) { field.labels = field.labels || (0, _formatLabels.formatLabels)(field.name); } if ((0, _types.fieldAffectsData)(field)) { if (existingFieldNames.has(field.name)) { throw new _errors.DuplicateFieldName(field.name); } else if (![ 'id', 'blockName' ].includes(field.name)) { existingFieldNames.add(field.name); } if (field.localized && !config.localization) delete field.localized; if (typeof field.validate === 'undefined') { const defaultValidate = _validations.default[field.type]; if (defaultValidate) { field.validate = (val, options)=>defaultValidate(val, { ...field, ...options }); } else { field.validate = ()=>true; } } if (!field.hooks) field.hooks = {}; if (!field.access) field.access = {}; } if (field.admin) { if (field.admin.condition && field.admin.components?.Field) { field.admin.components.Field = (0, _withCondition.default)(field.admin.components?.Field); } } else { field.admin = {}; } if ('fields' in field && field.fields) { field.fields = sanitizeFields({ config, existingFieldNames: (0, _types.fieldAffectsData)(field) ? new Set() : existingFieldNames, fields: field.fields, validRelationships }); } if (field.type === 'tabs') { field.tabs = field.tabs.map((tab)=>{ const unsanitizedTab = { ...tab }; if ((0, _types.tabHasName)(tab) && typeof tab.label === 'undefined') { unsanitizedTab.label = (0, _formatLabels.toWords)(tab.name); } unsanitizedTab.fields = sanitizeFields({ config, existingFieldNames: (0, _types.tabHasName)(tab) ? new Set() : existingFieldNames, fields: tab.fields, validRelationships }); return unsanitizedTab; }); } if ('blocks' in field && field.blocks) { field.blocks = field.blocks.map((block)=>{ const unsanitizedBlock = { ...block }; unsanitizedBlock.labels = !unsanitizedBlock.labels ? (0, _formatLabels.formatLabels)(unsanitizedBlock.slug) : unsanitizedBlock.labels; unsanitizedBlock.fields = sanitizeFields({ config, fields: block.fields, validRelationships, existingFieldNames: new Set() }); return unsanitizedBlock; }); } return field; }); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/fields/config/sanitize.ts"],"sourcesContent":["import type { Config } from '../../config/types'\nimport type { Field } from './types'\n\nimport withCondition from '../../admin/components/forms/withCondition'\nimport {\n  DuplicateFieldName,\n  InvalidFieldName,\n  InvalidFieldRelationship,\n  MissingFieldType,\n} from '../../errors'\nimport { formatLabels, toWords } from '../../utilities/formatLabels'\nimport { baseBlockFields } from '../baseFields/baseBlockFields'\nimport { baseIDField } from '../baseFields/baseIDField'\nimport validations from '../validations'\nimport { fieldAffectsData, tabHasName } from './types'\n\ntype Args = {\n  config: Config\n  existingFieldNames?: Set<string>\n  fields: Field[]\n  /**\n   * If not null, will validate that upload and relationship fields do not relate to a collection that is not in this array.\n   * This validation will be skipped if validRelationships is null.\n   */\n  validRelationships: null | string[]\n}\n\nexport const sanitizeFields = ({\n  config,\n  existingFieldNames = new Set(),\n  fields,\n  validRelationships,\n}: Args): Field[] => {\n  if (!fields) return []\n\n  return fields.map((unsanitizedField) => {\n    const field: Field = { ...unsanitizedField }\n\n    if (!field.type) throw new MissingFieldType(field)\n\n    // assert that field names do not contain forbidden characters\n    if (fieldAffectsData(field) && field.name.includes('.')) {\n      throw new InvalidFieldName(field, field.name)\n    }\n\n    // Make sure that the richText field has an editor\n    if (field.type === 'richText' && !field.editor && config.editor) {\n      field.editor = config.editor\n    }\n\n    // Auto-label\n    if (\n      'name' in field &&\n      field.name &&\n      typeof field.label !== 'object' &&\n      typeof field.label !== 'string' &&\n      field.label !== false\n    ) {\n      field.label = toWords(field.name)\n    }\n\n    if (\n      field.type === 'checkbox' &&\n      typeof field.defaultValue === 'undefined' &&\n      field.required === true\n    ) {\n      field.defaultValue = false\n    }\n\n    if (field.type === 'relationship' || field.type === 'upload') {\n      if (validRelationships) {\n        const relationships = Array.isArray(field.relationTo)\n          ? field.relationTo\n          : [field.relationTo]\n        relationships.forEach((relationship: string) => {\n          if (!validRelationships.includes(relationship)) {\n            throw new InvalidFieldRelationship(field, relationship)\n          }\n        })\n      }\n\n      if (field.type === 'relationship') {\n        if (field.min && !field.minRows) {\n          console.warn(\n            `(payload): The \"min\" property is deprecated for the Relationship field \"${field.name}\" and will be removed in a future version. Please use \"minRows\" instead.`,\n          )\n        }\n        if (field.max && !field.maxRows) {\n          console.warn(\n            `(payload): The \"max\" property is deprecated for the Relationship field \"${field.name}\" and will be removed in a future version. Please use \"maxRows\" instead.`,\n          )\n        }\n        field.minRows = field.minRows || field.min\n        field.maxRows = field.maxRows || field.max\n      }\n    }\n\n    if (field.type === 'blocks' && field.blocks) {\n      field.blocks = field.blocks.map((block) => ({\n        ...block,\n        fields: block.fields.concat(baseBlockFields),\n      }))\n    }\n\n    if (field.type === 'array' && field.fields) {\n      field.fields.push(baseIDField)\n    }\n\n    if ((field.type === 'blocks' || field.type === 'array') && field.label) {\n      field.labels = field.labels || formatLabels(field.name)\n    }\n\n    if (fieldAffectsData(field)) {\n      if (existingFieldNames.has(field.name)) {\n        throw new DuplicateFieldName(field.name)\n      } else if (!['id', 'blockName'].includes(field.name)) {\n        existingFieldNames.add(field.name)\n      }\n\n      if (field.localized && !config.localization) delete field.localized\n\n      if (typeof field.validate === 'undefined') {\n        const defaultValidate = validations[field.type]\n        if (defaultValidate) {\n          field.validate = (val, options) => defaultValidate(val, { ...field, ...options })\n        } else {\n          field.validate = () => true\n        }\n      }\n\n      if (!field.hooks) field.hooks = {}\n      if (!field.access) field.access = {}\n    }\n\n    if (field.admin) {\n      if (field.admin.condition && field.admin.components?.Field) {\n        field.admin.components.Field = withCondition(field.admin.components?.Field)\n      }\n    } else {\n      field.admin = {}\n    }\n\n    if ('fields' in field && field.fields) {\n      field.fields = sanitizeFields({\n        config,\n        existingFieldNames: fieldAffectsData(field) ? new Set() : existingFieldNames,\n        fields: field.fields,\n        validRelationships,\n      })\n    }\n\n    if (field.type === 'tabs') {\n      field.tabs = field.tabs.map((tab) => {\n        const unsanitizedTab = { ...tab }\n        if (tabHasName(tab) && typeof tab.label === 'undefined') {\n          unsanitizedTab.label = toWords(tab.name)\n        }\n\n        unsanitizedTab.fields = sanitizeFields({\n          config,\n          existingFieldNames: tabHasName(tab) ? new Set() : existingFieldNames,\n          fields: tab.fields,\n          validRelationships,\n        })\n\n        return unsanitizedTab\n      })\n    }\n\n    if ('blocks' in field && field.blocks) {\n      field.blocks = field.blocks.map((block) => {\n        const unsanitizedBlock = { ...block }\n        unsanitizedBlock.labels = !unsanitizedBlock.labels\n          ? formatLabels(unsanitizedBlock.slug)\n          : unsanitizedBlock.labels\n\n        unsanitizedBlock.fields = sanitizeFields({\n          config,\n          fields: block.fields,\n          validRelationships,\n          existingFieldNames: new Set(),\n        })\n\n        return unsanitizedBlock\n      })\n    }\n\n    return field\n  })\n}\n"],"names":["sanitizeFields","config","existingFieldNames","Set","fields","validRelationships","map","unsanitizedField","field","type","MissingFieldType","fieldAffectsData","name","includes","InvalidFieldName","editor","label","toWords","defaultValue","required","relationships","Array","isArray","relationTo","forEach","relationship","InvalidFieldRelationship","min","minRows","console","warn","max","maxRows","blocks","block","concat","baseBlockFields","push","baseIDField","labels","formatLabels","has","DuplicateFieldName","add","localized","localization","validate","defaultValidate","validations","val","options","hooks","access","admin","condition","components","Field","withCondition","tabs","tab","unsanitizedTab","tabHasName","unsanitizedBlock","slug"],"mappings":"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"}