payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
95 lines (94 loc) • 12 kB
JavaScript
;
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"}