105 lines
2.3 KiB
JavaScript
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>
|
|
)
|
|
},
|
|
}
|