UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

95 lines (94 loc) 12 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "default", { enumerable: true, get: function() { return _default; } }); const _react = /*#__PURE__*/ _interop_require_default(require("react")); const _reacti18next = require("react-i18next"); const _reactrouterdom = require("react-router-dom"); const _types = require("../../../../../../fields/config/types"); const _getTranslation = require("../../../../../../utilities/getTranslation"); const _Config = require("../../../../utilities/Config"); const _RenderCustomComponent = /*#__PURE__*/ _interop_require_default(require("../../../../utilities/RenderCustomComponent")); const _fieldtypes = /*#__PURE__*/ _interop_require_default(require("./field-types")); const _Code = /*#__PURE__*/ _interop_require_default(require("./field-types/Code")); function _interop_require_default(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const DefaultCell = (props)=>{ const { cellData, className, collection: { slug }, collection, field, link = true, onClick, rowData: { id } = {}, rowData } = props; const { routes: { admin } } = (0, _Config.useConfig)(); const { i18n, t } = (0, _reacti18next.useTranslation)('general'); let WrapElement = 'span'; const wrapElementProps = { className }; if (link) { WrapElement = _reactrouterdom.Link; wrapElementProps.to = `${admin}/collections/${slug}/${id}`; } if (typeof onClick === 'function') { WrapElement = 'button'; wrapElementProps.type = 'button'; wrapElementProps.onClick = ()=>{ onClick(props); }; } if (field.name === 'id') { return /*#__PURE__*/ _react.default.createElement(WrapElement, wrapElementProps, /*#__PURE__*/ _react.default.createElement(_Code.default, { collection: collection, data: `ID: ${cellData}`, field: field, nowrap: true, rowData: rowData })); } let CellComponent = cellData && _fieldtypes.default[field.type]; if (!CellComponent) { if (collection.upload && (0, _types.fieldAffectsData)(field) && field.name === 'filename') { CellComponent = _fieldtypes.default.File; } else { if (!cellData && 'label' in field) { return /*#__PURE__*/ _react.default.createElement(WrapElement, wrapElementProps, t('noLabel', { label: (0, _getTranslation.getTranslation)(typeof field.label === 'function' ? 'data' : field.label || 'data', i18n) })); } else if (typeof cellData === 'string' || typeof cellData === 'number') { return /*#__PURE__*/ _react.default.createElement(WrapElement, wrapElementProps, cellData); } else if (typeof cellData === 'object') { return /*#__PURE__*/ _react.default.createElement(WrapElement, wrapElementProps, JSON.stringify(cellData)); } } } return /*#__PURE__*/ _react.default.createElement(WrapElement, wrapElementProps, /*#__PURE__*/ _react.default.createElement(CellComponent, { collection: collection, data: cellData, field: field, rowData: rowData })); }; const Cell = (props)=>{ const { cellData, className, colIndex, collection, field: { admin: { components: { Cell: CustomCell } = {} } = {} }, field, link, onClick, rowData } = props; return /*#__PURE__*/ _react.default.createElement(_RenderCustomComponent.default, { CustomComponent: CustomCell, DefaultComponent: DefaultCell, componentProps: { cellData, className, colIndex, collection, field, link, onClick, rowData } }); }; const _default = Cell; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../../src/admin/components/views/collections/List/Cell/index.tsx"],"sourcesContent":["import React from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { Link } from 'react-router-dom'\n\nimport type { CodeField } from '../../../../../../fields/config/types'\nimport type { CellComponentProps, Props } from './types'\n\nimport { fieldAffectsData } from '../../../../../../fields/config/types'\nimport { getTranslation } from '../../../../../../utilities/getTranslation'\nimport { useConfig } from '../../../../utilities/Config'\nimport RenderCustomComponent from '../../../../utilities/RenderCustomComponent'\nimport cellComponents from './field-types'\nimport CodeCell from './field-types/Code'\n\nconst DefaultCell: React.FC<Props> = (props) => {\n  const {\n    cellData,\n    className,\n    collection: { slug },\n    collection,\n    field,\n    link = true,\n    onClick,\n    rowData: { id } = {},\n    rowData,\n  } = props\n\n  const {\n    routes: { admin },\n  } = useConfig()\n  const { i18n, t } = useTranslation('general')\n\n  let WrapElement: React.ComponentType<any> | string = 'span'\n\n  const wrapElementProps: {\n    className?: string\n    onClick?: () => void\n    to?: string\n    type?: 'button'\n  } = {\n    className,\n  }\n\n  if (link) {\n    WrapElement = Link\n    wrapElementProps.to = `${admin}/collections/${slug}/${id}`\n  }\n\n  if (typeof onClick === 'function') {\n    WrapElement = 'button'\n    wrapElementProps.type = 'button'\n    wrapElementProps.onClick = () => {\n      onClick(props)\n    }\n  }\n\n  if (field.name === 'id') {\n    return (\n      <WrapElement {...wrapElementProps}>\n        <CodeCell\n          collection={collection}\n          data={`ID: ${cellData}`}\n          field={field as CodeField}\n          nowrap\n          rowData={rowData}\n        />\n      </WrapElement>\n    )\n  }\n\n  let CellComponent: React.FC<CellComponentProps> = cellData && cellComponents[field.type]\n\n  if (!CellComponent) {\n    if (collection.upload && fieldAffectsData(field) && field.name === 'filename') {\n      CellComponent = cellComponents.File\n    } else {\n      if (!cellData && 'label' in field) {\n        return (\n          <WrapElement {...wrapElementProps}>\n            {t('noLabel', {\n              label: getTranslation(\n                typeof field.label === 'function' ? 'data' : field.label || 'data',\n                i18n,\n              ),\n            })}\n          </WrapElement>\n        )\n      } else if (typeof cellData === 'string' || typeof cellData === 'number') {\n        return <WrapElement {...wrapElementProps}>{cellData}</WrapElement>\n      } else if (typeof cellData === 'object') {\n        return <WrapElement {...wrapElementProps}>{JSON.stringify(cellData)}</WrapElement>\n      }\n    }\n  }\n\n  return (\n    <WrapElement {...wrapElementProps}>\n      <CellComponent collection={collection} data={cellData} field={field} rowData={rowData} />\n    </WrapElement>\n  )\n}\n\nconst Cell: React.FC<Props> = (props) => {\n  const {\n    cellData,\n    className,\n    colIndex,\n    collection,\n    field: { admin: { components: { Cell: CustomCell } = {} } = {} },\n    field,\n    link,\n    onClick,\n    rowData,\n  } = props\n\n  return (\n    <RenderCustomComponent\n      CustomComponent={CustomCell}\n      DefaultComponent={DefaultCell}\n      componentProps={\n        {\n          cellData,\n          className,\n          colIndex,\n          collection,\n          field,\n          link,\n          onClick,\n          rowData,\n        } as Props\n      }\n    />\n  )\n}\n\nexport default Cell\n"],"names":["DefaultCell","props","cellData","className","collection","slug","field","link","onClick","rowData","id","routes","admin","useConfig","i18n","t","useTranslation","WrapElement","wrapElementProps","Link","to","type","name","CodeCell","data","nowrap","CellComponent","cellComponents","upload","fieldAffectsData","File","label","getTranslation","JSON","stringify","Cell","colIndex","components","CustomCell","RenderCustomComponent","CustomComponent","DefaultComponent","componentProps"],"mappings":";;;;+BAuIA;;;eAAA;;;8DAvIkB;8BACa;gCACV;uBAKY;gCACF;wBACL;8EACQ;mEACP;6DACN;;;;;;AAErB,MAAMA,cAA+B,CAACC;IACpC,MAAM,EACJC,QAAQ,EACRC,SAAS,EACTC,YAAY,EAAEC,IAAI,EAAE,EACpBD,UAAU,EACVE,KAAK,EACLC,OAAO,IAAI,EACXC,OAAO,EACPC,SAAS,EAAEC,EAAE,EAAE,GAAG,CAAC,CAAC,EACpBD,OAAO,EACR,GAAGR;IAEJ,MAAM,EACJU,QAAQ,EAAEC,KAAK,EAAE,EAClB,GAAGC,IAAAA,iBAAS;IACb,MAAM,EAAEC,IAAI,EAAEC,CAAC,EAAE,GAAGC,IAAAA,4BAAc,EAAC;IAEnC,IAAIC,cAAiD;IAErD,MAAMC,mBAKF;QACFf;IACF;IAEA,IAAII,MAAM;QACRU,cAAcE,oBAAI;QAClBD,iBAAiBE,EAAE,GAAG,CAAC,EAAER,MAAM,aAAa,EAAEP,KAAK,CAAC,EAAEK,GAAG,CAAC;IAC5D;IAEA,IAAI,OAAOF,YAAY,YAAY;QACjCS,cAAc;QACdC,iBAAiBG,IAAI,GAAG;QACxBH,iBAAiBV,OAAO,GAAG;YACzBA,QAAQP;QACV;IACF;IAEA,IAAIK,MAAMgB,IAAI,KAAK,MAAM;QACvB,qBACE,6BAACL,aAAgBC,gCACf,6BAACK,aAAQ;YACPnB,YAAYA;YACZoB,MAAM,CAAC,IAAI,EAAEtB,SAAS,CAAC;YACvBI,OAAOA;YACPmB,QAAAA;YACAhB,SAASA;;IAIjB;IAEA,IAAIiB,gBAA8CxB,YAAYyB,mBAAc,CAACrB,MAAMe,IAAI,CAAC;IAExF,IAAI,CAACK,eAAe;QAClB,IAAItB,WAAWwB,MAAM,IAAIC,IAAAA,uBAAgB,EAACvB,UAAUA,MAAMgB,IAAI,KAAK,YAAY;YAC7EI,gBAAgBC,mBAAc,CAACG,IAAI;QACrC,OAAO;YACL,IAAI,CAAC5B,YAAY,WAAWI,OAAO;gBACjC,qBACE,6BAACW,aAAgBC,kBACdH,EAAE,WAAW;oBACZgB,OAAOC,IAAAA,8BAAc,EACnB,OAAO1B,MAAMyB,KAAK,KAAK,aAAa,SAASzB,MAAMyB,KAAK,IAAI,QAC5DjB;gBAEJ;YAGN,OAAO,IAAI,OAAOZ,aAAa,YAAY,OAAOA,aAAa,UAAU;gBACvE,qBAAO,6BAACe,aAAgBC,kBAAmBhB;YAC7C,OAAO,IAAI,OAAOA,aAAa,UAAU;gBACvC,qBAAO,6BAACe,aAAgBC,kBAAmBe,KAAKC,SAAS,CAAChC;YAC5D;QACF;IACF;IAEA,qBACE,6BAACe,aAAgBC,gCACf,6BAACQ;QAActB,YAAYA;QAAYoB,MAAMtB;QAAUI,OAAOA;QAAOG,SAASA;;AAGpF;AAEA,MAAM0B,OAAwB,CAAClC;IAC7B,MAAM,EACJC,QAAQ,EACRC,SAAS,EACTiC,QAAQ,EACRhC,UAAU,EACVE,OAAO,EAAEM,OAAO,EAAEyB,YAAY,EAAEF,MAAMG,UAAU,EAAE,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,EAChEhC,KAAK,EACLC,IAAI,EACJC,OAAO,EACPC,OAAO,EACR,GAAGR;IAEJ,qBACE,6BAACsC,8BAAqB;QACpBC,iBAAiBF;QACjBG,kBAAkBzC;QAClB0C,gBACE;YACExC;YACAC;YACAiC;YACAhC;YACAE;YACAC;YACAC;YACAC;QACF;;AAIR;MAEA,WAAe0B"}