|
@@ -13,38 +13,108 @@
|
|
<!--
|
|
<!--
|
|
要resetFields起作用,必须配置:model和prop
|
|
要resetFields起作用,必须配置:model和prop
|
|
-->
|
|
-->
|
|
- <el-form ref="queryForm" :model="queryModel" inline class="demo-form-inline">
|
|
|
|
- <el-form-item label="交易流水号" prop="serialNumber">
|
|
|
|
- <el-input type="text" size="mini" v-model="queryModel.serialNumber"></el-input>
|
|
|
|
- </el-form-item>
|
|
|
|
- <el-form-item>
|
|
|
|
- <el-button
|
|
|
|
- type="primary"
|
|
|
|
- size="mini"
|
|
|
|
- icon="ios-search"
|
|
|
|
- @click="changePage(1)"
|
|
|
|
- :loading="loading"
|
|
|
|
- >查询</el-button>
|
|
|
|
- <el-button
|
|
|
|
- type="info"
|
|
|
|
- size="mini"
|
|
|
|
- style="margin-left: 8px"
|
|
|
|
- @click="handleReset('queryForm')"
|
|
|
|
- >重置</el-button>
|
|
|
|
- </el-form-item>
|
|
|
|
|
|
+ <el-form ref="queryForm" :model="queryModel" inline class="demo-form-inline" label-width="100px">
|
|
|
|
+ <el-row>
|
|
|
|
+ <el-col :span="6">
|
|
|
|
+ <el-form-item label="园区" prop="areaId">
|
|
|
|
+ <el-select
|
|
|
|
+ size="mini"
|
|
|
|
+ v-model="queryModel.areaId"
|
|
|
|
+ filterable
|
|
|
|
+ placeholder="请选择"
|
|
|
|
+ @change="changeArea"
|
|
|
|
+ >
|
|
|
|
+ <el-option
|
|
|
|
+ v-for="area in queryAreaResult"
|
|
|
|
+ :key="area.id"
|
|
|
|
+ :label="area.name"
|
|
|
|
+ :value="area.id"
|
|
|
|
+ ></el-option>
|
|
|
|
+ </el-select>
|
|
|
|
+ </el-form-item>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="6">
|
|
|
|
+ <el-form-item label="楼栋" prop="buildingId">
|
|
|
|
+ <el-select
|
|
|
|
+ size="mini"
|
|
|
|
+ v-model="queryModel.buildingId"
|
|
|
|
+ filterable
|
|
|
|
+ placeholder="请选择"
|
|
|
|
+ @change="changeBuilding"
|
|
|
|
+ >
|
|
|
|
+ <el-option
|
|
|
|
+ v-for="building in queryBuildingResult"
|
|
|
|
+ :key="building.id"
|
|
|
|
+ :label="building.name"
|
|
|
|
+ :value="building.id"
|
|
|
|
+ ></el-option>
|
|
|
|
+ </el-select>
|
|
|
|
+ </el-form-item>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="6">
|
|
|
|
+ <el-form-item label="房间" prop="roomsId">
|
|
|
|
+ <el-select
|
|
|
|
+ size="mini"
|
|
|
|
+ v-model="queryModel.roomsId"
|
|
|
|
+ filterable
|
|
|
|
+ placeholder="请选择"
|
|
|
|
+ @change="changeRoom"
|
|
|
|
+ >
|
|
|
|
+ <el-option
|
|
|
|
+ v-for="rooms in queryRoomResult"
|
|
|
|
+ :key="rooms.id"
|
|
|
|
+ :label="rooms.name"
|
|
|
|
+ :value="rooms.id"
|
|
|
|
+ ></el-option>
|
|
|
|
+ </el-select>
|
|
|
|
+ </el-form-item>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="6">
|
|
|
|
+ <el-form-item>
|
|
|
|
+ <el-button
|
|
|
|
+ type="primary"
|
|
|
|
+ size="mini"
|
|
|
|
+ icon="ios-search"
|
|
|
|
+ @click="changePage(1)"
|
|
|
|
+ :loading="loading"
|
|
|
|
+ >查询</el-button>
|
|
|
|
+ <el-button
|
|
|
|
+ type="info"
|
|
|
|
+ size="mini"
|
|
|
|
+ style="margin-left: 8px"
|
|
|
|
+ @click="handleReset('queryForm')"
|
|
|
|
+ >重置</el-button>
|
|
|
|
+ </el-form-item>
|
|
|
|
+ </el-col>
|
|
|
|
+ </el-row>
|
|
|
|
+ <el-row>
|
|
|
|
+ <el-col :span="6">
|
|
|
|
+ <el-form-item label="交易流水号" prop="serialNumber">
|
|
|
|
+ <el-input type="text" size="mini" v-model="queryModel.serialNumber" style="width:190px;"></el-input>
|
|
|
|
+ </el-form-item>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="6">
|
|
|
|
+ <el-form-item label="支付类型" prop="buyType" placeholder="请选择">
|
|
|
|
+ <el-select size="mini" v-model="queryModel.buyType">
|
|
|
|
+ <el-option value="alipay" label="支付宝" />
|
|
|
|
+ <el-option value="weipay" label="微信" />
|
|
|
|
+ <el-option value="cash" label="线下支付" />
|
|
|
|
+ </el-select>
|
|
|
|
+ </el-form-item>
|
|
|
|
+ </el-col>
|
|
|
|
+ <el-col :span="6">
|
|
|
|
+ <el-form-item label="支付状态" prop="paymentStatus" placeholder="请选择">
|
|
|
|
+ <el-select size="mini" v-model="queryModel.paymentStatus">
|
|
|
|
+ <el-option value="10" label="未支付"/>
|
|
|
|
+ <el-option value="20" label="已支付" />
|
|
|
|
+ <el-option value="30" label="支付失败" />
|
|
|
|
+ </el-select>
|
|
|
|
+ </el-form-item>
|
|
|
|
+ </el-col>
|
|
|
|
+ </el-row>
|
|
</el-form>
|
|
</el-form>
|
|
<el-divider></el-divider>
|
|
<el-divider></el-divider>
|
|
- <el-row class="button-group">
|
|
|
|
- <el-button type="primary" size="small" plain icon="el-icon-circle-plus" @click="handleAdd">新增</el-button>
|
|
|
|
- <el-button
|
|
|
|
- type="primary"
|
|
|
|
- size="small"
|
|
|
|
- plain
|
|
|
|
- icon="el-icon-circle-plus"
|
|
|
|
- :disabled="multipleSelection.length==0"
|
|
|
|
- @click="handleBatchDelete"
|
|
|
|
- >删除选中项</el-button>
|
|
|
|
- </el-row>
|
|
|
|
|
|
+ <el-row class="button-group"></el-row>
|
|
<el-table
|
|
<el-table
|
|
:data="tableData"
|
|
:data="tableData"
|
|
style="min-height:400px;"
|
|
style="min-height:400px;"
|
|
@@ -63,6 +133,13 @@
|
|
<el-table-column prop="area.name" label="园区" sortable="custom" width="120"></el-table-column>
|
|
<el-table-column prop="area.name" label="园区" sortable="custom" width="120"></el-table-column>
|
|
<el-table-column prop="building.name" label="楼栋" sortable="custom" width="120"></el-table-column>
|
|
<el-table-column prop="building.name" label="楼栋" sortable="custom" width="120"></el-table-column>
|
|
<el-table-column prop="room.name" label="房间" sortable="custom" width="120"></el-table-column>
|
|
<el-table-column prop="room.name" label="房间" sortable="custom" width="120"></el-table-column>
|
|
|
|
+ <el-table-column
|
|
|
|
+ prop="dumpEnergy"
|
|
|
|
+ sort-by="dump_energy"
|
|
|
|
+ label="剩余电量"
|
|
|
|
+ sortable="custom"
|
|
|
|
+ width="120"
|
|
|
|
+ ></el-table-column>
|
|
<el-table-column
|
|
<el-table-column
|
|
prop="buyElectricity"
|
|
prop="buyElectricity"
|
|
sort-by="buy_electricity"
|
|
sort-by="buy_electricity"
|
|
@@ -77,20 +154,45 @@
|
|
sortable="custom"
|
|
sortable="custom"
|
|
width="120"
|
|
width="120"
|
|
></el-table-column>
|
|
></el-table-column>
|
|
- <el-table-column prop="buyType" sort-by="buy_type" label="支付类型" sortable="custom" width="120"></el-table-column>
|
|
|
|
|
|
+ <el-table-column prop="buyType" sort-by="buy_type" label="支付类型" sortable="custom" width="120">
|
|
|
|
+ <template slot-scope="scope">
|
|
|
|
+ <p v-if="scope.row.buyType=='alipay'">支付宝</p>
|
|
|
|
+ <p v-if="scope.row.buyType=='weipay'">微信</p>
|
|
|
|
+ <p v-if="scope.row.buyType=='cash'">线下支付</p>
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
<el-table-column
|
|
<el-table-column
|
|
prop="paymentStatus"
|
|
prop="paymentStatus"
|
|
sort-by="payment_status"
|
|
sort-by="payment_status"
|
|
label="支付状态"
|
|
label="支付状态"
|
|
sortable="custom"
|
|
sortable="custom"
|
|
width="120"
|
|
width="120"
|
|
- ></el-table-column>
|
|
|
|
|
|
+ >
|
|
|
|
+ <template slot-scope="scope">
|
|
|
|
+ <p v-if="scope.row.paymentStatus=='10'">未支付</p>
|
|
|
|
+ <p v-if="scope.row.paymentStatus=='20'">已支付</p>
|
|
|
|
+ <p v-if="scope.row.paymentStatus=='30'">支付失败</p>
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
<el-table-column
|
|
<el-table-column
|
|
prop="chargingStatus"
|
|
prop="chargingStatus"
|
|
sort-by="charging_status"
|
|
sort-by="charging_status"
|
|
label="充电状态"
|
|
label="充电状态"
|
|
sortable="custom"
|
|
sortable="custom"
|
|
width="120"
|
|
width="120"
|
|
|
|
+ >
|
|
|
|
+ <template slot-scope="scope">
|
|
|
|
+ <p v-if="scope.row.chargingStatus=='10'">未充电</p>
|
|
|
|
+ <p v-if="scope.row.chargingStatus=='20'">已充电</p>
|
|
|
|
+ <p v-if="scope.row.chargingStatus=='30'">充电失败</p>
|
|
|
|
+ </template>
|
|
|
|
+ </el-table-column>
|
|
|
|
+ <el-table-column
|
|
|
|
+ prop="createTime"
|
|
|
|
+ sort-by="create_time"
|
|
|
|
+ label="创建时间"
|
|
|
|
+ sortable="custom"
|
|
|
|
+ width="180"
|
|
></el-table-column>
|
|
></el-table-column>
|
|
<el-table-column
|
|
<el-table-column
|
|
prop="paymentTime"
|
|
prop="paymentTime"
|
|
@@ -120,6 +222,7 @@
|
|
import Constant from "@/constant";
|
|
import Constant from "@/constant";
|
|
import RechargeRecordDetail from "./rechargeRecord-detail";
|
|
import RechargeRecordDetail from "./rechargeRecord-detail";
|
|
import rechargeRecordApi from "@/api/base/rechargeRecord";
|
|
import rechargeRecordApi from "@/api/base/rechargeRecord";
|
|
|
|
+import roomInfoApi from "@/api/base/roomInfo";
|
|
import NProgress from "nprogress"; // progress bar
|
|
import NProgress from "nprogress"; // progress bar
|
|
import "nprogress/nprogress.css"; // progress bar style
|
|
import "nprogress/nprogress.css"; // progress bar style
|
|
|
|
|
|
@@ -138,7 +241,11 @@ export default {
|
|
serialNumber: "",
|
|
serialNumber: "",
|
|
buyAmount: "",
|
|
buyAmount: "",
|
|
buyElectricity: "",
|
|
buyElectricity: "",
|
|
- buyType: ""
|
|
|
|
|
|
+ buyType: "",
|
|
|
|
+ paymentStatus: "20",
|
|
|
|
+ areaId: "",
|
|
|
|
+ buildingId: "",
|
|
|
|
+ roomsId: ""
|
|
},
|
|
},
|
|
loading: false,
|
|
loading: false,
|
|
tableData: [],
|
|
tableData: [],
|
|
@@ -152,7 +259,10 @@ export default {
|
|
multipleSelection: [],
|
|
multipleSelection: [],
|
|
showModal: false,
|
|
showModal: false,
|
|
modalTitle: "",
|
|
modalTitle: "",
|
|
- businessKey: ""
|
|
|
|
|
|
+ businessKey: "",
|
|
|
|
+ queryAreaResult: [],
|
|
|
|
+ queryBuildingResult: [],
|
|
|
|
+ queryRoomResult: []
|
|
};
|
|
};
|
|
},
|
|
},
|
|
methods: {
|
|
methods: {
|
|
@@ -178,6 +288,11 @@ export default {
|
|
formData.append("buyElectricity", self.queryModel.buyElectricity);
|
|
formData.append("buyElectricity", self.queryModel.buyElectricity);
|
|
formData.append("buyType", self.queryModel.buyType);
|
|
formData.append("buyType", self.queryModel.buyType);
|
|
|
|
|
|
|
|
+ formData.append("paymentStatus", self.queryModel.paymentStatus);
|
|
|
|
+ formData.append("areaId", self.queryModel.areaId);
|
|
|
|
+ formData.append("buildingId", self.queryModel.buildingId);
|
|
|
|
+ formData.append("roomsId", self.queryModel.roomsId);
|
|
|
|
+
|
|
if (this.field != null) {
|
|
if (this.field != null) {
|
|
formData.append("field", this.field);
|
|
formData.append("field", this.field);
|
|
}
|
|
}
|
|
@@ -286,10 +401,59 @@ export default {
|
|
if (refreshed) {
|
|
if (refreshed) {
|
|
this.changePage(this.pageIndex);
|
|
this.changePage(this.pageIndex);
|
|
}
|
|
}
|
|
|
|
+ },
|
|
|
|
+ selectRoomList(keywords, roomType) {
|
|
|
|
+ var roomData = new FormData();
|
|
|
|
+ roomData.append("parentId", keywords);
|
|
|
|
+ roomData.append("type", roomType);
|
|
|
|
+ roomData.append("limit", 100);
|
|
|
|
+
|
|
|
|
+ return roomInfoApi.query(roomData).then(response => {
|
|
|
|
+ var jsonData = response.data;
|
|
|
|
+
|
|
|
|
+ if (jsonData.result) {
|
|
|
|
+ console.log(jsonData.data);
|
|
|
|
+ if (roomType == "1") {
|
|
|
|
+ this.queryAreaResult = jsonData.data;
|
|
|
|
+ } else if (roomType == "2") {
|
|
|
|
+ this.queryModel.building = "";
|
|
|
|
+ this.queryModel.room = "";
|
|
|
|
+ this.queryBuildingResult = jsonData.data;
|
|
|
|
+ } else {
|
|
|
|
+ this.queryModel.room = "";
|
|
|
|
+ this.queryRoomResult = jsonData.data;
|
|
|
|
+ }
|
|
|
|
+ } else {
|
|
|
|
+ this.$message.error(jsonData.message + "");
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+ },
|
|
|
|
+ querySelectArea() {
|
|
|
|
+ this.queryModel.area = "";
|
|
|
|
+ this.queryModel.building = "";
|
|
|
|
+ this.queryModel.rooms = "";
|
|
|
|
+ this.selectRoomList("", "1");
|
|
|
|
+ },
|
|
|
|
+ changeArea(keywords) {
|
|
|
|
+ this.queryModel.rooms = "";
|
|
|
|
+ this.queryRoomResult = "";
|
|
|
|
+ this.queryModel.building = "";
|
|
|
|
+ this.queryBuildingResult = "";
|
|
|
|
+ this.selectRoomList(keywords, "2");
|
|
|
|
+ },
|
|
|
|
+ changeBuilding(keywords) {
|
|
|
|
+ this.queryModel.rooms = "";
|
|
|
|
+ this.queryRoomResult = "";
|
|
|
|
+ this.selectRoomList(keywords, "3");
|
|
|
|
+ },
|
|
|
|
+ changeRoom(keywords) {
|
|
|
|
+ this.$forceUpdate();
|
|
}
|
|
}
|
|
},
|
|
},
|
|
mounted: function() {
|
|
mounted: function() {
|
|
|
|
+ this.querySelectArea();
|
|
this.changePage(1);
|
|
this.changePage(1);
|
|
|
|
+ this.queryModel.paymentStatus = "20";
|
|
},
|
|
},
|
|
components: {
|
|
components: {
|
|
"rechargeRecord-detail": RechargeRecordDetail
|
|
"rechargeRecord-detail": RechargeRecordDetail
|
|
@@ -309,6 +473,10 @@ export default {
|
|
.demo-form-inline {
|
|
.demo-form-inline {
|
|
margin-left: 10px;
|
|
margin-left: 10px;
|
|
text-align: left;
|
|
text-align: left;
|
|
|
|
+
|
|
|
|
+ .el-form-item{
|
|
|
|
+ margin-bottom: 0px;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
.button-group {
|
|
.button-group {
|