import { Descriptions, Card, Flex, Divider } from 'antd' import PropTypes from 'prop-types' import ObjectProperty from './ObjectProperty' import { createElement } from 'react' const ObjectCard = ({ model, modelProperties, visibleColumns = {}, record, isEditing = false, rowActions = [], renderActions, cardStyle = 'borderless' }) => { const descriptionItems = [] const modelIcon = createElement(model.icon, { style: { fontSize: 24 } }) model.columns.forEach((colName) => { const prop = modelProperties.find((p) => p.name === colName) if (prop) { if ( (Object.keys(visibleColumns).length > 0 && visibleColumns[prop.name] === false) || prop.name == 'name' || (prop.name == 'state' && visibleColumns?.name == true) ) { return } descriptionItems.push( ) } }) var actions = undefined if (rowActions.length > 0) { actions = renderActions(record) } return ( {visibleColumns?.name == true && ( {modelIcon} p.name === 'name')} objectData={record} isEditing={isEditing} style={{ fontSize: 20, fontWeight: '600', lineHeight: 1.2 }} /> {visibleColumns?.state == true && ( p.name === 'state')} objectData={record} /> )} )} {descriptionItems} {actions && ( <> {actions} )} ) } ObjectCard.propTypes = { model: PropTypes.object.isRequired, modelProperties: PropTypes.array.isRequired, visibleColumns: PropTypes.object, record: PropTypes.object.isRequired, isEditing: PropTypes.bool, rowActions: PropTypes.array, renderActions: PropTypes.func.isRequired, cardStyle: PropTypes.string } export default ObjectCard