UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

156 lines (155 loc) • 13.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _extractTranslations = require("../translations/extractTranslations"); const _mimeTypeValidator = require("./mimeTypeValidator"); const labels = (0, _extractTranslations.extractTranslations)([ 'upload:width', 'upload:height', 'upload:fileSize', 'upload:fileName', 'upload:sizes' ]); const getBaseUploadFields = ({ collection, config })=>{ const uploadOptions = typeof collection.upload === 'object' ? collection.upload : {}; const mimeType = { name: 'mimeType', admin: { hidden: true, readOnly: true }, label: 'MIME Type', type: 'text' }; const url = { name: 'url', admin: { hidden: true, readOnly: true }, label: 'URL', type: 'text' }; const width = { name: 'width', admin: { hidden: true, readOnly: true }, label: labels['upload:width'], type: 'number' }; const height = { name: 'height', admin: { hidden: true, readOnly: true }, label: labels['upload:height'], type: 'number' }; const filesize = { name: 'filesize', admin: { hidden: true, readOnly: true }, label: labels['upload:fileSize'], type: 'number' }; const filename = { name: 'filename', admin: { disableBulkEdit: true, hidden: true, readOnly: true }, index: true, label: labels['upload:fileName'], type: 'text', unique: true }; let uploadFields = [ { ...url, hooks: { afterRead: [ ({ data })=>{ if (data?.filename) { if (uploadOptions.staticURL.startsWith('/')) { return `${config.serverURL}${uploadOptions.staticURL}/${data.filename}`; } return `${uploadOptions.staticURL}/${data.filename}`; } return undefined; } ] } }, filename, mimeType, filesize, width, height ]; if (uploadOptions.mimeTypes) { mimeType.validate = (0, _mimeTypeValidator.mimeTypeValidator)(uploadOptions.mimeTypes); } if (uploadOptions.imageSizes) { uploadFields = uploadFields.concat([ { name: 'sizes', admin: { hidden: true }, fields: uploadOptions.imageSizes.map((size)=>({ name: size.name, admin: { hidden: true }, fields: [ { ...url, hooks: { afterRead: [ ({ data })=>{ const sizeFilename = data?.sizes?.[size.name]?.filename; if (sizeFilename) { if (uploadOptions.staticURL.startsWith('/')) { return `${config.serverURL}${uploadOptions.staticURL}/${sizeFilename}`; } return `${uploadOptions.staticURL}/${sizeFilename}`; } return null; } ] } }, width, height, mimeType, filesize, { ...filename, unique: false } ], label: size.name, type: 'group' })), label: labels['upload:Sizes'], type: 'group' } ]); } return uploadFields; }; const _default = getBaseUploadFields; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/uploads/getBaseFields.ts"],"sourcesContent":["import type { CollectionConfig } from '../collections/config/types'\nimport type { Config } from '../config/types'\nimport type { Field } from '../fields/config/types'\nimport type { IncomingUploadType } from './types'\n\nimport { extractTranslations } from '../translations/extractTranslations'\nimport { mimeTypeValidator } from './mimeTypeValidator'\n\nconst labels = extractTranslations([\n  'upload:width',\n  'upload:height',\n  'upload:fileSize',\n  'upload:fileName',\n  'upload:sizes',\n])\n\ntype Options = {\n  collection: CollectionConfig\n  config: Config\n}\n\nconst getBaseUploadFields = ({ collection, config }: Options): Field[] => {\n  const uploadOptions: IncomingUploadType =\n    typeof collection.upload === 'object' ? collection.upload : {}\n\n  const mimeType: Field = {\n    name: 'mimeType',\n    admin: {\n      hidden: true,\n      readOnly: true,\n    },\n    label: 'MIME Type',\n    type: 'text',\n  }\n\n  const url: Field = {\n    name: 'url',\n    admin: {\n      hidden: true,\n      readOnly: true,\n    },\n    label: 'URL',\n    type: 'text',\n  }\n\n  const width: Field = {\n    name: 'width',\n    admin: {\n      hidden: true,\n      readOnly: true,\n    },\n    label: labels['upload:width'],\n    type: 'number',\n  }\n\n  const height: Field = {\n    name: 'height',\n    admin: {\n      hidden: true,\n      readOnly: true,\n    },\n    label: labels['upload:height'],\n    type: 'number',\n  }\n\n  const filesize: Field = {\n    name: 'filesize',\n    admin: {\n      hidden: true,\n      readOnly: true,\n    },\n    label: labels['upload:fileSize'],\n    type: 'number',\n  }\n\n  const filename: Field = {\n    name: 'filename',\n    admin: {\n      disableBulkEdit: true,\n      hidden: true,\n      readOnly: true,\n    },\n    index: true,\n    label: labels['upload:fileName'],\n    type: 'text',\n    unique: true,\n  }\n\n  let uploadFields: Field[] = [\n    {\n      ...url,\n      hooks: {\n        afterRead: [\n          ({ data }) => {\n            if (data?.filename) {\n              if (uploadOptions.staticURL.startsWith('/')) {\n                return `${config.serverURL}${uploadOptions.staticURL}/${data.filename}`\n              }\n              return `${uploadOptions.staticURL}/${data.filename}`\n            }\n\n            return undefined\n          },\n        ],\n      },\n    },\n    filename,\n    mimeType,\n    filesize,\n    width,\n    height,\n  ]\n\n  if (uploadOptions.mimeTypes) {\n    mimeType.validate = mimeTypeValidator(uploadOptions.mimeTypes)\n  }\n\n  if (uploadOptions.imageSizes) {\n    uploadFields = uploadFields.concat([\n      {\n        name: 'sizes',\n        admin: {\n          hidden: true,\n        },\n        fields: uploadOptions.imageSizes.map((size) => ({\n          name: size.name,\n          admin: {\n            hidden: true,\n          },\n          fields: [\n            {\n              ...url,\n              hooks: {\n                afterRead: [\n                  ({ data }) => {\n                    const sizeFilename = data?.sizes?.[size.name]?.filename\n\n                    if (sizeFilename) {\n                      if (uploadOptions.staticURL.startsWith('/')) {\n                        return `${config.serverURL}${uploadOptions.staticURL}/${sizeFilename}`\n                      }\n                      return `${uploadOptions.staticURL}/${sizeFilename}`\n                    }\n\n                    return null\n                  },\n                ],\n              },\n            },\n            width,\n            height,\n            mimeType,\n            filesize,\n            {\n              ...filename,\n              unique: false,\n            },\n          ],\n          label: size.name,\n          type: 'group',\n        })),\n        label: labels['upload:Sizes'],\n        type: 'group',\n      },\n    ])\n  }\n  return uploadFields\n}\n\nexport default getBaseUploadFields\n"],"names":["labels","extractTranslations","getBaseUploadFields","collection","config","uploadOptions","upload","mimeType","name","admin","hidden","readOnly","label","type","url","width","height","filesize","filename","disableBulkEdit","index","unique","uploadFields","hooks","afterRead","data","staticURL","startsWith","serverURL","undefined","mimeTypes","validate","mimeTypeValidator","imageSizes","concat","fields","map","size","sizeFilename","sizes"],"mappings":"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"}