2019-07-02 16:29:52 +08:00
|
|
|
|
<template>
|
2019-10-29 13:15:57 +08:00
|
|
|
|
<!-- :style="{height: queryList.height ? 'auto' : listPageHeight}" -->
|
|
|
|
|
<div class="query-list-page">
|
2019-07-02 16:29:52 +08:00
|
|
|
|
<query-form
|
|
|
|
|
v-show="!(queryForm.show === false)"
|
|
|
|
|
ref="queryForm"
|
|
|
|
|
:query-form="queryForm"
|
2019-10-28 10:26:33 +08:00
|
|
|
|
:left-span="queryForm.leftSpan"
|
2020-04-21 15:08:27 +08:00
|
|
|
|
:offset-span="queryForm.offsetSpan"
|
2019-07-02 16:29:52 +08:00
|
|
|
|
:query-list="queryList"
|
|
|
|
|
:before-query="queryForm.beforeQuery"
|
|
|
|
|
:can-query="canQuery"
|
|
|
|
|
@query="query"
|
|
|
|
|
@queryExport="queryExport"
|
|
|
|
|
@disableQuery="disableQuery"
|
|
|
|
|
@enableQuery="enableQuery"
|
|
|
|
|
/>
|
|
|
|
|
<el-card v-loading="loading">
|
|
|
|
|
<el-table
|
|
|
|
|
ref="table2"
|
|
|
|
|
highlight-current-row
|
|
|
|
|
stripe
|
|
|
|
|
border
|
|
|
|
|
:data="queryList.data"
|
|
|
|
|
size="medium"
|
|
|
|
|
:header-cell-style="headerCellStyle"
|
|
|
|
|
:default-sort="queryList.defaultSort"
|
|
|
|
|
@row-click="onRowClick"
|
|
|
|
|
@select="onSelect"
|
|
|
|
|
@select-all="onSelectAll"
|
|
|
|
|
@selection-change="onSelectionChange"
|
2019-12-12 10:40:54 +08:00
|
|
|
|
@sort-change="sortChange"
|
2019-07-02 16:29:52 +08:00
|
|
|
|
>
|
|
|
|
|
<el-table-column v-if="queryList.selectCheckShow" type="selection" width="55" />
|
2019-11-11 09:20:24 +08:00
|
|
|
|
<el-table-column v-if="queryList.indexShow" type="index" width="50" :label="this.$t('global.index')" />
|
2020-04-21 15:08:27 +08:00
|
|
|
|
<el-table-column v-if="queryList.radioShow" :label="`#${$t('global.select')}`" width="80">
|
2019-07-02 16:29:52 +08:00
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<el-radio v-model="choose" :label="scope.row">{{ `` }}</el-radio>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<template v-for="(column, index) in queryList.columns">
|
|
|
|
|
<el-table-column
|
2019-10-11 17:35:22 +08:00
|
|
|
|
v-if="checkColumnTyep(column, 'basic')"
|
2019-07-02 16:29:52 +08:00
|
|
|
|
:key="index"
|
|
|
|
|
:prop="column.prop"
|
|
|
|
|
:label="column.title"
|
|
|
|
|
:width="column.width"
|
|
|
|
|
show-overflow-tooltip
|
|
|
|
|
:sortable="column.sortable"
|
2019-12-12 10:40:54 +08:00
|
|
|
|
:sort-by="column.sortBy"
|
2019-07-02 16:29:52 +08:00
|
|
|
|
/>
|
2020-05-27 16:36:55 +08:00
|
|
|
|
<el-table-column
|
|
|
|
|
v-else-if="checkColumnTyep(column, 'html')"
|
|
|
|
|
:key="index"
|
|
|
|
|
:prop="column.prop"
|
|
|
|
|
:label="column.title"
|
|
|
|
|
:width="column.width"
|
|
|
|
|
show-overflow-tooltip
|
|
|
|
|
:sortable="column.sortable"
|
|
|
|
|
:sort-by="column.sortBy"
|
|
|
|
|
>
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<div v-html="scope.row[column.prop]" />
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
2019-08-08 13:47:30 +08:00
|
|
|
|
<el-table-column
|
2019-08-08 15:27:30 +08:00
|
|
|
|
v-else-if="checkColumnTyep(column, 'basicText')"
|
|
|
|
|
:key="index"
|
2019-08-13 11:10:55 +08:00
|
|
|
|
:label="column.title"
|
2019-08-08 15:27:30 +08:00
|
|
|
|
:width="column.width"
|
|
|
|
|
:sortable="column.sortable"
|
2019-12-12 10:40:54 +08:00
|
|
|
|
:sort-by="column.sortBy"
|
2019-08-13 11:10:55 +08:00
|
|
|
|
>
|
2019-08-08 15:27:30 +08:00
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<span class="hideOutContent">{{ column.columnValue(scope.row, scope.$index) }}</span>
|
|
|
|
|
</template>
|
2019-08-08 13:47:30 +08:00
|
|
|
|
</el-table-column>
|
2019-07-02 16:29:52 +08:00
|
|
|
|
<el-table-column
|
|
|
|
|
v-else-if="checkColumnTyep(column, 'tag')"
|
|
|
|
|
:key="index"
|
|
|
|
|
:label="column.title"
|
|
|
|
|
:width="column.width"
|
|
|
|
|
:sortable="column.sortable"
|
2019-12-12 10:40:54 +08:00
|
|
|
|
:sort-by="column.sortBy"
|
2019-07-02 16:29:52 +08:00
|
|
|
|
>
|
|
|
|
|
<template slot-scope="scope">
|
2019-08-30 17:00:18 +08:00
|
|
|
|
<el-tag v-if="column.columnValue(scope.row, scope.$index)" :type="column.tagType(scope.row, scope.$index)">{{ column.columnValue(scope.row, scope.$index) }}</el-tag>
|
2019-07-02 16:29:52 +08:00
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column
|
|
|
|
|
v-else-if="checkColumnTyep(column, 'replicText')"
|
|
|
|
|
:key="index"
|
|
|
|
|
:label="column.title"
|
|
|
|
|
:width="column.width"
|
|
|
|
|
:sortable="column.sortable"
|
2019-12-12 10:40:54 +08:00
|
|
|
|
:sort-by="column.sortBy"
|
2019-07-02 16:29:52 +08:00
|
|
|
|
>
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<span>{{ column.columnValue(scope.row, scope.$index) }}</span>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column
|
|
|
|
|
v-else-if="checkColumnTyep(column, 'tagMore')"
|
|
|
|
|
:key="index"
|
|
|
|
|
:label="column.title"
|
|
|
|
|
:width="column.width"
|
|
|
|
|
:sortable="column.sortable"
|
2019-12-12 10:40:54 +08:00
|
|
|
|
:sort-by="column.sortBy"
|
2019-07-02 16:29:52 +08:00
|
|
|
|
>
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<template v-for="tag in column.columnValue(scope.row)">
|
|
|
|
|
<el-tag
|
|
|
|
|
:key="tag"
|
|
|
|
|
:type="column.tagType(scope.row, scope.$index)"
|
|
|
|
|
style="margin-right: 10px; margin-bottom: 5px;"
|
|
|
|
|
>{{ tag }}</el-tag>
|
|
|
|
|
</template>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
<el-table-column
|
|
|
|
|
v-else-if="checkColumnTyep(column, 'formatter')"
|
|
|
|
|
:key="index"
|
|
|
|
|
:prop="column.prop"
|
|
|
|
|
:label="column.title"
|
|
|
|
|
:formatter="column.formatter"
|
|
|
|
|
:sortable="column.sortable"
|
2019-12-12 10:40:54 +08:00
|
|
|
|
:sort-by="column.sortBy"
|
2019-07-02 16:29:52 +08:00
|
|
|
|
/>
|
|
|
|
|
<el-table-column
|
|
|
|
|
v-else-if="checkColumnTyep(column, 'button') && !(column.hide && column.hide(column))"
|
|
|
|
|
:key="index"
|
|
|
|
|
:label="column.title"
|
|
|
|
|
:width="column.width"
|
|
|
|
|
>
|
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
<template v-for="(button, idx) in column.buttons">
|
|
|
|
|
<el-button
|
|
|
|
|
v-if="button.show === undefined ? ((button.showControl === undefined) ? true: button.showControl(scope.row)): button.show"
|
|
|
|
|
:key="idx"
|
|
|
|
|
size="mini"
|
2019-11-13 14:29:20 +08:00
|
|
|
|
style="margin-top: 5px;"
|
2020-06-16 18:36:18 +08:00
|
|
|
|
:loading="scope.row['loading'+idx]"
|
2019-07-02 16:29:52 +08:00
|
|
|
|
:type="button.type ? button.type : 'primary'"
|
|
|
|
|
:disabled="isTableBtnDisabled(button, scope.$index, scope.row)"
|
2020-06-16 18:36:18 +08:00
|
|
|
|
@click="button.handleClick(scope.$index, scope.row, idx) "
|
2019-09-02 17:05:53 +08:00
|
|
|
|
>{{ getTableBtnName(button.name, scope.$index, scope.row) }}</el-button>
|
2019-07-02 16:29:52 +08:00
|
|
|
|
</template>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table-column>
|
|
|
|
|
</template>
|
|
|
|
|
</el-table>
|
2019-11-14 16:22:39 +08:00
|
|
|
|
<div v-if="queryList.selectCheckShow" style="margin-top: 8px; margin-left: 8px;">
|
2019-07-02 16:29:52 +08:00
|
|
|
|
<el-button
|
|
|
|
|
size="mini"
|
|
|
|
|
:type="'primary'"
|
|
|
|
|
:disabled="!queryList.selection.length"
|
|
|
|
|
@click="queryList.selectAllClick(queryList.selection)"
|
2019-08-13 11:10:55 +08:00
|
|
|
|
>{{ $t('global.selectAdd') }}</el-button>
|
2019-07-02 16:29:52 +08:00
|
|
|
|
</div>
|
2020-05-26 13:03:37 +08:00
|
|
|
|
<div v-if="!queryList.paginationHiden" class="page-container " style="text-align: center; margin: 10px 0; height: 40px;">
|
2019-07-02 16:29:52 +08:00
|
|
|
|
<el-pagination
|
|
|
|
|
:current-page="pageIndex"
|
|
|
|
|
:page-sizes="[10, 20, 50, 100] "
|
|
|
|
|
:page-size="pageSize "
|
|
|
|
|
layout="total, sizes, prev, pager, next, jumper "
|
|
|
|
|
:total="queryList.total "
|
|
|
|
|
@size-change="pageSizeChange "
|
2020-04-13 10:05:09 +08:00
|
|
|
|
@current-change="changePage"
|
2019-07-02 16:29:52 +08:00
|
|
|
|
/>
|
|
|
|
|
</div>
|
|
|
|
|
</el-card>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
// import QueryForm from '@/components/QueryListPage/QueryForm'
|
|
|
|
|
// import { mapGetters } from 'vuex'
|
|
|
|
|
|
|
|
|
|
export default {
|
2019-10-29 13:15:57 +08:00
|
|
|
|
components: {
|
|
|
|
|
QueryForm: resolve => { require(['@/components/QueryListPage/QueryForm'], resolve); } // 懒加载
|
|
|
|
|
},
|
|
|
|
|
props: {
|
|
|
|
|
queryForm: {
|
|
|
|
|
type: Object,
|
|
|
|
|
required: true
|
|
|
|
|
},
|
|
|
|
|
pagerConfig: {
|
|
|
|
|
type: Object,
|
|
|
|
|
default() {
|
|
|
|
|
return {};
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
queryList: {
|
|
|
|
|
type: Object,
|
|
|
|
|
required: true
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
loading: false,
|
|
|
|
|
choose: null,
|
|
|
|
|
queryData: {},
|
|
|
|
|
currentpagerConfig: {},
|
|
|
|
|
headerCellStyle: {
|
|
|
|
|
// "background-color ": 'rgba(48, 60, 86, 1)',
|
|
|
|
|
// color: 'white'
|
|
|
|
|
},
|
|
|
|
|
listPageHeight: '100%',
|
|
|
|
|
tableHeight: 0,
|
|
|
|
|
pageSize: 10,
|
|
|
|
|
pageIndex: 1,
|
|
|
|
|
pageOffset: 0,
|
|
|
|
|
canQuery: true, // 查询按钮是否可点
|
2019-12-12 10:40:54 +08:00
|
|
|
|
thirdQRCodeMakeUrl: 'http://s.jiathis.com/qrcode.php?url=',
|
|
|
|
|
sortBy:''
|
2019-10-29 13:15:57 +08:00
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
computed: {
|
|
|
|
|
globalPagerConfig: function() {
|
|
|
|
|
const pagerConfig = {
|
|
|
|
|
pageSize: 'pageSize',
|
|
|
|
|
pageIndex: 'pageNow'
|
|
|
|
|
};
|
|
|
|
|
return pagerConfig;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
created() {
|
|
|
|
|
const self = this;
|
|
|
|
|
// queryList 如果没有data属性,就创建并赋值为[]
|
|
|
|
|
if (!this.queryList.data) {
|
|
|
|
|
this.$set(this.queryList, 'data', []);
|
|
|
|
|
}
|
|
|
|
|
// queryList 如果没有total属性,就创建并赋值为0
|
|
|
|
|
if (!this.queryList.total) {
|
|
|
|
|
this.$set(this.queryList, 'total', 0);
|
|
|
|
|
}
|
|
|
|
|
// 如果设置了pageConfig就使用它,否则使用globalPageConfig
|
|
|
|
|
if (!this.pagerConfig) {
|
|
|
|
|
this.currentpagerConfig = Object.assign({}, this.globalPagerConfig);
|
|
|
|
|
} else {
|
|
|
|
|
this.currentpagerConfig = Object.assign({}, this.pagerConfig);
|
|
|
|
|
}
|
|
|
|
|
// queryList 如果没有selection属性,就创建并赋值为[]
|
|
|
|
|
if (!this.queryList.selection) {
|
|
|
|
|
this.$set(this.queryList, 'selection', []);
|
|
|
|
|
}
|
|
|
|
|
// 给queryList添加数据重载的方法
|
|
|
|
|
this.queryList.reload = function() {
|
2020-07-01 11:27:09 +08:00
|
|
|
|
self.choose = null;
|
2019-10-29 13:15:57 +08:00
|
|
|
|
return self.commitQuery();
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
mounted() {
|
|
|
|
|
// this.commitQuery();
|
|
|
|
|
// this.tableHeight = this.$refs.table2.$el.offsetHeight + 23;
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
// 根据类型显示
|
|
|
|
|
checkColumnTyep(column, typeName) {
|
|
|
|
|
if (column.show === false) {
|
|
|
|
|
return false;
|
|
|
|
|
} else if (column.isShow) {
|
|
|
|
|
return column.isShow();
|
|
|
|
|
}
|
|
|
|
|
if (typeof column.type === 'undefined') {
|
|
|
|
|
if (column.formatter instanceof Function) {
|
|
|
|
|
column.type = 'formatter';
|
|
|
|
|
} else {
|
|
|
|
|
column.type = 'basic';
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
// 类型是否匹配
|
|
|
|
|
const typeFlag = column.type === typeName;
|
|
|
|
|
return typeFlag;
|
|
|
|
|
},
|
|
|
|
|
isTableBtnDisabled(button, index, row) {
|
|
|
|
|
if (button.isDisabled) {
|
|
|
|
|
return button.isDisabled(index, row);
|
|
|
|
|
} else {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
// 计算列表的列为链接时显示的名称,可能为列对象的字段
|
|
|
|
|
getTableBtnName(btnName, index, row) {
|
|
|
|
|
if (typeof btnName.trim() === 'function') {
|
|
|
|
|
return btnName(index, row);
|
|
|
|
|
} else {
|
|
|
|
|
return btnName;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
// 按钮查询
|
|
|
|
|
query(queryData) {
|
|
|
|
|
this.queryData = queryData;
|
2020-04-13 10:05:09 +08:00
|
|
|
|
this.pageIndex = 1;
|
|
|
|
|
this.queryData[this.currentpagerConfig.pageSize] = this.pageSize;
|
|
|
|
|
this.queryData[this.currentpagerConfig.pageIndex] = this.pageIndex;
|
2019-10-29 13:15:57 +08:00
|
|
|
|
this.queryList.reload();
|
|
|
|
|
},
|
|
|
|
|
// 导出操作
|
|
|
|
|
queryExport(queryData) {
|
|
|
|
|
const self = this;
|
|
|
|
|
self.disableQuery();
|
|
|
|
|
self.queryData = queryData;
|
2019-07-02 16:29:52 +08:00
|
|
|
|
import('@/utils/Export2Excel').then(excel => {
|
2019-10-29 13:15:57 +08:00
|
|
|
|
const tHeader = self.queryForm.exportConfig.header;
|
|
|
|
|
self.prepareExportData().then(data => {
|
|
|
|
|
excel.export_json_to_excel(tHeader, data, self.queryForm.exportConfig.filename);
|
|
|
|
|
self.enableQuery();
|
2020-04-22 18:37:09 +08:00
|
|
|
|
}).catch(() => {
|
2019-10-29 13:15:57 +08:00
|
|
|
|
self.enableQuery();
|
|
|
|
|
});
|
2019-08-02 10:36:17 +08:00
|
|
|
|
});
|
2019-10-29 13:15:57 +08:00
|
|
|
|
},
|
|
|
|
|
// 导出数据准备
|
|
|
|
|
prepareExportData() {
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
|
const filterVals = this.queryForm.exportConfig.filterVals;
|
|
|
|
|
this.queryExportData().then(result => {
|
|
|
|
|
const list = result.list;
|
|
|
|
|
const data = this.formatJson(filterVals, list);
|
|
|
|
|
resolve(data);
|
|
|
|
|
}).catch(error => {
|
|
|
|
|
reject(error);
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
// 格式化数据列表
|
|
|
|
|
formatJson(filterVals, list) {
|
|
|
|
|
return list.map(v => filterVals.map(fv => {
|
|
|
|
|
let keys = [];
|
|
|
|
|
if (typeof (fv) === 'string') {
|
|
|
|
|
keys = fv.split('.');
|
|
|
|
|
} else {
|
|
|
|
|
keys = fv.key.split('.');
|
|
|
|
|
}
|
|
|
|
|
let obj = v;
|
|
|
|
|
keys.forEach(element => {
|
|
|
|
|
obj = obj[element];
|
|
|
|
|
});
|
|
|
|
|
if (fv.type === 'date') {
|
|
|
|
|
const format = fv.format || 'yyyy-MM-dd';
|
|
|
|
|
return new Date(obj).Format(format);
|
|
|
|
|
} else if (fv.formatter instanceof Function) {
|
|
|
|
|
return fv.formatter(v);
|
|
|
|
|
} else {
|
|
|
|
|
return obj;
|
|
|
|
|
}
|
|
|
|
|
}));
|
|
|
|
|
},
|
|
|
|
|
// 查询需要导出的数据列表
|
|
|
|
|
queryExportData() {
|
|
|
|
|
},
|
|
|
|
|
/**
|
2019-08-08 14:32:32 +08:00
|
|
|
|
* 翻页方法
|
|
|
|
|
* pageIndex: 翻页后是第几页
|
|
|
|
|
* params: 查询条件
|
|
|
|
|
**/
|
2019-10-29 13:15:57 +08:00
|
|
|
|
changePage(pageIndex, params) {
|
|
|
|
|
this.pageIndex = pageIndex;
|
|
|
|
|
this.pageOffset = (this.pageIndex - 1) * this.pageSize;
|
|
|
|
|
if (params) {
|
|
|
|
|
// 如果是点查询按钮到这来的,不用混合分页信息,已经有默认的第一页信息
|
|
|
|
|
this.queryData = params;
|
|
|
|
|
// 以防pageSize改变, 重新赋值
|
|
|
|
|
this.queryData[this.currentpagerConfig.pageSize] = this.pageSize;
|
|
|
|
|
} else {
|
|
|
|
|
// 如果是点翻页按钮到这来的,把分页信息混合到this.queryData里
|
|
|
|
|
this.mixinBackPageInfoToQueryData();
|
|
|
|
|
}
|
|
|
|
|
// 加时间戳
|
|
|
|
|
// this.queryData._time = this.$moment()._d.getTime();
|
|
|
|
|
this.queryList.reload();
|
|
|
|
|
},
|
|
|
|
|
/**
|
2019-08-08 14:32:32 +08:00
|
|
|
|
* 改变分页大小回调函数,执行完毕后,iview会自动触发changePage事件,去查第一页数据
|
|
|
|
|
*/
|
2019-10-29 13:15:57 +08:00
|
|
|
|
pageSizeChange(newPageSize) {
|
|
|
|
|
if (newPageSize) {
|
|
|
|
|
this.pageSize = newPageSize;
|
|
|
|
|
this.changePage(1, this.queryData);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
/**
|
2019-08-08 14:32:32 +08:00
|
|
|
|
* 把分页信息混合到this.queryData里
|
|
|
|
|
*/
|
2019-10-29 13:15:57 +08:00
|
|
|
|
mixinBackPageInfoToQueryData() {
|
|
|
|
|
// 当前的分页信息
|
|
|
|
|
const pagerParams = {
|
|
|
|
|
pageSize: this.pageSize,
|
|
|
|
|
pageIndex: this.pageIndex,
|
|
|
|
|
pageOffset: this.pageOffset
|
|
|
|
|
};
|
|
|
|
|
const tempPagerParams = {};
|
|
|
|
|
// 肯定要有pageSize
|
|
|
|
|
tempPagerParams[this.currentpagerConfig.pageSize] = pagerParams.pageSize || this.queryData[this.currentpagerConfig.pageSize];
|
|
|
|
|
// 判断使用 pageIndex 还是 pageOffset
|
|
|
|
|
if (this.currentpagerConfig.pageIndex) {
|
|
|
|
|
// 使用 pageIndex
|
|
|
|
|
tempPagerParams[this.currentpagerConfig.pageIndex] = pagerParams.pageIndex || this.queryData[this.currentpagerConfig.pageIndex];
|
|
|
|
|
} else {
|
|
|
|
|
// 使用 pageOffset
|
|
|
|
|
tempPagerParams[this.currentpagerConfig.pageOffset] = pagerParams.pageOffset !== undefined ? pagerParams.pageOffset : this.queryData[this.currentpagerConfig.pageOffset];
|
|
|
|
|
}
|
|
|
|
|
// 将分页信息封装到查询条件中
|
|
|
|
|
this.queryData = { ...this.queryData, ...tempPagerParams };
|
|
|
|
|
},
|
|
|
|
|
preCommitQueryHandler() {
|
|
|
|
|
// 填充表单
|
|
|
|
|
// this.$refs.form2.initFormData(this.queryData);
|
|
|
|
|
// 预设分页组件
|
|
|
|
|
this.pageIndex = parseInt(this.queryData[this.currentpagerConfig.pageIndex] || this.pageIndex);
|
|
|
|
|
this.pageSize = parseInt(this.queryData[this.currentpagerConfig.pageSize]);
|
|
|
|
|
},
|
|
|
|
|
commitQuery() {
|
|
|
|
|
const self = this;
|
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
|
self.disableQuery();
|
|
|
|
|
self.mixinBackPageInfoToQueryData();
|
|
|
|
|
const postData = this.queryData;
|
|
|
|
|
if (postData === false) {
|
|
|
|
|
self.enableQuery();
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (this.queryList.query instanceof Function) {
|
|
|
|
|
this.queryList.query(this.queryData).then(response => {
|
|
|
|
|
self.enableQuery();
|
|
|
|
|
if (this.queryList.afterQuery && this.queryList.afterQuery instanceof Function) {
|
|
|
|
|
this.queryList.afterQuery(response.data);
|
|
|
|
|
}
|
2019-08-14 15:19:11 +08:00
|
|
|
|
|
2019-10-29 13:15:57 +08:00
|
|
|
|
const resultData = response.data;
|
|
|
|
|
this.$set(this.queryList, 'data', resultData.list);
|
|
|
|
|
this.$set(this.queryList, 'total', resultData.total);
|
2020-04-22 18:37:09 +08:00
|
|
|
|
}).catch(() => {
|
2019-10-29 13:15:57 +08:00
|
|
|
|
self.enableQuery();
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
const data = this.queryList.data;
|
|
|
|
|
if (data) {
|
|
|
|
|
self.enableQuery();
|
|
|
|
|
if (this.queryList.afterQuery && this.queryList.afterQuery instanceof Function) {
|
|
|
|
|
this.queryList.afterQuery(data);
|
|
|
|
|
}
|
|
|
|
|
this.$set(this.queryList, 'data', data);
|
2019-07-02 16:29:52 +08:00
|
|
|
|
|
2019-10-29 13:15:57 +08:00
|
|
|
|
let total = this.queryList.total;
|
|
|
|
|
if (!total) {
|
|
|
|
|
total = this.queryList.data.length;
|
|
|
|
|
}
|
|
|
|
|
this.$set(this.queryList, 'total', total);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
enableQuery() {
|
|
|
|
|
this.canQuery = true;
|
|
|
|
|
this.loading = false;
|
|
|
|
|
},
|
|
|
|
|
disableQuery() {
|
|
|
|
|
// 禁止查询按钮
|
|
|
|
|
this.canQuery = false;
|
|
|
|
|
this.loading = true;
|
|
|
|
|
// 清空表格的数据
|
|
|
|
|
// this.queryList.data = [];
|
|
|
|
|
},
|
|
|
|
|
onSelect(selection, row) {
|
|
|
|
|
this.queryList.onSelect && this.queryList.onSelect(selection, row);
|
|
|
|
|
this.queryList.selection = selection;
|
|
|
|
|
},
|
|
|
|
|
onSelectAll(selection) {
|
|
|
|
|
this.queryList.onSelectAll && this.queryList.onSelectAll(selection);
|
|
|
|
|
this.queryList.selection = selection;
|
|
|
|
|
},
|
|
|
|
|
onSelectionChange(selection) {
|
|
|
|
|
this.queryList.onSelectionChange && this.queryList.onSelectionChange(selection);
|
|
|
|
|
this.queryList.selection = selection;
|
|
|
|
|
},
|
|
|
|
|
onRowClick(row) {
|
|
|
|
|
this.choose = row;
|
|
|
|
|
},
|
|
|
|
|
currentChoose() {
|
|
|
|
|
return this.choose;
|
|
|
|
|
},
|
|
|
|
|
refresh(flag) {
|
|
|
|
|
if (flag) {
|
|
|
|
|
this.commitQuery();
|
|
|
|
|
}
|
|
|
|
|
this.queryList.data = [...this.queryList.data];
|
2019-12-12 10:40:54 +08:00
|
|
|
|
},
|
2020-05-29 18:24:51 +08:00
|
|
|
|
getFormModel() {
|
|
|
|
|
if (this.$refs.queryForm) {
|
|
|
|
|
return this.$refs.queryForm.getFormModel();
|
|
|
|
|
} else {
|
|
|
|
|
return '';
|
|
|
|
|
}
|
|
|
|
|
},
|
2019-12-12 10:40:54 +08:00
|
|
|
|
sortChange(data) {
|
|
|
|
|
const self = this;
|
|
|
|
|
if (data.order && data.column.sortable == 'custom') {
|
|
|
|
|
switch (data.order) {
|
|
|
|
|
case 'ascending': {
|
|
|
|
|
if (data.column.sortBy) {
|
|
|
|
|
const temp = {};
|
|
|
|
|
temp[data.column.sortBy] = data.prop;
|
|
|
|
|
self.queryData = { ...self.queryData, ...temp };
|
|
|
|
|
self.sortBy = data.column.sortBy;
|
|
|
|
|
self.refresh(true);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
case 'descending': {
|
|
|
|
|
if (data.column.sortBy) {
|
|
|
|
|
const temp = {};
|
|
|
|
|
temp[data.column.sortBy] = data.prop + ' desc';
|
|
|
|
|
self.queryData = { ...self.queryData, ...temp };
|
|
|
|
|
self.sortBy = data.column.sortBy;
|
|
|
|
|
self.refresh(true);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
delete self.queryData[self.sortBy];
|
|
|
|
|
self.refresh(true);
|
|
|
|
|
}
|
2019-10-29 13:15:57 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2019-07-02 16:29:52 +08:00
|
|
|
|
|
2019-08-02 10:36:17 +08:00
|
|
|
|
};
|
2019-07-02 16:29:52 +08:00
|
|
|
|
|
|
|
|
|
</script>
|