UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

170 lines (169 loc) • 16.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _react = /*#__PURE__*/ _interop_require_wildcard(require("react")); const _Meta = /*#__PURE__*/ _interop_require_default(require("../FileDetails/Meta")); 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 = 'preview-sizes'; const sortSizes = (sizes, imageSizes)=>{ if (!imageSizes || imageSizes.length === 0) return sizes; const orderedSizes = {}; imageSizes.forEach(({ name })=>{ if (sizes[name]) { orderedSizes[name] = sizes[name]; } }); return orderedSizes; }; const PreviewSizeCard = ({ name, active, baseURL, meta, onClick, previewSrc })=>{ return /*#__PURE__*/ _react.default.createElement("div", { className: [ `${baseClass}__sizeOption`, active && `${baseClass}--selected` ].filter(Boolean).join(' '), onClick: typeof onClick === 'function' ? onClick : undefined, onKeyDown: (e)=>{ if (typeof onClick !== 'function') return; if (e.key === 'Enter') onClick(); }, role: "button", tabIndex: 0 }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__image` }, /*#__PURE__*/ _react.default.createElement("img", { alt: meta.filename, src: previewSrc })), /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__sizeMeta` }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__sizeName` }, name), /*#__PURE__*/ _react.default.createElement(_Meta.default, { ...meta, staticURL: baseURL }))); }; const PreviewSizes = ({ collection, doc, imageCacheTag })=>{ const { upload: { imageSizes, staticURL } } = collection; const { sizes } = doc; const [orderedSizes, setOrderedSizes] = (0, _react.useState)(()=>sortSizes(sizes, imageSizes)); const [selectedSize, setSelectedSize] = (0, _react.useState)(null); const generateImageUrl = (doc)=>{ if (!doc.filename) return null; if (doc.url) return `${doc.url}${imageCacheTag ? `?${imageCacheTag}` : ''}`; }; (0, _react.useEffect)(()=>{ setOrderedSizes(sortSizes(sizes, imageSizes)); }, [ sizes, imageSizes, imageCacheTag ]); const mainPreviewSrc = selectedSize ? generateImageUrl(doc.sizes[selectedSize]) : generateImageUrl(doc); const originalImage = (0, _react.useMemo)(()=>({ filename: doc.filename, filesize: doc.filesize, height: doc.height, mimeType: doc.mimeType, width: doc.width }), [ doc ]); const originalFilename = 'Original'; return /*#__PURE__*/ _react.default.createElement("div", { className: baseClass }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__imageWrap` }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__meta` }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__sizeName` }, selectedSize || originalFilename), /*#__PURE__*/ _react.default.createElement(_Meta.default, { ...selectedSize ? orderedSizes[selectedSize] : originalImage, staticURL: staticURL })), /*#__PURE__*/ _react.default.createElement("img", { alt: doc.filename, className: `${baseClass}__preview`, src: mainPreviewSrc })), /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__listWrap` }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__list` }, /*#__PURE__*/ _react.default.createElement(PreviewSizeCard, { active: !selectedSize, baseURL: staticURL, meta: originalImage, name: originalFilename, onClick: ()=>setSelectedSize(null), previewSrc: generateImageUrl(doc) }), Object.entries(orderedSizes).map(([key, val])=>{ const selected = selectedSize === key; const previewSrc = generateImageUrl(val); if (previewSrc) { return /*#__PURE__*/ _react.default.createElement(PreviewSizeCard, { active: selected, baseURL: staticURL, key: key, meta: val, name: key, onClick: ()=>setSelectedSize(key), previewSrc: previewSrc }); } return null; })))); }; const _default = PreviewSizes; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/PreviewSizes/index.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useState } from 'react'\n\nimport type { SanitizedCollectionConfig } from '../../../../exports/types'\nimport type { FileSizes, Upload } from '../../../../uploads/types'\nimport type { Data } from '../../forms/Form/types'\n\nimport Meta from '../FileDetails/Meta'\nimport './index.scss'\n\nconst baseClass = 'preview-sizes'\n\nconst sortSizes = (sizes: FileSizes, imageSizes: Upload['imageSizes']) => {\n  if (!imageSizes || imageSizes.length === 0) return sizes\n\n  const orderedSizes: FileSizes = {}\n\n  imageSizes.forEach(({ name }) => {\n    if (sizes[name]) {\n      orderedSizes[name] = sizes[name]\n    }\n  })\n\n  return orderedSizes\n}\n\ntype PreviewSizeCardProps = {\n  active: boolean\n  baseURL: string\n  meta: FileSizes[0]\n  name: string\n  onClick?: () => void\n  previewSrc: string\n}\nconst PreviewSizeCard: React.FC<PreviewSizeCardProps> = ({\n  name,\n  active,\n  baseURL,\n  meta,\n  onClick,\n  previewSrc,\n}) => {\n  return (\n    <div\n      className={[`${baseClass}__sizeOption`, active && `${baseClass}--selected`]\n        .filter(Boolean)\n        .join(' ')}\n      onClick={typeof onClick === 'function' ? onClick : undefined}\n      onKeyDown={(e) => {\n        if (typeof onClick !== 'function') return\n        if (e.key === 'Enter') onClick()\n      }}\n      role=\"button\"\n      tabIndex={0}\n    >\n      <div className={`${baseClass}__image`}>\n        <img alt={meta.filename} src={previewSrc} />\n      </div>\n      <div className={`${baseClass}__sizeMeta`}>\n        <div className={`${baseClass}__sizeName`}>{name}</div>\n        <Meta {...meta} staticURL={baseURL} />\n      </div>\n    </div>\n  )\n}\n\nconst PreviewSizes: React.FC<{\n  collection: SanitizedCollectionConfig\n  doc: Data & {\n    sizes?: FileSizes\n  }\n  imageCacheTag?: string\n}> = ({ collection, doc, imageCacheTag }) => {\n  const {\n    upload: { imageSizes, staticURL },\n  } = collection\n  const { sizes } = doc\n\n  const [orderedSizes, setOrderedSizes] = useState<FileSizes>(() => sortSizes(sizes, imageSizes))\n  const [selectedSize, setSelectedSize] = useState<null | string>(null)\n\n  const generateImageUrl = (doc) => {\n    if (!doc.filename) return null\n    if (doc.url) return `${doc.url}${imageCacheTag ? `?${imageCacheTag}` : ''}`\n  }\n  useEffect(() => {\n    setOrderedSizes(sortSizes(sizes, imageSizes))\n  }, [sizes, imageSizes, imageCacheTag])\n\n  const mainPreviewSrc = selectedSize\n    ? generateImageUrl(doc.sizes[selectedSize])\n    : generateImageUrl(doc)\n\n  const originalImage = useMemo(\n    (): FileSizes[0] => ({\n      filename: doc.filename,\n      filesize: doc.filesize,\n      height: doc.height,\n      mimeType: doc.mimeType,\n      width: doc.width,\n    }),\n    [doc],\n  )\n  const originalFilename = 'Original'\n\n  return (\n    <div className={baseClass}>\n      <div className={`${baseClass}__imageWrap`}>\n        <div className={`${baseClass}__meta`}>\n          <div className={`${baseClass}__sizeName`}>{selectedSize || originalFilename}</div>\n          <Meta\n            {...(selectedSize ? orderedSizes[selectedSize] : originalImage)}\n            staticURL={staticURL}\n          />\n        </div>\n        <img alt={doc.filename} className={`${baseClass}__preview`} src={mainPreviewSrc} />\n      </div>\n      <div className={`${baseClass}__listWrap`}>\n        <div className={`${baseClass}__list`}>\n          <PreviewSizeCard\n            active={!selectedSize}\n            baseURL={staticURL}\n            meta={originalImage}\n            name={originalFilename}\n            onClick={() => setSelectedSize(null)}\n            previewSrc={generateImageUrl(doc)}\n          />\n\n          {Object.entries(orderedSizes).map(([key, val]) => {\n            const selected = selectedSize === key\n            const previewSrc = generateImageUrl(val)\n\n            if (previewSrc) {\n              return (\n                <PreviewSizeCard\n                  active={selected}\n                  baseURL={staticURL}\n                  key={key}\n                  meta={val}\n                  name={key}\n                  onClick={() => setSelectedSize(key)}\n                  previewSrc={previewSrc}\n                />\n              )\n            }\n\n            return null\n          })}\n        </div>\n      </div>\n    </div>\n  )\n}\nexport default PreviewSizes\n"],"names":["baseClass","sortSizes","sizes","imageSizes","length","orderedSizes","forEach","name","PreviewSizeCard","active","baseURL","meta","onClick","previewSrc","div","className","filter","Boolean","join","undefined","onKeyDown","e","key","role","tabIndex","img","alt","filename","src","Meta","staticURL","PreviewSizes","collection","doc","imageCacheTag","upload","setOrderedSizes","useState","selectedSize","setSelectedSize","generateImageUrl","url","useEffect","mainPreviewSrc","originalImage","useMemo","filesize","height","mimeType","width","originalFilename","Object","entries","map","val","selected"],"mappings":"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"}