element-plus
Version:
A Component Library for Vue3.0
42 lines (38 loc) • 954 B
text/typescript
import { PropType } from 'vue'
import { Store } from '../store'
import { ColumnCls, ColumnStyle, DefaultRow, Table } from '../table/defaults'
interface TableBodyProps<T> {
store: Store<T>
stripe?: boolean
context: Table<T>
rowClassName: ColumnCls<T>
rowStyle: ColumnStyle<T>
fixed: string
highlight: boolean
tooltipEffect: string
}
const defaultProps = {
store: {
required: true,
type: Object as PropType<TableBodyProps<DefaultRow>['store']>,
},
stripe: Boolean,
tooltipEffect: String,
context: {
default: () => ({}),
type: Object as PropType<TableBodyProps<DefaultRow>['context']>,
},
rowClassName: [String, Function] as PropType<
TableBodyProps<DefaultRow>['rowClassName']
>,
rowStyle: [Object, Function] as PropType<
TableBodyProps<DefaultRow>['rowStyle']
>,
fixed: {
type: String,
default: '',
},
highlight: Boolean,
}
export { TableBodyProps }
export default defaultProps