UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

248 lines (247 loc) • 26.9 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); function _export(target, all) { for(var name in all)Object.defineProperty(target, name, { enumerable: true, get: all[name] }); } _export(exports, { Upload: function() { return Upload; }, UploadActions: function() { return UploadActions; }, editDrawerSlug: function() { return editDrawerSlug; }, sizePreviewSlug: function() { return sizePreviewSlug; } }); const _react = /*#__PURE__*/ _interop_require_wildcard(require("react")); const _reacti18next = require("react-i18next"); const _isImage = /*#__PURE__*/ _interop_require_default(require("../../../../../../uploads/isImage")); const _Button = /*#__PURE__*/ _interop_require_default(require("../../../../elements/Button")); const _Drawer = require("../../../../elements/Drawer"); const _Dropzone = require("../../../../elements/Dropzone"); const _EditUpload = require("../../../../elements/EditUpload"); const _FileDetails = /*#__PURE__*/ _interop_require_default(require("../../../../elements/FileDetails")); const _PreviewSizes = /*#__PURE__*/ _interop_require_default(require("../../../../elements/PreviewSizes")); const _Thumbnail = /*#__PURE__*/ _interop_require_default(require("../../../../elements/Thumbnail")); const _Error = /*#__PURE__*/ _interop_require_default(require("../../../../forms/Error")); const _context = require("../../../../forms/Form/context"); const _reduceFieldsToValues = /*#__PURE__*/ _interop_require_default(require("../../../../forms/Form/reduceFieldsToValues")); const _shared = require("../../../../forms/field-types/shared"); const _useField = /*#__PURE__*/ _interop_require_default(require("../../../../forms/useField")); const _DocumentInfo = require("../../../../utilities/DocumentInfo"); require("./index.scss"); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interop_require_wildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = { __proto__: null }; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for(var key in obj){ if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } const baseClass = 'file-field'; const editDrawerSlug = 'edit-upload'; const sizePreviewSlug = 'preview-sizes'; const validate = (value)=>{ if (!value && value !== undefined) { return 'A file is required.'; } return true; }; const UploadActions = ({ canEdit, showSizePreviews })=>{ const { t } = (0, _reacti18next.useTranslation)('upload'); return /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__file-mutation` }, showSizePreviews && /*#__PURE__*/ _react.default.createElement(_Drawer.DrawerToggler, { className: `${baseClass}__previewSizes`, slug: sizePreviewSlug }, t('upload:previewSizes')), canEdit && /*#__PURE__*/ _react.default.createElement(_Drawer.DrawerToggler, { className: `${baseClass}__edit`, slug: editDrawerSlug }, t('upload:editImage'))); }; const Upload = (props)=>{ const submitted = (0, _context.useFormSubmitted)(); const { collection, internalState, onChange, updatedAt } = props; const [replacingFile, setReplacingFile] = (0, _react.useState)(false); const [fileSrc, setFileSrc] = (0, _react.useState)(null); const { t } = (0, _reacti18next.useTranslation)([ 'upload', 'general' ]); const [doc, setDoc] = (0, _react.useState)((0, _reduceFieldsToValues.default)(internalState || {}, true)); const { docPermissions } = (0, _DocumentInfo.useDocumentInfo)(); const { errorMessage, setValue, showError, value } = (0, _useField.default)({ path: 'file', validate }); const handleFileNameChange = (e)=>{ const updatedFileName = e.target.value; if (value) { const fileValue = value; // Creating a new File object with updated properties const newFile = new File([ fileValue ], updatedFileName, { type: fileValue.type }); setValue(newFile) // Updating the state with the new File object ; } }; const handleFileSelection = _react.default.useCallback((files)=>{ const fileToUpload = files?.[0]; setValue(fileToUpload); }, [ setValue ]); const handleFileRemoval = (0, _react.useCallback)(()=>{ setReplacingFile(true); setValue(null); setFileSrc(''); }, [ setValue ]); (0, _react.useEffect)(()=>{ setDoc((0, _reduceFieldsToValues.default)(internalState || {}, true)); setReplacingFile(false); }, [ internalState ]); (0, _react.useEffect)(()=>{ if (value instanceof File) { const fileReader = new FileReader(); fileReader.onload = (e)=>{ const imgSrc = e.target?.result; if (typeof imgSrc === 'string') { setFileSrc(imgSrc); } }; fileReader.readAsDataURL(value); } if (typeof onChange === 'function') { onChange(value); } }, [ value, onChange, updatedAt ]); const canRemoveUpload = docPermissions?.update?.permission && 'delete' in docPermissions && docPermissions?.delete?.permission; const hasImageSizes = collection?.upload?.imageSizes?.length > 0; const hasResizeOptions = Boolean(collection?.upload?.resizeOptions); const { collection: { upload: { crop: showCrop = true, focalPoint = true } } = {} } = props; const showFocalPoint = focalPoint && (hasImageSizes || hasResizeOptions); const lastSubmittedTime = submitted ? new Date().toISOString() : null; return /*#__PURE__*/ _react.default.createElement("div", { className: [ _shared.fieldBaseClass, baseClass ].filter(Boolean).join(' ') }, /*#__PURE__*/ _react.default.createElement(_Error.default, { message: errorMessage, showError: showError }), doc.filename && !replacingFile && /*#__PURE__*/ _react.default.createElement(_FileDetails.default, { canEdit: showCrop || showFocalPoint, collection: collection, doc: doc, handleRemove: canRemoveUpload ? handleFileRemoval : undefined, hasImageSizes: hasImageSizes, imageCacheTag: lastSubmittedTime }), (!doc.filename || replacingFile) && /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__upload` }, !value && /*#__PURE__*/ _react.default.createElement(_Dropzone.Dropzone, { className: `${baseClass}__dropzone`, mimeTypes: collection?.upload?.mimeTypes, onChange: handleFileSelection }), value && /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__thumbnail-wrap` }, /*#__PURE__*/ _react.default.createElement(_Thumbnail.default, { fileSrc: (0, _isImage.default)(value.type) ? fileSrc : null })), /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__file-adjustments` }, /*#__PURE__*/ _react.default.createElement("input", { className: `${baseClass}__filename`, onChange: handleFileNameChange, type: "text", value: value.name }), (0, _isImage.default)(value.type) && value.type !== 'image/svg+xml' && /*#__PURE__*/ _react.default.createElement(UploadActions, { canEdit: showCrop || showFocalPoint, showSizePreviews: hasImageSizes && doc.filename && !replacingFile })), /*#__PURE__*/ _react.default.createElement(_Button.default, { buttonStyle: "icon-label", className: `${baseClass}__remove`, icon: "x", iconStyle: "with-border", onClick: handleFileRemoval, round: true, tooltip: t('general:cancel') }))), (value || doc.filename) && /*#__PURE__*/ _react.default.createElement(_Drawer.Drawer, { header: null, slug: editDrawerSlug }, /*#__PURE__*/ _react.default.createElement(_EditUpload.EditUpload, { doc: doc || undefined, fileName: value?.name || doc?.filename, fileSrc: fileSrc || doc?.url, imageCacheTag: lastSubmittedTime, showCrop: showCrop, showFocalPoint: showFocalPoint })), doc && hasImageSizes && /*#__PURE__*/ _react.default.createElement(_Drawer.Drawer, { className: `${baseClass}__previewDrawer`, hoverTitle: true, slug: sizePreviewSlug, title: t('upload:sizesFor', { label: doc?.filename }) }, /*#__PURE__*/ _react.default.createElement(_PreviewSizes.default, { collection: collection, doc: doc }))); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../../src/admin/components/views/collections/Edit/Upload/index.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { Props } from './types'\n\nimport isImage from '../../../../../../uploads/isImage'\nimport Button from '../../../../elements/Button'\nimport { Drawer, DrawerToggler } from '../../../../elements/Drawer'\nimport { Dropzone } from '../../../../elements/Dropzone'\nimport { EditUpload } from '../../../../elements/EditUpload'\nimport FileDetails from '../../../../elements/FileDetails'\nimport PreviewSizes from '../../../../elements/PreviewSizes'\nimport Thumbnail from '../../../../elements/Thumbnail'\nimport Error from '../../../../forms/Error'\nimport { useFormSubmitted } from '../../../../forms/Form/context'\nimport reduceFieldsToValues from '../../../../forms/Form/reduceFieldsToValues'\nimport { fieldBaseClass } from '../../../../forms/field-types/shared'\nimport useField from '../../../../forms/useField'\nimport { useDocumentInfo } from '../../../../utilities/DocumentInfo'\nimport './index.scss'\n\nconst baseClass = 'file-field'\nexport const editDrawerSlug = 'edit-upload'\nexport const sizePreviewSlug = 'preview-sizes'\n\nconst validate = (value) => {\n  if (!value && value !== undefined) {\n    return 'A file is required.'\n  }\n\n  return true\n}\n\nexport const UploadActions = ({ canEdit, showSizePreviews }) => {\n  const { t } = useTranslation('upload')\n  return (\n    <div className={`${baseClass}__file-mutation`}>\n      {showSizePreviews && (\n        <DrawerToggler className={`${baseClass}__previewSizes`} slug={sizePreviewSlug}>\n          {t('upload:previewSizes')}\n        </DrawerToggler>\n      )}\n      {canEdit && (\n        <DrawerToggler className={`${baseClass}__edit`} slug={editDrawerSlug}>\n          {t('upload:editImage')}\n        </DrawerToggler>\n      )}\n    </div>\n  )\n}\n\nexport const Upload: React.FC<Props> = (props) => {\n  const submitted = useFormSubmitted()\n  const { collection, internalState, onChange, updatedAt } = props\n  const [replacingFile, setReplacingFile] = useState(false)\n  const [fileSrc, setFileSrc] = useState<null | string>(null)\n  const { t } = useTranslation(['upload', 'general'])\n  const [doc, setDoc] = useState(reduceFieldsToValues(internalState || {}, true))\n  const { docPermissions } = useDocumentInfo()\n  const { errorMessage, setValue, showError, value } = useField<File>({\n    path: 'file',\n    validate,\n  })\n\n  const handleFileNameChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n    const updatedFileName = e.target.value\n    if (value) {\n      const fileValue = value\n      // Creating a new File object with updated properties\n      const newFile = new File([fileValue], updatedFileName, { type: fileValue.type })\n      setValue(newFile) // Updating the state with the new File object\n    }\n  }\n\n  const handleFileSelection = React.useCallback(\n    (files: FileList) => {\n      const fileToUpload = files?.[0]\n      setValue(fileToUpload)\n    },\n    [setValue],\n  )\n\n  const handleFileRemoval = useCallback(() => {\n    setReplacingFile(true)\n    setValue(null)\n    setFileSrc('')\n  }, [setValue])\n\n  useEffect(() => {\n    setDoc(reduceFieldsToValues(internalState || {}, true))\n    setReplacingFile(false)\n  }, [internalState])\n\n  useEffect(() => {\n    if (value instanceof File) {\n      const fileReader = new FileReader()\n      fileReader.onload = (e) => {\n        const imgSrc = e.target?.result\n\n        if (typeof imgSrc === 'string') {\n          setFileSrc(imgSrc)\n        }\n      }\n      fileReader.readAsDataURL(value)\n    }\n\n    if (typeof onChange === 'function') {\n      onChange(value)\n    }\n  }, [value, onChange, updatedAt])\n\n  const canRemoveUpload =\n    docPermissions?.update?.permission &&\n    'delete' in docPermissions &&\n    docPermissions?.delete?.permission\n\n  const hasImageSizes = collection?.upload?.imageSizes?.length > 0\n  const hasResizeOptions = Boolean(collection?.upload?.resizeOptions)\n\n  const { collection: { upload: { crop: showCrop = true, focalPoint = true } } = {} } = props\n\n  const showFocalPoint = focalPoint && (hasImageSizes || hasResizeOptions)\n\n  const lastSubmittedTime = submitted ? new Date().toISOString() : null\n\n  return (\n    <div className={[fieldBaseClass, baseClass].filter(Boolean).join(' ')}>\n      <Error message={errorMessage} showError={showError} />\n\n      {doc.filename && !replacingFile && (\n        <FileDetails\n          canEdit={showCrop || showFocalPoint}\n          collection={collection}\n          doc={doc}\n          handleRemove={canRemoveUpload ? handleFileRemoval : undefined}\n          hasImageSizes={hasImageSizes}\n          imageCacheTag={lastSubmittedTime}\n        />\n      )}\n\n      {(!doc.filename || replacingFile) && (\n        <div className={`${baseClass}__upload`}>\n          {!value && (\n            <Dropzone\n              className={`${baseClass}__dropzone`}\n              mimeTypes={collection?.upload?.mimeTypes}\n              onChange={handleFileSelection}\n            />\n          )}\n\n          {value && (\n            <React.Fragment>\n              <div className={`${baseClass}__thumbnail-wrap`}>\n                <Thumbnail fileSrc={isImage(value.type) ? fileSrc : null} />\n              </div>\n              <div className={`${baseClass}__file-adjustments`}>\n                <input\n                  className={`${baseClass}__filename`}\n                  onChange={handleFileNameChange}\n                  type=\"text\"\n                  value={value.name}\n                />\n\n                {isImage(value.type) && value.type !== 'image/svg+xml' && (\n                  <UploadActions\n                    canEdit={showCrop || showFocalPoint}\n                    showSizePreviews={hasImageSizes && doc.filename && !replacingFile}\n                  />\n                )}\n              </div>\n              <Button\n                buttonStyle=\"icon-label\"\n                className={`${baseClass}__remove`}\n                icon=\"x\"\n                iconStyle=\"with-border\"\n                onClick={handleFileRemoval}\n                round\n                tooltip={t('general:cancel')}\n              />\n            </React.Fragment>\n          )}\n        </div>\n      )}\n\n      {(value || doc.filename) && (\n        <Drawer header={null} slug={editDrawerSlug}>\n          <EditUpload\n            doc={doc || undefined}\n            fileName={value?.name || doc?.filename}\n            fileSrc={fileSrc || doc?.url}\n            imageCacheTag={lastSubmittedTime}\n            showCrop={showCrop}\n            showFocalPoint={showFocalPoint}\n          />\n        </Drawer>\n      )}\n      {doc && hasImageSizes && (\n        <Drawer\n          className={`${baseClass}__previewDrawer`}\n          hoverTitle\n          slug={sizePreviewSlug}\n          title={t('upload:sizesFor', { label: doc?.filename })}\n        >\n          <PreviewSizes collection={collection} doc={doc} />\n        </Drawer>\n      )}\n    </div>\n  )\n}\n"],"names":["Upload","UploadActions","editDrawerSlug","sizePreviewSlug","baseClass","validate","value","undefined","canEdit","showSizePreviews","t","useTranslation","div","className","DrawerToggler","slug","props","submitted","useFormSubmitted","collection","internalState","onChange","updatedAt","replacingFile","setReplacingFile","useState","fileSrc","setFileSrc","doc","setDoc","reduceFieldsToValues","docPermissions","useDocumentInfo","errorMessage","setValue","showError","useField","path","handleFileNameChange","e","updatedFileName","target","fileValue","newFile","File","type","handleFileSelection","React","useCallback","files","fileToUpload","handleFileRemoval","useEffect","fileReader","FileReader","onload","imgSrc","result","readAsDataURL","canRemoveUpload","update","permission","delete","hasImageSizes","upload","imageSizes","length","hasResizeOptions","Boolean","resizeOptions","crop","showCrop","focalPoint","showFocalPoint","lastSubmittedTime","Date","toISOString","fieldBaseClass","filter","join","Error","message","filename","FileDetails","handleRemove","imageCacheTag","Dropzone","mimeTypes","Fragment","Thumbnail","isImage","input","name","Button","buttonStyle","icon","iconStyle","onClick","round","tooltip","Drawer","header","EditUpload","fileName","url","hoverTitle","title","label","PreviewSizes"],"mappings":"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"}