ant-design-vue/components/vc-table/src/TableCell.jsx

105 lines
2.3 KiB
JavaScript

import PropTypes from '../../_util/vue-types'
import get from 'lodash/get'
export default {
name: 'TableCell',
props: {
record: PropTypes.object,
prefixCls: PropTypes.string,
index: PropTypes.number,
indent: PropTypes.number,
indentSize: PropTypes.number,
column: PropTypes.object,
expandIcon: PropTypes.any,
component: PropTypes.any,
},
methods: {
isInvalidRenderCellText (text) {
// debugger
return text &&
Object.prototype.toString.call(text) === '[object Object]'
},
handleClick (e) {
const { record, column: { onCellClick }} = this
if (onCellClick) {
onCellClick(record, e)
}
},
},
render () {
const {
record,
indentSize,
prefixCls,
indent,
index,
expandIcon,
column,
component: BodyCell,
} = this
const { dataIndex, render } = column
// We should return undefined if no dataIndex is specified, but in order to
// be compatible with object-path's behavior, we return the record object instead.
let text
if (typeof dataIndex === 'number') {
text = get(record, dataIndex)
} else if (!dataIndex || dataIndex.length === 0) {
text = record
} else {
text = get(record, dataIndex)
}
let tdProps = {}
let colSpan
let rowSpan
if (render) {
text = render(text, record, index)
if (this.isInvalidRenderCellText(text)) {
tdProps = text.props || tdProps
colSpan = tdProps.colSpan
rowSpan = tdProps.rowSpan
text = text.children
}
}
if (column.onCell) {
tdProps = { ...tdProps, ...column.onCell(record) }
}
// Fix https://github.com/ant-design/ant-design/issues/1202
if (this.isInvalidRenderCellText(text)) {
text = null
}
const indentText = expandIcon ? (
<span
style={{ paddingLeft: `${indentSize * indent}px` }}
class={`${prefixCls}-indent indent-level-${indent}`}
/>
) : null
if (rowSpan === 0 || colSpan === 0) {
return null
}
if (column.align) {
tdProps.style = { textAlign: column.align }
}
console.log('tdProps', tdProps)
return (
<BodyCell
onClick={this.handleClick}
{...tdProps}
>
{indentText}
{expandIcon}
{text}
</BodyCell>
)
},
}