363 lines
15 KiB
Vue
363 lines
15 KiB
Vue
<template>
|
|
<div class="layout-content-wrap">
|
|
<div class="navigation-bar flex-row mb-16">
|
|
<img src="../../assets/image/Link.png" height="22" alt="">
|
|
<a>/</a>
|
|
<a>案件错误修复</a>
|
|
</div>
|
|
|
|
<div class="layout-tabs-content-box background-color-fff border-radius-4">
|
|
<div class="pt-8 border-b-solid-lighter-1">
|
|
<div class="height-30 flex-row align-items-center justify-content-between mb-24">
|
|
<div class="f22 color-text-primary">筛选</div>
|
|
</div>
|
|
<el-collapse-transition>
|
|
<div v-show="showSearch">
|
|
<el-row :gutter="56">
|
|
<el-col :span="6">
|
|
<div class="flex-row-center align-items-center height-40 mb-24">
|
|
<span class="tabs__search-criteria-title flex-shrink-0 pr-16">案件包名称</span>
|
|
<el-select v-model="queryParam.pkgName" placeholder="请选择案件包"
|
|
class="width100" >
|
|
<el-option
|
|
v-for="item in CasepackageList"
|
|
:key="item.id"
|
|
:label="item.pkgName"
|
|
:value="item.id">
|
|
</el-option>
|
|
</el-select>
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="14">
|
|
<div class="flex-row align-items-center justify-content-end">
|
|
|
|
</div>
|
|
</el-col>
|
|
<el-col :span="4" >
|
|
<div class="flex-row align-items-center justify-content-end">
|
|
<el-button @click="hanldeReset">重置</el-button>
|
|
<el-button type="primary" @click="handleSearch">搜索</el-button>
|
|
</div>
|
|
</el-col>
|
|
</el-row>
|
|
|
|
<el-row :gutter="56">
|
|
|
|
</el-row>
|
|
</div>
|
|
</el-collapse-transition>
|
|
</div>
|
|
<!-- table -->
|
|
<div class="pt-8">
|
|
<div class="height-56 flex-row align-items-center justify-content-between">
|
|
<div class="f22 color-text-primary">列表</div>
|
|
<div class="flex-row">
|
|
<el-button size="small" type="primary" @click="handleImport">导入案件</el-button>
|
|
<el-button size="small" @click="handleAddForm">导出错误案件</el-button>
|
|
<el-button size="small" @click="handleDelete">清空错误案件</el-button>
|
|
</div>
|
|
</div>
|
|
|
|
<div >
|
|
<el-table :data="tableData" :height="`${contentHeight}`"
|
|
@selection-change="handleSelectionChange">
|
|
<el-table-column type="index" label="序号" width="55"></el-table-column>
|
|
<!-- <el-table-column type="selection" width="55" ></el-table-column> -->
|
|
<el-table-column prop="pkgName" label="案件包名称" show-overflow-tooltip ></el-table-column>
|
|
<el-table-column prop="entrustingAgencyName" label="委案机构" show-overflow-tooltip ></el-table-column>
|
|
<el-table-column prop="channel" label="被申请人姓名" show-overflow-tooltip ></el-table-column>
|
|
<el-table-column prop="channel" label="被申请人手机号码" show-overflow-tooltip ></el-table-column>
|
|
<el-table-column prop="months" label="身份证号码" show-overflow-tooltip ></el-table-column>
|
|
<el-table-column prop="caseTotal" label="金融产品名称" show-overflow-tooltip ></el-table-column>
|
|
<el-table-column prop="assignTotal" label="合同名称" show-overflow-tooltip ></el-table-column>
|
|
<el-table-column prop="assignTotal" label="委托时逾期天数" show-overflow-tooltip ></el-table-column>
|
|
<!-- <el-table-column prop="assignTotal" label="合同名称" show-overflow-tooltip ></el-table-column> -->
|
|
<el-table-column prop="assignTotal" label="当前逾期金额" show-overflow-tooltip ></el-table-column>
|
|
</el-table>
|
|
</div>
|
|
|
|
<div class="text-center pt-16">
|
|
<el-pagination
|
|
@size-change="getCaseInfoList"
|
|
@current-change="getCaseInfoList"
|
|
:current-page="queryParam.current"
|
|
:page-size="queryParam.size"
|
|
layout="total, prev, pager, next, jumper"
|
|
:total="total">
|
|
</el-pagination>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
<!-- 导入 -->
|
|
<importPackageDialog v-if="importCaseDialog" :importCaseDialog.sync="importCaseDialog" />
|
|
|
|
</div>
|
|
</template>
|
|
<script>
|
|
import cpkapi from "@/services/casePackageManagement";
|
|
import api from "@/services/casePackageManagement";
|
|
export default {
|
|
components: {
|
|
importPackageDialog: () => import('./components/importPackageDialog'),//导入
|
|
|
|
},
|
|
data() {
|
|
return {
|
|
activeName:'all',
|
|
showSearch: true,
|
|
queryDate: '',
|
|
activeUsage: '',
|
|
|
|
mediateStatusData:[],//所有案件状态枚举
|
|
financialProductsTypeOptions:[],//金融产品类型
|
|
departmentOptions:[],//区域
|
|
queryParam: {
|
|
pkgName:'',//案件包名称
|
|
entrustingAgencyName: '',//委案机构
|
|
endTime: '',//结束时间
|
|
beginTime:'',//开始时间
|
|
willEnd:'',
|
|
current:1,
|
|
size:10,
|
|
},
|
|
usageOption: ['今日','昨日', '近一周', '近一月', '近半年', '近一年'],
|
|
tableData: [],
|
|
total:0,
|
|
uniqueSelection:[],
|
|
caseAllocationDialog:null,//案件分配弹框
|
|
importCaseDialog:null,//导入
|
|
addCaseDialog:null,//新增
|
|
editCaseDrawer:null,//编辑
|
|
CasepackageList:[],
|
|
|
|
}
|
|
},
|
|
created() {
|
|
this.getCasepkgList()
|
|
this.getCaseInfoList(1)
|
|
},
|
|
computed:{
|
|
// 获取抽屉drawer的内容高度
|
|
contentHeight(){
|
|
let oh = document.documentElement.clientHeight;
|
|
if(this.showSearch){
|
|
return oh-56-48-366-32
|
|
|
|
}else{
|
|
return oh-56-48-175-32
|
|
}
|
|
}
|
|
},
|
|
methods: {
|
|
jumpUrl (url) {
|
|
this.$router.push(url);
|
|
},
|
|
// 案件包列表数据
|
|
getCasepkgList(){
|
|
cpkapi.getCasePkgQuery({current:1,size:500}).then(res => {
|
|
if (!res.code) {
|
|
this.CasepackageList = res.records;
|
|
}
|
|
})
|
|
},
|
|
// 导入
|
|
handleImport(){
|
|
this.importCaseDialog={
|
|
title:'批量导入案件',
|
|
}
|
|
},
|
|
// 批量删除
|
|
handleBatchDelete(){
|
|
if(this.uniqueSelection.length==0){
|
|
this.$message.warning("请先选择你要删除的列表数据");
|
|
return
|
|
}
|
|
this.$confirm("请确定是否删除这些数据?", "提示", {
|
|
confirmButtonText: "确定",
|
|
cancelButtonText: "取消",
|
|
type: "warning",
|
|
}).then(() => {
|
|
if(!this.$clickThrottle()) { return }//防止重复点击
|
|
|
|
let data = {
|
|
ids:this.uniqueSelection
|
|
}
|
|
api.deleteCaseBatch(data).then((res) => {
|
|
|
|
this.$message.success("成功");
|
|
this.getCaseInfoList(1)
|
|
|
|
});
|
|
}).catch(() => {});
|
|
},
|
|
// 单条删除
|
|
handleDelete(scope){
|
|
this.$confirm("请确定是否删除此条数据?", "提示", {
|
|
confirmButtonText: "确定",
|
|
cancelButtonText: "取消",
|
|
type: "warning",
|
|
}).then(() => {
|
|
if(!this.$clickThrottle()) { return }//防止重复点击
|
|
// api.CasePkgdeleteById({id:scope.row.id}).then((res) => {
|
|
|
|
// this.$message.success("删除成功");
|
|
// this.getCaseInfoList(1)
|
|
|
|
// });
|
|
}).catch(() => {});
|
|
},
|
|
//撤回分案
|
|
handleBackCase(scope){
|
|
this.$confirm("请确定是否撤回分案?", "提示", {
|
|
confirmButtonText: "确定",
|
|
cancelButtonText: "取消",
|
|
type: "warning",
|
|
}).then(() => {
|
|
if(!this.$clickThrottle()) { return }//防止重复点击
|
|
api.postpkgquash({id:scope.row.id}).then((res) => {
|
|
this.$message.success("撤回分案成功");
|
|
this.getCaseInfoList(1)
|
|
|
|
});
|
|
}).catch(() => {});
|
|
},
|
|
// 新增
|
|
handleAddForm(){
|
|
this.addCaseDialog={
|
|
title:'新增案件',
|
|
}
|
|
},
|
|
// 案件分配
|
|
handleCaseAllocation(scope){
|
|
if((scope.row.caseTotal - scope.row.assignTotal) <= 0)
|
|
{
|
|
this.$message({
|
|
showClose: true,
|
|
message: '该案件包没有待分配的案件!',
|
|
type: 'warning'
|
|
});
|
|
return false
|
|
}
|
|
|
|
|
|
this.caseAllocationDialog={
|
|
title:'案件分配',
|
|
ObjectInfo:scope.row
|
|
}
|
|
},
|
|
// 编辑
|
|
handleEdit(scope){
|
|
this.editCaseDrawer={
|
|
title:'编辑案件',
|
|
data:scope.row,
|
|
currentPage:this.queryParam.current
|
|
}
|
|
},
|
|
// 列表数据
|
|
getCaseInfoList(val){
|
|
|
|
|
|
this.queryParam.planBegin = this.queryParam.beginTime
|
|
this.queryParam.planEnd = this.queryParam.endTime
|
|
this.queryParam.current = val
|
|
api.getCasePkgQuery(this.queryParam).then(res => {
|
|
if (!res.code) {
|
|
this.tableData = res.records;
|
|
this.total = res.total;
|
|
}
|
|
})
|
|
},
|
|
handleToggleSearch() {
|
|
this.showSearch = !this.showSearch
|
|
},
|
|
// 重置
|
|
hanldeReset() {
|
|
for (let key in this.queryParam) {
|
|
this.queryParam[key] = ''
|
|
}
|
|
this.queryParam.current = 1
|
|
this.queryParam.size = 10
|
|
},
|
|
handleSearch() {
|
|
this.queryParam.size = 10;
|
|
this.queryParam.current = 1;
|
|
this.getCaseInfoList(1)
|
|
},
|
|
handleClickUsage(item) {
|
|
this.activeUsage = item
|
|
this.setDateFast()
|
|
},
|
|
handleChangeDate() {
|
|
this.activeUsage = ''
|
|
if(this.queryDate === null) {
|
|
this.setDateFast()
|
|
}else {
|
|
this.queryParam.beginTime = this.$util.getDayStart(this.queryDate[0])
|
|
this.queryParam.endTime = this.$util.getDayEnd(this.queryDate[1])
|
|
}
|
|
|
|
},
|
|
setDateFast() {
|
|
switch (this.activeUsage) {
|
|
case "今日":
|
|
let todayObj = this.$util.getToday()
|
|
this.queryParam.beginTime = todayObj.todayStart
|
|
this.queryParam.endTime = todayObj.todayEnd
|
|
break
|
|
case "昨日":
|
|
let yesterdayObj = this.$util.getYesterday()
|
|
this.queryParam.beginTime = yesterdayObj.beginTime
|
|
this.queryParam.endTime = yesterdayObj.endTime
|
|
break
|
|
case "近一周":
|
|
let rangeWeek = this.$util.getRecentWeeks()
|
|
this.queryParam.beginTime = rangeWeek.recentWeekStart
|
|
this.queryParam.endTime = rangeWeek.todayEnd
|
|
break
|
|
case "近一月":
|
|
let rangeMonth = this.$util.getRecentMonths()
|
|
this.queryParam.beginTime = rangeMonth.recentMonthStart
|
|
this.queryParam.endTime = rangeMonth.todayEnd
|
|
break
|
|
case "近半年":
|
|
let rangeMonths = this.$util.getRecentMonths(6)
|
|
console.log('近半年:', rangeMonths)
|
|
this.queryParam.beginTime = rangeMonths.recentMonthStart
|
|
this.queryParam.endTime = rangeMonths.todayEnd
|
|
break
|
|
case "近一年":
|
|
let rangeYear = this.$util.getRecentYears()
|
|
this.queryParam.beginTime = rangeYear.recentYearStart
|
|
this.queryParam.endTime = rangeYear.todayEnd
|
|
break
|
|
default:
|
|
this.queryParam.beginTime = ''
|
|
this.queryParam.endTime = ''
|
|
this.queryDate = ''
|
|
break
|
|
}
|
|
if(this.queryParam.beginTime && this.queryParam.endTime) {
|
|
this.queryDate = [this.queryParam.beginTime, this.queryParam.endTime]
|
|
}
|
|
|
|
},
|
|
|
|
handleSelectionChange(val){
|
|
console.log('获取val',val)
|
|
this.uniqueSelection = []
|
|
val.forEach((row)=>{
|
|
this.uniqueSelection.push(row.id)
|
|
})
|
|
console.log('uniqueSelection',this.uniqueSelection)
|
|
|
|
},
|
|
|
|
}
|
|
}
|
|
</script>
|
|
<style scoped>
|
|
.el-badge{
|
|
top: 3px;
|
|
}
|
|
</style> |