<template>
<!-- 通话回推列表 -->
<div class="CallList" v-loading="loading">
<el-row :gutter="12" class="mt10">
<el-col :span="24">
<el-card shadow="always" class='ml20 mr20'>
<el-form :inline="true" :model="formInline" label-width="100px" class="demo-form-inline mt20">
<el-form-item label="手机号">
<el-input v-model="formInline.phone" size="small" clearable></el-input>
</el-form-item>
<el-form-item label="接听状态">
<el-select v-model="formInline.status" size="small" clearable>
<el-option label="已接" value="dealing"></el-option>
<el-option label="振铃未接听" value="notDeal"></el-option>
<el-option label="ivr放弃" value="leak"></el-option>
<el-option label="排队放弃" value="queueLeak"></el-option>
<el-option label="黑名单" value="blackList"></el-option>
<el-option label="留言" value="voicemail"></el-option>
</el-select>
</el-form-item>
<br/>
<el-form-item label="通话类型">
<el-select v-model="formInline.type" size="small" clearable>
<el-option label="外呼通话" value="dialout"></el-option>
<el-option label="普通来电" value="normal"></el-option>
<el-option label="呼入转接" value="transfer"></el-option>
<el-option label="外呼转接" value="dialTransfer"></el-option>
</el-select>
</el-form-item>
<el-form-item label="创建时间">
<el-date-picker
v-model="date"
@change="setDate"
size="small"
type="daterange"
value-format='yyyy-MM-dd'
range-separator="至"
start-placeholder="开始日期"
end-placeholder="结束日期">
</el-date-picker>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit" size="small">查询</el-button>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="downExcel" size="small">导出</el-button>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="batch" size="small" :disabled='batchArr.length==0?true:false'>批量下载</el-button>
</el-form-item>
</el-form>
<el-table
size='small'
:data="tableData.rows"
@selection-change="handleSelectionChange"
style="width: 100%">
<el-table-column
type="selection"
width="55">
</el-table-column>
<el-table-column
prop="province"
width="60"
label="省份">
</el-table-column>
<el-table-column
prop="district"
width="60"
label="城市">
</el-table-column>
<el-table-column
prop="cdrVar"
width="100"
:formatter='filterCd'
label="电话号码">
</el-table-column>
<el-table-column
prop="callType"
width="80"
:formatter='setCallType'
label="通话类型">
</el-table-column>
<el-table-column
prop="state"
width="80"
:formatter='setState'
label="接听状态">
</el-table-column>
<el-table-column
prop="beginTime"
width="140"
:formatter='setTime'
label="通话接听时间">
</el-table-column>
<el-table-column
prop="endTime"
width="140"
:formatter='setTime'
label="通话结束时间">
</el-table-column>
<el-table-column
prop="exten"
width="70"
label="坐席工号">
</el-table-column>
<el-table-column
prop="recordFile"
label="录音文件名">
</el-table-column>
<el-table-column
prop="callNo"
width="110"
label="主叫号码">
</el-table-column>
<el-table-column
prop="calledNo"
width="100"
label="被叫号码">
</el-table-column>
<el-table-column label="编辑" align="center" width="60">
<template slot-scope="scope">
<el-button
@click.native.prevent="downRow(scope.$index, tableData)"
v-if="tableData.rows[scope.$index].state == 'dealing'"
type="text"
size="small">
下载
</el-button>
</template>
</el-table-column>
</el-table>
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page.sync="currentPage4"
:page-sizes="[10, 20, 30, 40]"
:page-size="10"
layout="total, sizes, prev, pager, next, jumper"
:total="tableData.total"
class="mt20 tr"
>
</el-pagination>
</el-card>
</el-col>
</el-row>
<!-- <HelloWorld msg="Welcome to Your Vue.js App"/> -->
</div>
</template>
<script>
import Vue from 'vue'
import { Form,FormItem,Row,Col,Button ,Loading ,Pagination,Table,TableColumn,Select,Option,Card,Input ,DatePicker} from 'element-ui';
const arr = [Form,FormItem,Row,Col,Button ,Pagination,Table,TableColumn,Select,Option,Card,Input,DatePicker]
arr.map((e)=>{ //动态生成全局组件
//Vue.use(e);
Vue.component(e.name, e)
})
Vue.use(Loading.directive);
// @ is an alias to /src
import HelloWorld from '@/components/HelloWorld.vue'
import { constants } from 'crypto';
export default {
name: 'CallList',
data() {
return {
loading:false,
selectRows:'',
tableData: {
rows:[],
total:0
},
currentPage4: 1,
date:[],
formInline: {
phone:'',
status:'',
startDate:'',
type:'',
endDate:''
},
batchArr:[]
}
},
created () {
this.getList({...this.formInline})
},
methods: {
setDate(date){
this.formInline.startDate = date[0]
this.formInline.endDate = date[1]
},
handleSizeChange(val) {
this.selectRows = val //用户控制rows
this.getList({...this.formInline}) //查询
},
handleCurrentChange(val) {
this.getList({...this.formInline ,page:val}) //用户选择页数
},
downRow(index,data){ //单个下载
let that = this
let oReq = new XMLHttpRequest();
oReq.open("GET", data.rows[index].fileServer+'/'+data.rows[index].recordFile, true);
oReq.responseType = "blob";
oReq.onload = function (oEvent) {
var content = oReq.response;
var elink = document.createElement('a');
elink.download = data.rows[index].recordFile.split('/')[3].replace('.mp3','-'+data.rows[index].cdrVar.split(':')[1]+'.mp3');
elink.style.display = 'none';
var blob = new Blob([content])
elink.href = URL.createObjectURL(blob);
document.body.appendChild(elink);
elink.click();
document.body.removeChild(elink);
};
oReq.send();
},
handleSelectionChange(val) {
this.batchArr = val
},
batch(){//批量下载
//方式一,服务器牛逼,请用这个
let that = this
this.batchArr.map((item)=>{
let oReq = new XMLHttpRequest();
oReq.open("GET", item.fileServer+'/'+item.recordFile, true);
oReq.responseType = "blob";
oReq.onload = function (oEvent) {
var content = oReq.response;
var elink = document.createElement('a');
elink.download = item.recordFile.split('/')[3].replace('.mp3','-'+item.cdrVar.split(':')[1]+'.mp3');
elink.style.display = 'none';
var blob = new Blob([content])
elink.href = URL.createObjectURL(blob);
document.body.appendChild(elink);
elink.click();
document.body.removeChild(elink);
};
oReq.send();
})
//方式二 垃圾服务器,一秒10次,请用这个,哈哈哈哈
let that = this
let num = 5 //下载个数
let time = 10000 //延迟时间
for(let n=0;n<this.batchArr.length/num;n++){
setTimeout(()=>{
this.batchArr.slice(n*num,(n+1)*num).map((item)=>{
let oReq = new XMLHttpRequest();
oReq.open("GET", item.fileServer+'/'+item.recordFile, true);
oReq.responseType = "blob";
oReq.onload = function (oEvent) {
var content = oReq.response;
var elink = document.createElement('a');
elink.download = item.recordFile.split('/')[3].replace('.mp3','-'+item.cdrVar.split(':')[1]+'.mp3');
elink.style.display = 'none';
var blob = new Blob([content])
elink.href = URL.createObjectURL(blob);
document.body.appendChild(elink);
elink.click();
document.body.removeChild(elink);
};
oReq.send();
})
},time*n)
}
},
onSubmit() {
console.log('submit!',this.formInline);
this.currentPage4 = 1
this.getList({...this.formInline}) //查询
},
getList(val={}){
let that = this
this.loading = true
let data = {
page:1,
rows:that.selectRows?that.selectRows:that.$my.rows,
...val
}
this.$axios.post(that.$my.api + 'callBack/getList', data).then(res => {
if(res.data.code === 200){
that.loading = false;
that.tableData = res.data.data
}else{
that.loading = false
that.$message({
message: res.data.message,
type: 'error',
duration: 1500
})
return false
}
}).catch(function (error) {
that.loading = false
})
},
downExcel(){
let that = this
let oReq = new XMLHttpRequest();
oReq.open("POST", that.$my.api+'callBack/exportRecordData', true);
oReq.responseType = "blob";
oReq.setRequestHeader("Content-Type","application/json");
oReq.onload = function (oEvent) {
var content = oReq.response;
var elink = document.createElement('a');
elink.download = '回推excel.xls';
elink.style.display = 'none';
var blob = new Blob([content], { type: 'application/vnd.ms-excel'})
elink.href = URL.createObjectURL(blob);
document.body.appendChild(elink);
elink.click();
document.body.removeChild(elink);
};
oReq.send(JSON.stringify({...this.formInline}));
},
//过滤
setTime(row, column, cellValue, index){
return cellValue?this.$my.timestampToTime(cellValue,'YMDHMS'):''
},
setCallType(row, column, cellValue, index){
return cellValue?this.$my.callType[cellValue]:''
},
filterCd(row, column, cellValue, index){
return cellValue?cellValue.split(':')[1]:''
},
setState(row, column, cellValue, index){
return cellValue?this.$my.state[cellValue]:''
},
},
components: {
HelloWorld
}
}
</script>
介绍:为啥给前端分页单独说,因为如果是前端分页,批量下载有bug,下面代码已经解决了
<template>
<!-- 通话记录列表 -->
<div class="CallRecordList" v-loading="loading">
<el-row :gutter="12" class="mt10">
<el-col :span="24">
<el-card shadow="always" class='ml20 mr20'>
<el-form :inline="true" :model="formInline" label-width="100px" class="demo-form-inline mt20">
<el-form-item label="被叫号码">
<el-input v-model="formInline.calledNo" size="small" clearable></el-input>
</el-form-item>
<el-form-item label="处理状态">
<el-select v-model="formInline.status" size="small" clearable>
<el-option label="已接" value="dealing"></el-option>
<el-option label="振铃未接听" value="notDeal"></el-option>
<el-option label="ivr放弃" value="leak"></el-option>
<el-option label="排队放弃" value="queueLeak"></el-option>
<el-option label="黑名单" value="blackList"></el-option>
<el-option label="留言" value="voicemail"></el-option>
</el-select>
</el-form-item>
<br/>
<el-form-item label="呼叫类型">
<el-select v-model="formInline.connectType" size="small" clearable>
<el-option label="外呼通话" value="dialout"></el-option>
<el-option label="普通来电" value="normal"></el-option>
<el-option label="呼入转接" value="transfer"></el-option>
<el-option label="外呼转接" value="dialTransfer"></el-option>
</el-select>
</el-form-item>
<el-form-item label="创建时间">
<el-date-picker
v-model="date"
@change="setDate"
size="small"
type="daterange"
value-format='yyyy-MM-dd'
range-separator="至"
start-placeholder="开始日期"
end-placeholder="结束日期">
</el-date-picker>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit" size="small">查询</el-button>
</el-form-item>
<!-- <el-form-item>
<el-button type="primary" @click="downExcel" size="small">导出</el-button>
</el-form-item> -->
<el-form-item>
<el-button type="primary" @click="batch" size="small" :disabled='batchArr.length==0?true:false'>批量下载</el-button>
</el-form-item>
</el-form>
<el-table
size='small'
:data="tableDatas"
@selection-change="handleSelectionChange"
style="width: 100%">
<el-table-column
type="selection"
width="55">
</el-table-column>
<el-table-column
prop="province"
width="60"
label="省份">
</el-table-column>
<el-table-column
prop="district"
width="60"
label="城市">
</el-table-column>
<el-table-column
prop="connect_TYPE"
width="80"
:formatter='setCallType'
label="呼叫类型">
</el-table-column>
<el-table-column
prop="status"
width="80"
:formatter='setState'
label="处理状态">
</el-table-column>
<el-table-column
prop="begin_TIME"
width="140"
label="通话接听时间">
</el-table-column>
<el-table-column
prop="end_TIME"
width="140"
label="通话结束时间">
</el-table-column>
<el-table-column
prop="exten"
width="70"
label="坐席工号">
</el-table-column>
<el-table-column
prop="record_FILE_NAME"
label="录音文件名">
</el-table-column>
<el-table-column
prop="call_NO"
width="110"
label="主叫号码">
</el-table-column>
<el-table-column
prop="called_NO"
width="100"
label="被叫号码">
</el-table-column>
<el-table-column label="编辑" align="center" width="150">
<template slot-scope="scope">
<el-button
@click.native.prevent="downRow(scope.$index, tableData)"
v-if="tableData[scope.$index].status == 'dealing'"
type="text"
size="small">
下载
</el-button>
</template>
</el-table-column>
</el-table>
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page.sync="currentPage4"
:page-sizes="[10, 20, 30, 40]"
:page-size="10"
layout="total, sizes, prev, pager, next, jumper"
:total="tableData.length"
class="mt20 tr"
>
</el-pagination>
</el-card>
</el-col>
</el-row>
<!-- <HelloWorld msg="Welcome to Your Vue.js App"/> -->
</div>
</template>
<script>
import Vue from 'vue'
import { Form,FormItem,Row,Col,Button ,Loading ,Pagination,Table,TableColumn,Select,Option,Card,Input ,DatePicker} from 'element-ui';
const arr = [Form,FormItem,Row,Col,Button ,Pagination,Table,TableColumn,Select,Option,Card,Input,DatePicker]
arr.map((e)=>{ //动态生成全局组件
//Vue.use(e);
Vue.component(e.name, e)
})
Vue.use(Loading.directive);
// @ is an alias to /src
import HelloWorld from '@/components/HelloWorld.vue'
import { constants } from 'crypto';
export default {
name: 'CallRecordList',
data() {
return {
loading:false,
selectRows:10, //行数
tableData: [],
currentPage4: 1,/页数
date:[new Date(),new Date()],
formInline: {
calledNo:'',
connectType:'',
status:'',
beginDate:'',
endDate:''
},
batchArr:[] //批量下载数据
}
},
created () {
this.formInline = {
beginDate: new Date(),
endDate: new Date()
}
},
computed: {
//重要,解决批量打印无法选中表格
tableDatas(){
return this.tableData.slice((this.currentPage4-1)*this.selectRows,this.currentPage4*this.selectRows)
}
},
mounted () {
this.getList({...this.formInline})
},
methods: {
setDate(date){ //处理日期
this.formInline.beginDate = date[0]
this.formInline.endDate = date[1]
},
handleSizeChange(val) {
this.selectRows = val //用户控制rows
},
handleCurrentChange(val) {
this.currentPage4 = val
},
onSubmit() { //查询
console.log('submit!',this.formInline);
this.currentPage4 = 1
this.getList({...this.formInline}) //查询
},
getList(val={}){
let that = this
this.loading = true
let data = {
// page:1,
// rows:that.selectRows?that.selectRows:that.$my.rows,
...val
}
this.$axios.post(that.$my.api + 'callBack/getRecordList', data).then(res => {
if(res.data.code === 200){
that.loading = false;
console.log(res.data.data)
that.tableData = res.data.data
}else{
that.loading = false
that.$message({
message: res.data.message,
type: 'error',
duration: 1500
})
return false
}
}).catch(function (error) {
that.loading = false
})
},
downExcel(){ //导出-未使用
let that = this
let oReq = new XMLHttpRequest();
oReq.open("POST", that.$my.api+'greenCard/exportGreenData', true);
oReq.responseType = "blob";
oReq.setRequestHeader("Content-Type","application/json");
oReq.onload = function (oEvent) {
var content = oReq.response;
var elink = document.createElement('a');
elink.download = '普通版excel.xls';
elink.style.display = 'none';
var blob = new Blob([content], { type: 'application/vnd.ms-excel'})
elink.href = URL.createObjectURL(blob);
document.body.appendChild(elink);
elink.click();
document.body.removeChild(elink);
};
oReq.send(JSON.stringify({...this.formInline}));
},
downRow(index,data){ //单个下载
let that = this
let oReq = new XMLHttpRequest();
oReq.open("GET", data[index].file_SERVER+'/'+data[index].record_FILE_NAME, true);
oReq.responseType = "blob";
oReq.onload = function (oEvent) {
var content = oReq.response;
var elink = document.createElement('a');
elink.download = data[index].record_FILE_NAME.split('/')[3].replace('.mp3','-'+ data[index].called_NO+'.mp3');
elink.style.display = 'none';
var blob = new Blob([content])
elink.href = URL.createObjectURL(blob);
document.body.appendChild(elink);
elink.click();
document.body.removeChild(elink);
};
oReq.send();
},
handleSelectionChange(val) { //前端分页,此处给batchArr赋值会出发两次,第二次为[],改为计算属性写分页就好了
console.log(val)
this.batchArr = val
},
batch(){//批量下载
//方式一,服务器牛逼,请用这个
let that = this
this.batchArr.map((item)=>{
let oReq = new XMLHttpRequest();
oReq.open("GET", item.file_SERVER+'/'+item.record_FILE_NAME, true);
oReq.responseType = "blob";
oReq.onload = function (oEvent) {
var content = oReq.response;
var elink = document.createElement('a');
elink.download = item.record_FILE_NAME.split('/')[3].replace('.mp3','-'+item.called_NO+'.mp3');
elink.style.display = 'none';
var blob = new Blob([content])
elink.href = URL.createObjectURL(blob);
document.body.appendChild(elink);
elink.click();
document.body.removeChild(elink);
};
oReq.send();
})
//方式二 垃圾服务器,一秒最多请求10次,请用这个,哈哈哈哈
let that = this
let num = 5 //下载个数
let time = 10000 //延迟时间
for(let n=0;n<this.batchArr.length/num;n++){
setTimeout(()=>{
this.batchArr.slice(n*num,(n+1)*num).map((item)=>{
let oReq = new XMLHttpRequest();
oReq.open("GET", item.file_SERVER+'/'+item.record_FILE_NAME, true);
oReq.responseType = "blob";
oReq.onload = function (oEvent) {
var content = oReq.response;
var elink = document.createElement('a');
elink.download = item.record_FILE_NAME.split('/')[3].replace('.mp3','-'+item.called_NO+'.mp3');
elink.style.display = 'none';
var blob = new Blob([content])
elink.href = URL.createObjectURL(blob);
document.body.appendChild(elink);
elink.click();
document.body.removeChild(elink);
};
oReq.send();
})
},time*n)
}
},
//过滤
setCallType(row, column, cellValue, index){
return cellValue?this.$my.callType[cellValue]:''
},
filterCd(row, column, cellValue, index){
return cellValue?cellValue.split(':')[1]:''
},
setState(row, column, cellValue, index){
return cellValue?this.$my.state[cellValue]:''
},
},
components: {
HelloWorld
}
}
</script>