payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
142 lines (141 loc) • 18.9 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "getLocalizedPaths", {
enumerable: true,
get: function() {
return getLocalizedPaths;
}
});
const _types = require("../fields/config/types");
const _flattenTopLevelFields = /*#__PURE__*/ _interop_require_default(require("../utilities/flattenTopLevelFields"));
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
async function getLocalizedPaths({ collectionSlug, fields, globalSlug, incomingPath, locale, overrideAccess = false, payload }) {
const pathSegments = incomingPath.split('.');
const localizationConfig = payload.config.localization;
let paths = [
{
collectionSlug,
complete: false,
field: undefined,
fields: (0, _flattenTopLevelFields.default)(fields, false),
globalSlug,
invalid: false,
path: ''
}
];
for(let i = 0; i < pathSegments.length; i += 1){
const segment = pathSegments[i];
const lastIncompletePath = paths.find(({ complete })=>!complete);
if (lastIncompletePath) {
const { path } = lastIncompletePath;
let currentPath = path ? `${path}.${segment}` : segment;
const matchedField = lastIncompletePath.fields.find((field)=>(0, _types.fieldAffectsData)(field) && field.name === segment);
lastIncompletePath.field = matchedField;
if (currentPath === 'globalType' && globalSlug) {
lastIncompletePath.path = currentPath;
lastIncompletePath.complete = true;
lastIncompletePath.field = {
name: 'globalType',
type: 'text'
};
return paths;
}
if (!matchedField && currentPath === 'id' && i === pathSegments.length - 1) {
lastIncompletePath.path = currentPath;
const idField = {
name: 'id',
type: payload.db.defaultIDType
};
lastIncompletePath.field = idField;
lastIncompletePath.complete = true;
return paths;
}
if (matchedField) {
if ('hidden' in matchedField && matchedField.hidden && !overrideAccess) {
lastIncompletePath.invalid = true;
}
const nextSegment = pathSegments[i + 1];
const nextSegmentIsLocale = localizationConfig && localizationConfig.localeCodes.includes(nextSegment);
if (nextSegmentIsLocale) {
// Skip the next iteration, because it's a locale
i += 1;
currentPath = `${currentPath}.${nextSegment}`;
} else if (localizationConfig && 'localized' in matchedField && matchedField.localized) {
currentPath = `${currentPath}.${locale}`;
}
switch(matchedField.type){
case 'blocks':
case 'richText':
case 'json':
{
const upcomingSegments = pathSegments.slice(i + 1).join('.');
lastIncompletePath.complete = true;
lastIncompletePath.path = upcomingSegments ? `${currentPath}.${upcomingSegments}` : currentPath;
return paths;
}
case 'relationship':
case 'upload':
{
// If this is a polymorphic relation,
// We only support querying directly (no nested querying)
if (typeof matchedField.relationTo !== 'string') {
const lastSegmentIsValid = [
'relationTo',
'value'
].includes(pathSegments[pathSegments.length - 1]) || pathSegments.length === 1;
if (lastSegmentIsValid) {
lastIncompletePath.complete = true;
lastIncompletePath.path = pathSegments.join('.');
} else {
lastIncompletePath.invalid = true;
return paths;
}
} else {
lastIncompletePath.complete = true;
lastIncompletePath.path = currentPath;
const nestedPathToQuery = pathSegments.slice(nextSegmentIsLocale ? i + 2 : i + 1).join('.');
if (nestedPathToQuery) {
const relatedCollection = payload.collections[matchedField.relationTo].config;
// eslint-disable-next-line no-await-in-loop
const remainingPaths = await getLocalizedPaths({
collectionSlug: relatedCollection.slug,
fields: relatedCollection.fields,
globalSlug,
incomingPath: nestedPathToQuery,
locale,
payload
});
paths = [
...paths,
...remainingPaths
];
}
return paths;
}
break;
}
default:
{
if ('fields' in lastIncompletePath.field) {
lastIncompletePath.fields = (0, _flattenTopLevelFields.default)(lastIncompletePath.field.fields, false);
}
if (i + 1 === pathSegments.length) lastIncompletePath.complete = true;
lastIncompletePath.path = currentPath;
}
}
} else {
lastIncompletePath.invalid = true;
lastIncompletePath.path = currentPath;
return paths;
}
}
}
return paths;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/database/getLocalizedPaths.ts"],"sourcesContent":["import type { Payload } from '..'\nimport type { Field } from '../fields/config/types'\nimport type { PathToQuery } from './queryValidation/types'\n\nimport { fieldAffectsData } from '../fields/config/types'\nimport flattenFields from '../utilities/flattenTopLevelFields'\n\nexport async function getLocalizedPaths({\n  collectionSlug,\n  fields,\n  globalSlug,\n  incomingPath,\n  locale,\n  overrideAccess = false,\n  payload,\n}: {\n  collectionSlug?: string\n  fields: Field[]\n  globalSlug?: string\n  incomingPath: string\n  locale?: string\n  overrideAccess?: boolean\n  payload: Payload\n}): Promise<PathToQuery[]> {\n  const pathSegments = incomingPath.split('.')\n  const localizationConfig = payload.config.localization\n\n  let paths: PathToQuery[] = [\n    {\n      collectionSlug,\n      complete: false,\n      field: undefined,\n      fields: flattenFields(fields, false),\n      globalSlug,\n      invalid: false,\n      path: '',\n    },\n  ]\n\n  for (let i = 0; i < pathSegments.length; i += 1) {\n    const segment = pathSegments[i]\n\n    const lastIncompletePath = paths.find(({ complete }) => !complete)\n\n    if (lastIncompletePath) {\n      const { path } = lastIncompletePath\n      let currentPath = path ? `${path}.${segment}` : segment\n\n      const matchedField = lastIncompletePath.fields.find(\n        (field) => fieldAffectsData(field) && field.name === segment,\n      )\n      lastIncompletePath.field = matchedField\n\n      if (currentPath === 'globalType' && globalSlug) {\n        lastIncompletePath.path = currentPath\n        lastIncompletePath.complete = true\n        lastIncompletePath.field = {\n          name: 'globalType',\n          type: 'text',\n        }\n\n        return paths\n      }\n\n      if (!matchedField && currentPath === 'id' && i === pathSegments.length - 1) {\n        lastIncompletePath.path = currentPath\n        const idField: Field = {\n          name: 'id',\n          type: payload.db.defaultIDType as 'text',\n        }\n        lastIncompletePath.field = idField\n        lastIncompletePath.complete = true\n        return paths\n      }\n\n      if (matchedField) {\n        if ('hidden' in matchedField && matchedField.hidden && !overrideAccess) {\n          lastIncompletePath.invalid = true\n        }\n\n        const nextSegment = pathSegments[i + 1]\n        const nextSegmentIsLocale =\n          localizationConfig && localizationConfig.localeCodes.includes(nextSegment)\n\n        if (nextSegmentIsLocale) {\n          // Skip the next iteration, because it's a locale\n          i += 1\n          currentPath = `${currentPath}.${nextSegment}`\n        } else if (localizationConfig && 'localized' in matchedField && matchedField.localized) {\n          currentPath = `${currentPath}.${locale}`\n        }\n\n        switch (matchedField.type) {\n          case 'blocks':\n          case 'richText':\n          case 'json': {\n            const upcomingSegments = pathSegments.slice(i + 1).join('.')\n            lastIncompletePath.complete = true\n            lastIncompletePath.path = upcomingSegments\n              ? `${currentPath}.${upcomingSegments}`\n              : currentPath\n            return paths\n          }\n\n          case 'relationship':\n          case 'upload': {\n            // If this is a polymorphic relation,\n            // We only support querying directly (no nested querying)\n            if (typeof matchedField.relationTo !== 'string') {\n              const lastSegmentIsValid =\n                ['relationTo', 'value'].includes(pathSegments[pathSegments.length - 1]) ||\n                pathSegments.length === 1\n\n              if (lastSegmentIsValid) {\n                lastIncompletePath.complete = true\n                lastIncompletePath.path = pathSegments.join('.')\n              } else {\n                lastIncompletePath.invalid = true\n                return paths\n              }\n            } else {\n              lastIncompletePath.complete = true\n              lastIncompletePath.path = currentPath\n\n              const nestedPathToQuery = pathSegments\n                .slice(nextSegmentIsLocale ? i + 2 : i + 1)\n                .join('.')\n\n              if (nestedPathToQuery) {\n                const relatedCollection = payload.collections[matchedField.relationTo].config\n\n                // eslint-disable-next-line no-await-in-loop\n                const remainingPaths = await getLocalizedPaths({\n                  collectionSlug: relatedCollection.slug,\n                  fields: relatedCollection.fields,\n                  globalSlug,\n                  incomingPath: nestedPathToQuery,\n                  locale,\n                  payload,\n                })\n\n                paths = [...paths, ...remainingPaths]\n              }\n\n              return paths\n            }\n\n            break\n          }\n\n          default: {\n            if ('fields' in lastIncompletePath.field) {\n              lastIncompletePath.fields = flattenFields(lastIncompletePath.field.fields, false)\n            }\n\n            if (i + 1 === pathSegments.length) lastIncompletePath.complete = true\n            lastIncompletePath.path = currentPath\n          }\n        }\n      } else {\n        lastIncompletePath.invalid = true\n        lastIncompletePath.path = currentPath\n        return paths\n      }\n    }\n  }\n\n  return paths\n}\n"],"names":["getLocalizedPaths","collectionSlug","fields","globalSlug","incomingPath","locale","overrideAccess","payload","pathSegments","split","localizationConfig","config","localization","paths","complete","field","undefined","flattenFields","invalid","path","i","length","segment","lastIncompletePath","find","currentPath","matchedField","fieldAffectsData","name","type","idField","db","defaultIDType","hidden","nextSegment","nextSegmentIsLocale","localeCodes","includes","localized","upcomingSegments","slice","join","relationTo","lastSegmentIsValid","nestedPathToQuery","relatedCollection","collections","remainingPaths","slug"],"mappings":"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"}