2022-11-23 18:05:36 +08:00
|
|
|
|
import { App, unref, watch } from 'vue'
|
2022-10-19 17:10:19 +08:00
|
|
|
|
import XEUtils from 'xe-utils'
|
2022-11-23 15:40:34 +08:00
|
|
|
|
import './index.scss'
|
2022-11-12 15:52:43 +08:00
|
|
|
|
import './renderer'
|
2022-10-19 17:10:19 +08:00
|
|
|
|
import { i18n } from '@/plugins/vueI18n'
|
2022-11-23 18:05:36 +08:00
|
|
|
|
import { useAppStore } from '@/store/modules/app'
|
2022-11-23 15:40:34 +08:00
|
|
|
|
import zhCN from 'vxe-table/lib/locale/lang/zh-CN'
|
|
|
|
|
import enUS from 'vxe-table/lib/locale/lang/en-US'
|
2022-10-19 17:10:19 +08:00
|
|
|
|
import {
|
|
|
|
|
// 全局对象
|
|
|
|
|
VXETable,
|
|
|
|
|
// 表格功能
|
|
|
|
|
Filter,
|
|
|
|
|
Edit,
|
|
|
|
|
Menu,
|
|
|
|
|
Export,
|
|
|
|
|
Keyboard,
|
|
|
|
|
Validator,
|
|
|
|
|
// 可选组件
|
|
|
|
|
Icon,
|
|
|
|
|
Column,
|
|
|
|
|
Colgroup,
|
|
|
|
|
Grid,
|
|
|
|
|
Tooltip,
|
|
|
|
|
Toolbar,
|
|
|
|
|
Pager,
|
|
|
|
|
Form,
|
|
|
|
|
FormItem,
|
|
|
|
|
FormGather,
|
|
|
|
|
Checkbox,
|
|
|
|
|
CheckboxGroup,
|
|
|
|
|
Radio,
|
|
|
|
|
RadioGroup,
|
|
|
|
|
RadioButton,
|
|
|
|
|
Switch,
|
|
|
|
|
Input,
|
|
|
|
|
Select,
|
|
|
|
|
Optgroup,
|
|
|
|
|
Option,
|
|
|
|
|
Textarea,
|
|
|
|
|
Button,
|
|
|
|
|
Modal,
|
|
|
|
|
List,
|
|
|
|
|
Pulldown,
|
|
|
|
|
// 表格
|
|
|
|
|
Table
|
|
|
|
|
} from 'vxe-table'
|
|
|
|
|
|
2022-11-23 18:05:36 +08:00
|
|
|
|
const appStore = useAppStore()
|
|
|
|
|
watch(
|
|
|
|
|
() => appStore.getIsDark,
|
|
|
|
|
() => {
|
|
|
|
|
if (appStore.getIsDark) {
|
|
|
|
|
import('./theme/dark.scss')
|
|
|
|
|
} else {
|
|
|
|
|
import('./theme/light.scss')
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
{ immediate: true }
|
|
|
|
|
)
|
2022-10-19 17:10:19 +08:00
|
|
|
|
// 全局默认参数
|
|
|
|
|
VXETable.setup({
|
|
|
|
|
size: 'medium', // 全局尺寸
|
|
|
|
|
version: 0, // 版本号,对于某些带数据缓存的功能有用到,上升版本号可以用于重置数据
|
|
|
|
|
zIndex: 1008, // 全局 zIndex 起始值,如果项目的的 z-index 样式值过大时就需要跟随设置更大,避免被遮挡
|
|
|
|
|
loadingText: '加载中...', // 全局loading提示内容,如果为null则不显示文本
|
2022-11-01 14:36:18 +08:00
|
|
|
|
height: 600,
|
2022-10-19 17:10:19 +08:00
|
|
|
|
table: {
|
2022-11-01 15:56:40 +08:00
|
|
|
|
border: 'inner', // default(默认), full(完整边框), outer(外边框), inner(内边框), none(无边框)
|
|
|
|
|
align: 'center', // eft(左对齐), center(居中对齐), right(右对齐)
|
|
|
|
|
autoResize: true, // 自动监听父元素的变化去重新计算表格
|
|
|
|
|
resizable: true, // 列是否允许拖动列宽调整大小
|
|
|
|
|
emptyText: '暂无数据', // 空表单
|
2022-11-03 18:09:40 +08:00
|
|
|
|
highlightHoverRow: true, // 自动监听父元素的变化去重新计算表格
|
|
|
|
|
treeConfig: {
|
|
|
|
|
rowField: 'id',
|
|
|
|
|
parentField: 'parentId',
|
|
|
|
|
children: 'children',
|
|
|
|
|
indent: 20,
|
|
|
|
|
showIcon: true
|
|
|
|
|
}
|
2022-10-19 17:10:19 +08:00
|
|
|
|
},
|
2022-11-01 14:36:18 +08:00
|
|
|
|
grid: {
|
|
|
|
|
toolbarConfig: {
|
|
|
|
|
refresh: true,
|
|
|
|
|
export: true,
|
|
|
|
|
print: true,
|
|
|
|
|
zoom: true,
|
|
|
|
|
custom: true
|
|
|
|
|
},
|
|
|
|
|
pagerConfig: {
|
|
|
|
|
border: false,
|
|
|
|
|
background: true,
|
|
|
|
|
autoHidden: true,
|
|
|
|
|
perfect: true,
|
|
|
|
|
pageSize: 10,
|
|
|
|
|
pagerCount: 7,
|
|
|
|
|
pageSizes: [5, 10, 15, 20, 50, 100, 200, 500],
|
|
|
|
|
layouts: [
|
|
|
|
|
'PrevJump',
|
|
|
|
|
'PrevPage',
|
|
|
|
|
'Jump',
|
|
|
|
|
'PageCount',
|
|
|
|
|
'NextPage',
|
|
|
|
|
'NextJump',
|
|
|
|
|
'Sizes',
|
|
|
|
|
'Total'
|
|
|
|
|
]
|
|
|
|
|
}
|
|
|
|
|
},
|
2022-10-19 17:10:19 +08:00
|
|
|
|
pager: {
|
2022-11-01 14:36:18 +08:00
|
|
|
|
background: true,
|
2022-10-19 17:10:19 +08:00
|
|
|
|
autoHidden: false,
|
|
|
|
|
perfect: true,
|
|
|
|
|
pageSize: 10,
|
|
|
|
|
pagerCount: 7,
|
|
|
|
|
pageSizes: [10, 15, 20, 50, 100],
|
|
|
|
|
layouts: ['PrevJump', 'PrevPage', 'Jump', 'PageCount', 'NextPage', 'NextJump', 'Sizes', 'Total']
|
|
|
|
|
},
|
|
|
|
|
input: {
|
|
|
|
|
clearable: true
|
|
|
|
|
},
|
2022-11-01 17:12:26 +08:00
|
|
|
|
form: {
|
|
|
|
|
titleColon: true // 是否显示标题冒号
|
|
|
|
|
},
|
2022-11-01 15:56:40 +08:00
|
|
|
|
modal: {
|
2022-11-04 16:43:11 +08:00
|
|
|
|
width: 800, // 窗口的宽度
|
|
|
|
|
height: 600, // 窗口的高度
|
|
|
|
|
minWidth: 460,
|
|
|
|
|
minHeight: 320,
|
2022-11-01 15:56:40 +08:00
|
|
|
|
showZoom: true, // 标题是否标显示最大化与还原按钮
|
|
|
|
|
resize: true, // 是否允许窗口边缘拖动调整窗口大小
|
|
|
|
|
marginSize: 0, // 只对 resize 启用后有效,用于设置可拖动界限范围,如果为负数则允许拖动超出屏幕边界
|
|
|
|
|
remember: false, // 记忆功能,会记住最后操作状态,再次打开窗口时还原窗口状态
|
|
|
|
|
destroyOnClose: true, // 在窗口关闭时销毁内容
|
|
|
|
|
storage: false, // 是否启用 localStorage 本地保存,会将窗口拖动的状态保存到本地
|
|
|
|
|
transfer: true, // 是否将弹框容器插入于 body 内
|
|
|
|
|
showFooter: true, // 是否显示底部
|
|
|
|
|
mask: true, // 是否显示遮罩层
|
|
|
|
|
maskClosable: true, // 是否允许点击遮罩层关闭窗口
|
|
|
|
|
escClosable: true // 是否允许按 Esc 键关闭窗口
|
|
|
|
|
},
|
2022-10-19 17:10:19 +08:00
|
|
|
|
i18n: (key, args) => {
|
2022-10-19 18:08:42 +08:00
|
|
|
|
return unref(i18n.global.locale) === 'zh-CN'
|
2022-10-19 17:10:19 +08:00
|
|
|
|
? XEUtils.toFormatString(XEUtils.get(zhCN, key), args)
|
|
|
|
|
: XEUtils.toFormatString(XEUtils.get(enUS, key), args)
|
|
|
|
|
}
|
|
|
|
|
})
|
2022-11-03 18:09:40 +08:00
|
|
|
|
// 自定义全局的格式化处理函数
|
|
|
|
|
VXETable.formats.mixin({
|
|
|
|
|
// 格式日期,默认 yyyy-MM-dd HH:mm:ss
|
|
|
|
|
formatDate({ cellValue }, format) {
|
2022-11-28 16:50:53 +08:00
|
|
|
|
if (cellValue != null) {
|
|
|
|
|
return XEUtils.toDateString(cellValue, format || 'yyyy-MM-dd HH:mm:ss')
|
|
|
|
|
} else {
|
|
|
|
|
return ''
|
|
|
|
|
}
|
2022-11-03 18:09:40 +08:00
|
|
|
|
},
|
|
|
|
|
// 四舍五入金额,每隔3位逗号分隔,默认2位数
|
|
|
|
|
formatAmount({ cellValue }, digits = 2) {
|
|
|
|
|
return XEUtils.commafy(Number(cellValue), { digits })
|
|
|
|
|
},
|
|
|
|
|
// 格式化银行卡,默认每4位空格隔开
|
|
|
|
|
formatBankcard({ cellValue }) {
|
|
|
|
|
return XEUtils.commafy(XEUtils.toValueString(cellValue), { spaceNumber: 4, separator: ' ' })
|
|
|
|
|
},
|
|
|
|
|
// 四舍五入,默认两位数
|
|
|
|
|
formatFixedNumber({ cellValue }, digits = 2) {
|
|
|
|
|
return XEUtils.toFixed(XEUtils.round(cellValue, digits), digits)
|
|
|
|
|
},
|
|
|
|
|
// 向下舍入,默认两位数
|
|
|
|
|
formatCutNumber({ cellValue }, digits = 2) {
|
|
|
|
|
return XEUtils.toFixed(XEUtils.floor(cellValue, digits), digits)
|
2022-11-15 13:59:22 +08:00
|
|
|
|
},
|
|
|
|
|
// 格式化图片,将图片链接转换为html标签
|
|
|
|
|
formatImg({ cellValue }) {
|
|
|
|
|
return '<img height="40" src="' + cellValue + '"> '
|
2022-11-29 23:23:33 +08:00
|
|
|
|
},
|
|
|
|
|
// 格式化文件大小
|
|
|
|
|
formatSize({ cellValue }, digits = 0) {
|
|
|
|
|
const unitArr = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB']
|
|
|
|
|
const srcSize = parseFloat(cellValue)
|
|
|
|
|
const index = Math.floor(Math.log(srcSize) / Math.log(1024))
|
|
|
|
|
const size = srcSize / Math.pow(1024, index)
|
|
|
|
|
return XEUtils.toFixed(XEUtils.floor(size, 2), 2) + ' ' + unitArr[digits]
|
2022-11-03 18:09:40 +08:00
|
|
|
|
}
|
2022-11-01 17:12:26 +08:00
|
|
|
|
})
|
2022-10-19 17:10:19 +08:00
|
|
|
|
export const setupVxeTable = (app: App<Element>) => {
|
|
|
|
|
// 表格功能
|
|
|
|
|
app.use(Filter).use(Edit).use(Menu).use(Export).use(Keyboard).use(Validator)
|
|
|
|
|
|
|
|
|
|
// 可选组件
|
|
|
|
|
app
|
|
|
|
|
.use(Icon)
|
|
|
|
|
.use(Column)
|
|
|
|
|
.use(Colgroup)
|
|
|
|
|
.use(Grid)
|
|
|
|
|
.use(Tooltip)
|
|
|
|
|
.use(Toolbar)
|
|
|
|
|
.use(Pager)
|
|
|
|
|
.use(Form)
|
|
|
|
|
.use(FormItem)
|
|
|
|
|
.use(FormGather)
|
|
|
|
|
.use(Checkbox)
|
|
|
|
|
.use(CheckboxGroup)
|
|
|
|
|
.use(Radio)
|
|
|
|
|
.use(RadioGroup)
|
|
|
|
|
.use(RadioButton)
|
|
|
|
|
.use(Switch)
|
|
|
|
|
.use(Input)
|
|
|
|
|
.use(Select)
|
|
|
|
|
.use(Optgroup)
|
|
|
|
|
.use(Option)
|
|
|
|
|
.use(Textarea)
|
|
|
|
|
.use(Button)
|
|
|
|
|
.use(Modal)
|
|
|
|
|
.use(List)
|
|
|
|
|
.use(Pulldown)
|
|
|
|
|
|
|
|
|
|
// 安装表格
|
|
|
|
|
.use(Table)
|
|
|
|
|
|
|
|
|
|
// 给 vue 实例挂载内部对象,例如:
|
|
|
|
|
// app.config.globalProperties.$XModal = VXETable.modal
|
|
|
|
|
// app.config.globalProperties.$XPrint = VXETable.print
|
|
|
|
|
// app.config.globalProperties.$XSaveFile = VXETable.saveFile
|
|
|
|
|
// app.config.globalProperties.$XReadFile = VXETable.readFile
|
|
|
|
|
}
|