|
@@ -5,7 +5,7 @@
|
|
|
<el-row>
|
|
|
<el-col :span="24">
|
|
|
<div class="top">
|
|
|
- <el-select v-model="formList.companyName" placeholder="请选择公司名称">
|
|
|
+ <el-select style="width:170px" v-model="formList.companyName" placeholder="请选择公司名称">
|
|
|
<el-option
|
|
|
v-for="item in companyList"
|
|
|
:key="item.companyName"
|
|
@@ -13,22 +13,11 @@
|
|
|
:value="item.companyName">
|
|
|
</el-option>
|
|
|
</el-select>
|
|
|
- <el-input placeholder="请输入车牌号码" class="input-demo" v-model="formList.carNum"></el-input>
|
|
|
- <el-date-picker
|
|
|
- v-model="formList.startTime"
|
|
|
- type="datetime"
|
|
|
- value-format="yyyy-MM-dd HH:mm:SS"
|
|
|
- placeholder="开票时间始"
|
|
|
- style="margin-left: 1%;">
|
|
|
- </el-date-picker>
|
|
|
- <el-date-picker
|
|
|
- v-model="formList.endTime"
|
|
|
- type="datetime"
|
|
|
- value-format="yyyy-MM-dd HH:mm:SS"
|
|
|
- placeholder="开票时间止"
|
|
|
- style="margin-left: 1%;">
|
|
|
- </el-date-picker>
|
|
|
- <el-button type="success" style="margin-left: 1%;" @click="queryLook" v-loading.fullscreen.lock="fullscreenLoading">查询</el-button>
|
|
|
+ <el-input placeholder="请输入车牌号码" style="width:170px" class="input-demo" v-model="formList.carNum"></el-input>
|
|
|
+ <el-date-picker v-model="formList.invoiceMakeTime" type="daterange" value-format="yyyy-MM-dd HH:mm:SS" range-separator="至" start-placeholder="开票时间始" end-placeholder="开票时间止"></el-date-picker>
|
|
|
+ <el-button type="success" style="margin-left: 1%;" @click="firstLoadData" v-loading.fullscreen.lock="fullscreenLoading">查询</el-button>
|
|
|
+ <el-button type="success" style="margin-left: 1%;" @click="queryLook" v-loading.fullscreen.lock="fullscreenLoading">更新</el-button>
|
|
|
+ <el-button type="primary" @click="exportExcel">导出报表</el-button>
|
|
|
</div>
|
|
|
</el-col>
|
|
|
</el-row>
|
|
@@ -57,6 +46,7 @@
|
|
|
</el-table-column>
|
|
|
<el-table-column
|
|
|
label="价税合计(元)"
|
|
|
+ width="120"
|
|
|
show-overflow-tooltip>
|
|
|
<template slot-scope="scope" show-overflow-tooltip>
|
|
|
<span>{{scope.row.totalAmount / 100}}</span>
|
|
@@ -95,15 +85,18 @@
|
|
|
<el-table-column
|
|
|
prop="enStationName"
|
|
|
label="入口收费站"
|
|
|
+ width="120"
|
|
|
show-overflow-tooltip>
|
|
|
</el-table-column>
|
|
|
<el-table-column
|
|
|
prop="exStationName"
|
|
|
label="出口收费站"
|
|
|
+ width="120"
|
|
|
show-overflow-tooltip>
|
|
|
</el-table-column>
|
|
|
<el-table-column
|
|
|
label="交易金额(元)"
|
|
|
+ width="120"
|
|
|
show-overflow-tooltip>
|
|
|
<template slot-scope="scope" show-overflow-tooltip>
|
|
|
<span>{{scope.row.fee / 100}}</span>
|
|
@@ -123,11 +116,24 @@
|
|
|
</el-table-column>
|
|
|
</el-table>
|
|
|
</template>
|
|
|
-
|
|
|
+ <!-- 分页 -->
|
|
|
+ <div class="block">
|
|
|
+ <el-pagination
|
|
|
+ @size-change="handleSizeChange"
|
|
|
+ @current-change="handleCurrentChange"
|
|
|
+ :current-page="current"
|
|
|
+ :page-sizes="[6, 8, 10, 20, 50, 100]"
|
|
|
+ :page-size="pagesize"
|
|
|
+ layout="total, sizes, prev, pager, next, jumper"
|
|
|
+ :total="total">
|
|
|
+ </el-pagination>
|
|
|
+ </div>
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
|
<script>
|
|
|
+import FileSaver from "file-saver";
|
|
|
+import XLSX from "xlsx";
|
|
|
export default{
|
|
|
data() {
|
|
|
return {
|
|
@@ -142,13 +148,17 @@ export default{
|
|
|
"carNum": "",
|
|
|
"startTime": "",
|
|
|
"endTime": "",
|
|
|
+ "invoiceMakeTime":""
|
|
|
},
|
|
|
+ current: 1,
|
|
|
+ pagesize: 8,
|
|
|
+ total:'',
|
|
|
companyList:[]
|
|
|
|
|
|
}
|
|
|
},
|
|
|
created() {
|
|
|
- this.heightt = tableHeight;
|
|
|
+ this.heightt = tableHeight+20;
|
|
|
this.formList.customerName = sessionStorage.getItem('userName');
|
|
|
this.initCompanyList();
|
|
|
},
|
|
@@ -156,15 +166,39 @@ export default{
|
|
|
firstLoadData(){
|
|
|
this.current = 1;
|
|
|
this.pagesize = 8;
|
|
|
- this.queryLook();
|
|
|
+ this.loadData();
|
|
|
+ },
|
|
|
+
|
|
|
+ // 列表展示
|
|
|
+ async loadData() {
|
|
|
+ const formData = new FormData();
|
|
|
+ formData.append('current', this.current);
|
|
|
+ formData.append('size', this.pagesize);
|
|
|
+ formData.append('customerName', this.formList.customerName);
|
|
|
+ formData.append('companyName', this.formList.companyName);
|
|
|
+ formData.append('plateNum', this.formList.carNum);
|
|
|
+ formData.append('invoiceMakeTime', this.formList.invoiceMakeTime);
|
|
|
+ const response = await this.$http.post('selfCar/findSelfCarInvoices', formData);
|
|
|
+ if (response.data.code === 0) {
|
|
|
+ this.usertabletwo = response.data.data.records;
|
|
|
+ this.total = response.data.data.total;
|
|
|
+ }
|
|
|
},
|
|
|
// 查询已开发票数据
|
|
|
async queryLook() {
|
|
|
debugger;
|
|
|
+ if(this.formList.invoiceMakeTime !=null && this.formList.invoiceMakeTime !=''){
|
|
|
+
|
|
|
+ this.formList.startTime = this.formList.invoiceMakeTime[0];
|
|
|
+ this.formList.endTime = this.formList.invoiceMakeTime[1];
|
|
|
+ }
|
|
|
const response = await this.$http.post(`/selfCar/findSelfcarInvoiceByTime`, this.formList);
|
|
|
var {data: { code, msg, data }} = response;
|
|
|
if(code === 0) {
|
|
|
- this.usertabletwo = response.data.data;
|
|
|
+ this.$message({
|
|
|
+ type: 'success',
|
|
|
+ message: '更新成功'
|
|
|
+ });
|
|
|
}else{
|
|
|
this.$message.error(msg);
|
|
|
}
|
|
@@ -175,12 +209,60 @@ export default{
|
|
|
this.companyList = response.data.data;
|
|
|
}
|
|
|
this.formList.companyName = this.companyList[0]['companyName'];
|
|
|
+ this.loadData();
|
|
|
},
|
|
|
// 展示发票全部信息
|
|
|
checkLook(user) {
|
|
|
window.location.href= user;
|
|
|
},
|
|
|
-
|
|
|
+ // 分页方法
|
|
|
+ handleSizeChange(val) {
|
|
|
+ this.pagesize = val;
|
|
|
+ this.loadData();
|
|
|
+ console.log(`每页 ${val} 条`);
|
|
|
+ },
|
|
|
+ handleCurrentChange(val) {
|
|
|
+ this.current = val;
|
|
|
+ this.loadData();
|
|
|
+ // console.log(`当前页: ${val}`);
|
|
|
+ },
|
|
|
+ async exportExcel() {
|
|
|
+ let curr = this.current;
|
|
|
+ let pagesize1 = this.pagesize;
|
|
|
+ this.current = 1;
|
|
|
+ this.pagesize = this.total;
|
|
|
+ await this.loadData();
|
|
|
+ // 设置当前日期
|
|
|
+ let time = new Date();
|
|
|
+ //console.log(time);
|
|
|
+ let year = time.getFullYear();
|
|
|
+ let month = time.getMonth() + 1;
|
|
|
+ let day = time.getDate();
|
|
|
+ let name = "自有车发票查询列表_"+year + "" + month + "" + day;
|
|
|
+ // console.log(name)
|
|
|
+ /* generate workbook object from table */
|
|
|
+ // .table要导出的是哪一个表格
|
|
|
+ var wb = XLSX.utils.table_to_book(document.querySelector(".table"),{ raw: true });
|
|
|
+ /* get binary string as output */
|
|
|
+ var wbout = XLSX.write(wb, {
|
|
|
+ bookType: "xlsx",
|
|
|
+ bookSST: true,
|
|
|
+ type: "array"
|
|
|
+ });
|
|
|
+ try {
|
|
|
+ // name+'.xlsx'表示导出的excel表格名字
|
|
|
+ FileSaver.saveAs(
|
|
|
+ new Blob([wbout], { type: "application/octet-stream" }),
|
|
|
+ name + ".xlsx"
|
|
|
+ );
|
|
|
+ } catch (e) {
|
|
|
+ if (typeof console !== "undefined") console.log(e, wbout);
|
|
|
+ }
|
|
|
+ this.current = curr;
|
|
|
+ this.pagesize = pagesize1;
|
|
|
+ this.loadData();
|
|
|
+ return wbout;
|
|
|
+ },
|
|
|
}
|
|
|
};
|
|
|
</script>
|
|
@@ -205,5 +287,57 @@ export default{
|
|
|
width: 20%;
|
|
|
margin-left: 1%;
|
|
|
}
|
|
|
-
|
|
|
+.already {
|
|
|
+ border: 1px solid #d9d9d9;
|
|
|
+ border-radius: 10px;
|
|
|
+}
|
|
|
+.already .title {
|
|
|
+ font-size: 5px;
|
|
|
+ margin-bottom: 20px;
|
|
|
+}
|
|
|
+.already .top {
|
|
|
+ padding-top: 20px;
|
|
|
+ padding-left: 20px;
|
|
|
+}
|
|
|
+.already .text {
|
|
|
+ display: inline-block;
|
|
|
+ color: #000;
|
|
|
+ font-size: 16px ;
|
|
|
+ margin-left: 1%;
|
|
|
+}
|
|
|
+.already .input-demo {
|
|
|
+ display: inline-block;
|
|
|
+ width: 20%;
|
|
|
+ margin-left: 1%;
|
|
|
+}
|
|
|
+.already .block {
|
|
|
+ font-size: 5px;
|
|
|
+ text-align: center;
|
|
|
+ margin-top: 25px;
|
|
|
+ margin-bottom: 25px;
|
|
|
+}
|
|
|
+.already .el-dialog {
|
|
|
+ width: 60%;
|
|
|
+}
|
|
|
+.already .el-dialog__header, .el-dialog__body {
|
|
|
+ padding: 0 20px;
|
|
|
+}
|
|
|
+.already .tou {
|
|
|
+ font-size: 20px;
|
|
|
+ height: 30px;
|
|
|
+ line-height: 30px;
|
|
|
+ padding-top: 15px;
|
|
|
+}
|
|
|
+.already .line {
|
|
|
+ margin-top: 15px;
|
|
|
+ margin-bottom: 15px;
|
|
|
+ width: 100%;
|
|
|
+ height: 2px;
|
|
|
+ background-color: #d9d9d9;
|
|
|
+}
|
|
|
+.already .xinxi {
|
|
|
+ text-align: center;
|
|
|
+ margin: 15px auto;
|
|
|
+ font-size: 18px;
|
|
|
+}
|
|
|
</style>
|