123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- <template>
- <el-table border style="width: 100%;overflow: auto;" :size="options.size || 'mini'" v-bind="options" :data="data">
- <slot name="pre"> </slot>
- <slot>
- <el-table-column
- v-for="(item, index) in listFields"
- :key="'field' + index"
- :label="item.label"
- :prop="item.name"
- :formatter="item.formatter"
- v-bind="item.options"
- show-overflow-tooltip
- />
- </slot>
- <slot name="ext"> </slot>
- <slot name="oper">
- <el-table-column label="操作" :width="options.operWidth || '100'" v-if="!readonly">
- <template slot-scope="scope">
- <el-button
- v-for="(item, index) in operItems"
- :key="'field' + index"
- @click="handleOper(item, scope.row, scope.$index)"
- type="text"
- :size="options.size || 'mini'"
- >
- <el-tooltip v-if="item.icon" :content="item.label"><i :class="item.icon"></i></el-tooltip>
- <span v-else>{{ item.label }}</span>
- </el-button>
- </template>
- </el-table-column>
- </slot>
- <slot name="post"> </slot>
- </el-table>
- </template>
- <script>
- import _ from 'lodash';
- import { FieldMeta, Operation, Formatter, MergeFilters } from './meta-util';
- export default {
- name: 'lite-grid',
- props: {
- meta: { type: Array, required: true },
- readonly: Boolean /* 是否显示操作列 */,
- options: {
- type: Object,
- default: () => ({ size: 'mini' }),
- } /* 表格扩展属性 */,
- operation: {
- default: () => [['edit', '编辑', 'el-icon-edit'], ['delete', '删除', 'el-icon-delete', true]],
- } /* 操作类型 */,
- data: Array,
- },
- methods: {
- async handleOper({ event, label, confirm }, data, index) {
- try {
- if (confirm) {
- const msg = _.isString(confirm) ? confirm : `是否${label}此数据?`;
- await this.$confirm(msg, '请确认', {
- confirmButtonText: '确定',
- cancelButtonText: '取消',
- type: 'warning',
- });
- }
- this.$emit(event, data, index);
- this.$emit('oper', { event, data, index });
- } catch (err) {
- if (err == 'cancel') {
- this.$message({
- type: 'info',
- message: `已取消${label}`,
- });
- }
- }
- },
- },
- computed: {
- listFields() {
- const res = this.meta
- .map(FieldMeta)
- .filter(p => p.slots.list)
- // .sort((a, b) => b.order - a.order)
- .map(p => ({
- ...p.field,
- formatter: Formatter(p, this),
- options: MergeFilters(p, this),
- }));
- // console.log('listFields: ', res);
- return res;
- },
- operItems() {
- return Operation(this.operation);
- },
- },
- };
- </script>
- <style lang="less" scoped>
- .el-table {
- height: 100%;
- overflow: auto;
- }
- .el-button + .el-button {
- margin-left: 5px;
- }
- </style>
|