vxe-table
Version:
一个基于 vue 的 PC 端表格组件,支持增删改查、虚拟滚动、懒加载、快捷菜单、数据校验、树形结构、打印导出、表单渲染、数据分页、虚拟列表、模态窗口、自定义模板、渲染器、贼灵活的配置项、扩展接口等...
295 lines (283 loc) • 10.4 kB
JavaScript
import XEUtils from 'xe-utils/ctor'
import GlobalConfig from '../../conf'
import formats from '../../v-x-e-table/src/formats'
let zindexIndex = 0
let lastZindex = 1
function getColFuncWidth (isExists, defaultWidth = 16) {
return isExists ? defaultWidth : 0
}
class ColumnInfo {
/* eslint-disable @typescript-eslint/no-use-before-define */
constructor ($xetable, _vm, { renderHeader, renderCell, renderFooter, renderData } = {}) {
const $xegrid = $xetable.$xegrid
const proxyOpts = $xegrid ? $xegrid.proxyOpts : null
const formatter = _vm.formatter
const visible = XEUtils.isBoolean(_vm.visible) ? _vm.visible : true
if (process.env.VUE_APP_VXE_TABLE_ENV === 'development') {
const types = ['seq', 'checkbox', 'radio', 'expand', 'html']
if (_vm.type && types.indexOf(_vm.type) === -1) {
UtilTools.warn('vxe.error.errProp', [`type=${_vm.type}`, types.join(', ')])
}
if (_vm.cellRender && _vm.editRender) {
UtilTools.warn('vxe.error.errConflicts', ['column.cell-render', 'column.edit-render'])
}
if (_vm.type === 'expand') {
if ($xetable.treeConfig && $xetable.treeOpts.line) {
UtilTools.error('vxe.error.errConflicts', ['tree-config.line', 'column.type=expand'])
}
}
if (_vm.remoteSort) {
UtilTools.warn('vxe.error.delProp', ['column.remote-sort', 'sort-config.remote'])
}
if (_vm.sortMethod) {
UtilTools.warn('vxe.error.delProp', ['column.sort-method', 'sort-config.sortMethod'])
}
if (formatter) {
if (XEUtils.isString(formatter)) {
const globalFunc = formats.get(formatter) || XEUtils[formatter]
if (!XEUtils.isFunction(globalFunc)) {
UtilTools.error('vxe.error.notFunc', [formatter])
}
} else if (XEUtils.isArray(formatter)) {
const globalFunc = formats.get(formatter[0]) || XEUtils[formatter[0]]
if (!XEUtils.isFunction(globalFunc)) {
UtilTools.error('vxe.error.notFunc', [formatter[0]])
}
}
}
}
Object.assign(this, {
// 基本属性
type: _vm.type,
property: _vm.field,
title: _vm.title,
width: _vm.width,
minWidth: _vm.minWidth,
resizable: _vm.resizable,
fixed: _vm.fixed,
align: _vm.align,
headerAlign: _vm.headerAlign,
footerAlign: _vm.footerAlign,
showOverflow: _vm.showOverflow,
showHeaderOverflow: _vm.showHeaderOverflow,
showFooterOverflow: _vm.showFooterOverflow,
className: _vm.className,
headerClassName: _vm.headerClassName,
footerClassName: _vm.footerClassName,
formatter: formatter,
sortable: _vm.sortable,
sortBy: _vm.sortBy,
sortMethod: _vm.sortMethod,
remoteSort: _vm.remoteSort,
filters: UtilTools.getFilters(_vm.filters),
filterMultiple: XEUtils.isBoolean(_vm.filterMultiple) ? _vm.filterMultiple : true,
filterMethod: _vm.filterMethod,
filterRender: _vm.filterRender,
treeNode: _vm.treeNode,
cellType: _vm.cellType,
cellRender: _vm.cellRender,
editRender: _vm.editRender,
contentRender: _vm.contentRender,
exportMethod: _vm.exportMethod,
footerExportMethod: _vm.footerExportMethod,
titleHelp: _vm.titleHelp,
// 自定义参数
params: _vm.params,
// 渲染属性
id: _vm.colId || XEUtils.uniqueId('col_'),
parentId: null,
visible,
halfVisible: false,
defaultVisible: visible,
checked: false,
halfChecked: false,
disabled: false,
level: 1,
rowSpan: 1,
colSpan: 1,
order: null,
renderWidth: 0,
renderHeight: 0,
resizeWidth: 0,
renderLeft: 0,
renderArgs: [], // 渲染参数可用于扩展
model: {},
renderHeader: renderHeader || _vm.renderHeader,
renderCell: renderCell || _vm.renderCell,
renderFooter: renderFooter || _vm.renderFooter,
renderData: renderData,
// 单元格插槽,只对 grid 有效
slots: _vm.slots
})
if (proxyOpts && proxyOpts.beforeColumn) {
proxyOpts.beforeColumn({ $grid: $xegrid, column: this })
}
}
getTitle () {
return UtilTools.getFuncText(this.title || (this.type === 'seq' ? GlobalConfig.i18n('vxe.table.seqTitle') : ''))
}
getKey () {
return this.property || (this.type ? `type=${this.type}` : null)
}
update (name, value) {
// 不支持双向的属性
if (name !== 'filters') {
if (name === 'field') {
this.property = value
} else {
this[name] = value
}
}
}
}
function outLog (type) {
return function (message, params) {
const msg = UtilTools.getLog(message, params)
console[type](msg)
return msg
}
}
export const UtilTools = {
warn: outLog('warn'),
error: outLog('error'),
getLog (message, args) {
return `[vxe-table] ${GlobalConfig.i18n(message, args)}`
},
getFuncText (content) {
return XEUtils.isFunction(content) ? content() : (GlobalConfig.translate ? GlobalConfig.translate(content) : content)
},
nextZIndex () {
lastZindex = GlobalConfig.zIndex + zindexIndex++
return lastZindex
},
getLastZIndex () {
return lastZindex
},
// 行主键 key
getRowkey ($xetable) {
return $xetable.rowId || '_XID'
},
// 行主键 value
getRowid ($xetable, row) {
const rowId = XEUtils.get(row, UtilTools.getRowkey($xetable))
return rowId ? encodeURIComponent(rowId) : ''
},
// 获取所有的列,排除分组
getColumnList (columns) {
const result = []
columns.forEach(column => {
result.push(...(column.children && column.children.length ? UtilTools.getColumnList(column.children) : [column]))
})
return result
},
getClass (property, params) {
return property ? XEUtils.isFunction(property) ? property(params) : property : ''
},
getFilters (filters) {
if (filters && XEUtils.isArray(filters)) {
return filters.map(({ label, value, data, resetValue, checked }) => {
return { label, value, data, resetValue, checked: !!checked, _checked: !!checked }
})
}
return filters
},
formatText (value, placeholder) {
return '' + (value === '' || value === null || value === undefined ? (placeholder ? GlobalConfig.emptyCell : '') : value)
},
getCellValue (row, column) {
return XEUtils.get(row, column.property)
},
getCellLabel (row, column, params) {
const { formatter } = column
const cellValue = UtilTools.getCellValue(row, column)
let cellLabel = cellValue
if (params && formatter) {
let rest, formatData
const { $table } = params
const colid = column.id
const fullAllDataRowMap = $table.fullAllDataRowMap
const cacheFormat = fullAllDataRowMap.has(row)
const formatParams = { cellValue, row, column }
if (cacheFormat) {
rest = fullAllDataRowMap.get(row)
formatData = rest.formatData
if (!formatData) {
formatData = fullAllDataRowMap.get(row).formatData = {}
}
if (rest && formatData[colid]) {
if (formatData[colid].value === cellValue) {
return formatData[colid].label
}
}
}
if (XEUtils.isString(formatter)) {
const globalFunc = formats.get(formatter)
cellLabel = globalFunc ? globalFunc(formatParams) : ''
} else if (XEUtils.isArray(formatter)) {
const globalFunc = formats.get(formatter[0])
cellLabel = globalFunc ? globalFunc(formatParams, ...formatter.slice(1)) : ''
} else {
cellLabel = formatter(formatParams)
}
if (formatData) {
formatData[colid] = { value: cellValue, label: cellLabel }
}
}
return cellLabel
},
setCellValue (row, column, value) {
return XEUtils.set(row, column.property, value)
},
isColumn (column) {
return column instanceof ColumnInfo
},
getColumnConfig ($xetable, _vm, options) {
return UtilTools.isColumn(_vm) ? _vm : new ColumnInfo($xetable, _vm, options)
},
// 组装列配置
assemColumn (_vm) {
const { $el, $xetable, $xecolumn, columnConfig } = _vm
const groupConfig = $xecolumn ? $xecolumn.columnConfig : null
columnConfig.slots = _vm.$scopedSlots
if (groupConfig) {
if (process.env.VUE_APP_VXE_TABLE_ENV === 'development') {
if ($xecolumn.$options._componentTag === 'vxe-table-column') {
UtilTools.warn('vxe.error.groupTag', [`<vxe-table-colgroup title=${$xecolumn.title} ...>`, `<vxe-table-column title=${$xecolumn.title} ...>`])
}
}
if (!groupConfig.children) {
groupConfig.children = []
}
groupConfig.children.splice([].indexOf.call($xecolumn.$el.children, $el), 0, columnConfig)
} else {
$xetable.staticColumns.splice([].indexOf.call($xetable.$refs.hideColumn.children, $el), 0, columnConfig)
}
},
// 销毁列
destroyColumn (_vm) {
const { $xetable, columnConfig } = _vm
const matchObj = XEUtils.findTree($xetable.staticColumns, column => column === columnConfig)
if (matchObj) {
matchObj.items.splice(matchObj.index, 1)
}
},
hasChildrenList (item) {
return item && item.children && item.children.length > 0
},
getColMinWidth (_vm, column) {
const { sortOpts, filterOpts, editOpts } = _vm
const { type, filters, sortable, remoteSort, editRender, titleHelp } = column
return 40 + getColFuncWidth(type === 'checkbox', 18) + getColFuncWidth(titleHelp, 18) + getColFuncWidth(filters && filterOpts.showIcon) + getColFuncWidth((sortable || remoteSort) && sortOpts.showIcon) + getColFuncWidth(editRender && editOpts.showIcon, 32)
},
parseFile (file) {
const name = file.name
const tIndex = XEUtils.lastIndexOf(name, '.')
const type = name.substring(tIndex + 1, name.length)
const filename = name.substring(0, tIndex)
return { filename, type }
},
isNumVal (num) {
return !isNaN(parseFloat('' + num))
}
}
export default UtilTools