This commit is contained in:
邱贞招 2024-07-03 21:18:55 +08:00
parent 29924c6da7
commit f402635178
14 changed files with 510 additions and 135 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.5 KiB

After

Width:  |  Height:  |  Size: 17 KiB

View File

@ -78,3 +78,12 @@ export function returnVehicle(data) {
params: data
})
}
// 押金抵扣
export function deduction(data) {
return request({
url: '/appVerify/order/deduction',
method: 'post',
params: data
})
}

View File

@ -42,3 +42,17 @@ export function delParking(parkingId) {
method: 'delete'
})
}
// 停车区状态修改
export function changeParkingStatus(parkingId, status) {
const data = {
parkingId,
status
}
return request({
url: '/system/parking/changeParkingStatus',
method: 'put',
data: data
})
}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.5 KiB

After

Width:  |  Height:  |  Size: 6.2 KiB

View File

@ -175,23 +175,30 @@ export default {
this.map.add(text);
},
formarStatus(status,onlineStatus){
if(onlineStatus == "0"){
return globalConfig.icon.red;
}else{
if(status == "0"){
return globalConfig.icon.gray;
}else if(status == "1"){
return globalConfig.icon.blue;
}else if(status == "2"){
return globalConfig.icon.yellow;
}else if(status == "3"){
return globalConfig.icon.yellow;
}else if(status == "4"){
return globalConfig.icon.light_blue;
}else if(status == "8"){
return globalConfig.icon.gray;
}else if(status == "9"){
return globalConfig.icon.gray;
function formarStatus(status,onlineStatus) {
if(onlineStatus == "0"){
if(status == "3"){
return globalConfig.icon.redyellow;
}else if(status == "4"){
return globalConfig.icon.orangered;
}
return globalConfig.icon.red;
}else{
if(status == "0"){
return globalConfig.icon.gray;
}else if(status == "1"){
return globalConfig.icon.blue;
}else if(status == "2"){
return globalConfig.icon.green;
}else if(status == "3"){
return globalConfig.icon.yellow;
}else if(status == "4"){
return globalConfig.icon.orange;
}else if(status == "8"){
return globalConfig.icon.gray;
}else if(status == "9"){
return globalConfig.icon.gray;
}
}
}
},

View File

@ -18,8 +18,11 @@ export default {
icon: {
'blue': '',
'red': '',
'light_blue': '',
'gray': '',
'yellow': '',
'green':'',
'orange':'',
'orangered':'',
'redyellow':'',
}
}

View File

@ -178,12 +178,57 @@
</el-select>
</el-form-item>
</el-col>
<!-- <el-col :span="12">-->
<!-- <el-form-item label="客服电话" prop="phone">-->
<!-- <el-input v-model="form.servicePhone" placeholder="请输入客服电话" />-->
<!-- </el-form-item>-->
<!-- </el-col>-->
</el-row>
<el-row>
<el-col :span="12">
<el-form-item label="客服电话" prop="phone">
<el-input v-model="form.servicePhone" placeholder="请输入客服电话" />
<el-form-item label="自定义客服" prop="customService" label-width="100px">
<el-switch v-model="form.customService" class="drawer-switch" />
</el-form-item>
</el-col>
</el-row>
<div v-if="form.customService == '1'">
<el-row>
<el-col :span="8">
<el-form-item label="自定义客服名称1" prop="serviceName1" label-width="180px">
<el-input v-model="form.serviceName1" placeholder="请输入自定义客服名称" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="电话" prop="servicePhone1" >
<el-input v-model="form.servicePhone1" placeholder="请输入客服电话" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="自定义客服名称2" prop="serviceName2" label-width="180px">
<el-input v-model="form.serviceName2" placeholder="请输入自定义客服名称" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="电话" prop="servicePhone2" >
<el-input v-model="form.servicePhone2" placeholder="请输入客服电话" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="8">
<el-form-item label="自定义客服名称3" prop="serviceName3" label-width="180px">
<el-input v-model="form.serviceName3" placeholder="请输入自定义客服名称" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="电话" prop="servicePhone3" >
<el-input v-model="form.servicePhone3" placeholder="请输入客服电话" />
</el-form-item>
</el-col>
</el-row>
</div>
<el-row v-if="form.areaTime == 2">
<el-col :span="12">
<el-form-item label="自定义">
@ -392,6 +437,7 @@ export default {
total: 0,
//
dateRange: [],
customService: false,
//
ruleOptions: [],
provinceList: [],
@ -602,13 +648,14 @@ export default {
getArea(areaId).then(response => {
this.form = response.data;
this.form.ruleIds = response.ruleIds
response.data.customService == "1" ? this.form.customService = true : this.form.customService = false
this.open = true;
this.title = "修改运营区";
this.key++;
listFee().then(response => {
this.ruleOptions = response.rows;
this.open = true;
this.title = "添加运营区";
this.title = "修改运营区";
this.key++;
});
// this.getCityList()
@ -635,7 +682,12 @@ export default {
// rest data
let data = { ...rest };
console.log("this.form=================",data)
if (data.customService) {
data.customService = "1";
}else{
data.customService = "0";
}
// console.log(data, 'data without cityList, countyList, provinceList');
// console.log(this.form,'formformformformform');
if (this.form.areaId != null) {

View File

@ -90,6 +90,16 @@
<dict-tag :options="dict.type.et_parking_type" :value="scope.row.type"/>
</template>
</el-table-column>
<el-table-column label="状态" align="center" key="status" >
<template slot-scope="scope">
<el-switch
v-model="scope.row.status"
active-value="0"
inactive-value="1"
@change="handleStatusChange(scope.row)"
></el-switch>
</template>
</el-table-column>
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.createTime, '{y}-{m}-{d}') }}</span>
@ -177,7 +187,14 @@
</template>
<script>
import { listParking, getParking, delParking, addParking, updateParking } from "@/api/system/parking";
import {
listParking,
getParking,
delParking,
addParking,
updateParking,
changeParkingStatus
} from '@/api/system/parking'
import {getArea, optionselect as getAreaOptionselect} from "@/api/system/area";
@ -244,6 +261,17 @@ export default {
this.getAreaList();
},
methods: {
//
handleStatusChange(row) {
let text = row.status === "0" ? "启用" : "停用";
this.$modal.confirm('确认要"' + text + '""' + row.parkingName + '"吗?').then(function() {
return changeParkingStatus(row.parkingId, row.status);
}).then(() => {
this.$modal.msgSuccess(text + "成功");
}).catch(function() {
row.status = row.status === "0" ? "1" : "0";
});
},
mapList(data){
let mapListJson = JSON.stringify(data);
console.log("mapListJson:"+mapListJson);

View File

@ -90,6 +90,16 @@
<dict-tag :options="dict.type.et_parking_type" :value="scope.row.type"/>
</template>
</el-table-column>
<el-table-column label="状态" align="center" key="status" >
<template slot-scope="scope">
<el-switch
v-model="scope.row.status"
active-value="0"
inactive-value="1"
@change="handleStatusChange(scope.row)"
></el-switch>
</template>
</el-table-column>
<!-- <el-table-column label="照片" align="center" prop="picture" width="100">-->
<!-- <template slot-scope="scope">-->
<!-- <image-preview :src="scope.row.picture" :width="50" :height="50"/>-->
@ -188,7 +198,14 @@
</template>
<script>
import { listParking, getParking, delParking, addParking, updateParking } from "@/api/system/parking";
import {
listParking,
getParking,
delParking,
addParking,
updateParking,
changeParkingStatus
} from '@/api/system/parking'
import {getArea, optionselect as getAreaOptionselect} from "@/api/system/area";
@ -255,6 +272,17 @@ export default {
this.getAreaList();
},
methods: {
//
handleStatusChange(row) {
let text = row.status === "0" ? "启用" : "停用";
this.$modal.confirm('确认要"' + text + '""' + row.parkingName + '"吗?').then(function() {
return changeParkingStatus(row.parkingId, row.status);
}).then(() => {
this.$modal.msgSuccess(text + "成功");
}).catch(function() {
row.status = row.status === "0" ? "1" : "0";
});
},
mapList(data){
let mapListJson = JSON.stringify(data);
console.log("mapListJson:"+mapListJson);

View File

@ -96,6 +96,16 @@
<image-preview :src="scope.row.picture" :width="50" :height="50"/>
</template>
</el-table-column>
<el-table-column label="状态" align="center" key="status" >
<template slot-scope="scope">
<el-switch
v-model="scope.row.status"
active-value="0"
inactive-value="1"
@change="handleStatusChange(scope.row)"
></el-switch>
</template>
</el-table-column>
<!-- <el-table-column label="区域" align="center" prop="areaId" />-->
<el-table-column label="创建时间" align="center" prop="createTime" width="180">
<template slot-scope="scope">
@ -193,7 +203,7 @@
</template>
<script>
import { listParking, getParking, delParking, addParking, updateParking } from "@/api/system/parking";
import { listParking, getParking, delParking, addParking, updateParking, changeParkingStatus } from "@/api/system/parking";
import {getArea, optionselect as getAreaOptionselect} from "@/api/system/area";
@ -263,6 +273,17 @@ export default {
this.getAreaList();
},
methods: {
//
handleStatusChange(row) {
let text = row.status === "0" ? "启用" : "停用";
this.$modal.confirm('确认要"' + text + '""' + row.parkingName + '"吗?').then(function() {
return changeParkingStatus(row.parkingId, row.status);
}).then(() => {
this.$modal.msgSuccess(text + "成功");
}).catch(function() {
row.status = row.status === "0" ? "1" : "0";
});
},
formatDistance(row) {
if (typeof row.error === 'number') {
return `${row.error}`;

View File

@ -27,6 +27,14 @@
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="车牌号" prop="vehicleNum">
<el-input style="width: 150px"
v-model="queryParams.vehicleNum"
placeholder="请输入车牌号"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="在线状态" prop="onlineStatus">
<el-select v-model="queryParams.onlineStatus" placeholder="请选择在线状态" clearable>
<el-option
@ -141,6 +149,7 @@
<el-table-column label="运营区" align="center" prop="areaName" />
<el-table-column label="定位" align="center" prop="location" :show-overflow-tooltip="true"/>
<el-table-column label="电压(V)" align="center" prop="voltage" />
<el-table-column label="信号强度" align="center" prop="signalStrength" />
<el-table-column label="版本" align="center" prop="version" />
<el-table-column label="剩余电量(%)" align="center" prop="remainingPower" />
<el-table-column label="车辆状态" align="center" prop="status">
@ -198,7 +207,7 @@
icon="el-icon-edit"
@click="handleListing(scope.row)"
v-hasPermi="['system:fault:edit']"
>{{ scope.row.status === '0' ? '上架' : '下架' }}</el-button>
>{{ scope.row.status === '0' ? '上线' : '下线' }}</el-button>
<el-button v-if="scope.row.status!= '3'"
size="mini"
type="text"
@ -658,7 +667,7 @@ export default {
let text = form1.status === '0'? '上线': '下线';
form1.status = form1.status === '0'? '1': '0';
if(form1.areaId == null){
this.$modal.msgError("未绑定运营区,无法上")
this.$modal.msgError("未绑定运营区,无法上线")
}else{
this.$modal.confirm('是否确认'+text+'设备MAC为"' + form1.mac + '"的设备吗?').then(function() {
return updateDevice(form1);

View File

@ -1,10 +1,44 @@
<template>
<div class="container">
<div id="container"></div>
<div class="tips">
<div class="tip-item">
<img :src="icons.blue" alt="蓝色">
<span class="span-class">待骑行</span>
</div>
<div class="tip-item">
<img :src="icons.green" alt="绿色">
<span class="span-class">预约中</span>
</div>
<div class="tip-item">
<img :src="icons.yellow" alt="黄色">
<span class="span-class">骑行中</span>
</div>
<div class="tip-item">
<img :src="icons.orange" alt="橙色">
<span class="span-class">临时停车</span>
</div>
<div class="tip-item">
<img :src="icons.red" alt="红色">
<span class="span-class">离线中</span>
</div>
<div class="tip-item">
<img :src="icons.redyellow" alt="红黄">
<span class="span-class">离线骑行</span>
</div>
<div class="tip-item">
<img :src="icons.orangered" alt="橙红">
<span class="span-class">离线临时锁车</span>
</div>
<div class="tip-item">
<img :src="icons.gray" alt="灰色">
<span class="span-class">未上架/下线</span>
</div>
</div>
<div class="input-card">
<!-- <div >{{tips}}</div>-->
<el-button @click="setFitView()">全局查看</el-button>
<el-button @click="changeMapStyle()">切换地图</el-button>
<el-button @click="showMarkers">显示/隐藏文字</el-button>
</div>
</div>
@ -16,7 +50,32 @@
import {listArea} from "@/api/system/area";
import { listParking } from '@/api/system/parking'
function formarStatus(status,onlineStatus) {
if(onlineStatus == "0"){
if(status == "3"){
return globalConfig.icon.redyellow;
}else if(status == "4"){
return globalConfig.icon.orangered;
}
return globalConfig.icon.red;
}else{
if(status == "0"){
return globalConfig.icon.gray;
}else if(status == "1"){
return globalConfig.icon.blue;
}else if(status == "2"){
return globalConfig.icon.green;
}else if(status == "3"){
return globalConfig.icon.yellow;
}else if(status == "4"){
return globalConfig.icon.orange;
}else if(status == "8"){
return globalConfig.icon.gray;
}else if(status == "9"){
return globalConfig.icon.gray;
}
}
}
export default {
name: "map-view",
data() {
@ -24,12 +83,18 @@
AMap: null,
map: null, //
markers: [],
labels: [],
tips: null,
//
areaList: [],
lon: null,
lat: null,
area:null,
icons: globalConfig.icon,
cluster: null,
data: [],
show: false,
//
deviceList: [],
parkingList: [],
@ -45,6 +110,28 @@
this.map?.destroy();
},
methods: {
showMarkers() {
if(this.show){
// this.markers.forEach(marker => {
// marker.show();
// });
this.labels.forEach(label => {
label.show();
});
}else{
// this.markers.forEach(marker => {
// marker.hide();
// });
this.labels.forEach(label => {
label.hide();
});
}
this.show = !this.show;
const elements = document.querySelectorAll('.apiary-marker-name');
elements.forEach(element => {
element.style.visibility = this.show ? 'hidden' : 'visible';
});
},
async getAreaList(){
listArea().then(response => {
this.areaList = response.rows;
@ -105,7 +192,6 @@
AMapLoader.load({
key: globalConfig.aMap.key, // WebKey load
version: "2.0", // JSAPI 1.4.15
plugins: ['AMap.Scale'], // 使'AMap.Scale'
}).then((AMap) => {
this.map = new AMap.Map("container", {
// id
@ -134,44 +220,135 @@
this.addNoriding(JSON.parse(noriding.boundaryStr) || [],noriding.parkingName,noriding.longitude,noriding.latitude);
this.addMarker2(noriding,"https://lxnapi.ccttiot.com/FmX1diEPPbFYe1vcUfKp6qbKzzh2",noriding.parkingName,"#ffcc00");
});
setTimeout(() => {
this.setFitView();
}, 1000);
// setTimeout(() => {
// this.setFitView();
// }, 2000);
}).catch((e) => {
console.log(e);
});
},
//
freshMarker(points) {
let that = this;
//
if (this.cluster != null) {
this.cluster.setData(points);
}else {
this.map.plugin(["AMap.MarkerCluster"], () => {
that.cluster = new AMap.MarkerCluster(
this.map, //
points, // lnglat
{
styles: this.getStyles(),
renderMarker: this.getRenderMarker, //
}
);
that.cluster.on('click', that.onClickCluster)
});
}
},
//
onClickCluster(e) {
this.ids = e.clusterData.map(item => item.apiaryId);
if (this.ids.length > 100) {
this.$message.warning("仅能查看最多100条数据");
return;
}
// > 1
if (this.ids.length > 1) {
this.showDialog = true;
}
},
//
getRenderMarker(context) {
let device = context.data[0];
let content = `
<div class="apiary-marker">
<div style="visibility: ${this.show ? 'hidden' : 'visible'};" class="apiary-marker-name">${device.sn}</div>
<image class="apiary-marker-img" src='${formarStatus(device.status,device.onlineStatus)}'/>
</div>
`
context.marker.setContent(content);
context.marker.on("click", this.onClickMarker(device.sn))
},
//
onClickMarker(e) {
console.log("点击非聚合点====",e)
},
getStyles() {
return [
{
//1-10
url: "//a.amap.com/jsapi_demos/static/images/blue.png", //
size: new AMap.Size(32, 32), //
offset: new AMap.Pixel(-16, -16), //
textColor: "#fff", //
},
{
//11-100
url: "//a.amap.com/jsapi_demos/static/images/green.png",
size: new AMap.Size(32, 32),
offset: new AMap.Pixel(-16, -16),
textColor: "#fff",
},
{
//101-1000
url: "//a.amap.com/jsapi_demos/static/images/orange.png",
size: new AMap.Size(36, 36),
offset: new AMap.Pixel(-18, -18),
textColor: "#fff"
},
{
//1001-10000
url: "//a.amap.com/jsapi_demos/static/images/red.png",
size: new AMap.Size(48, 48),
offset: new AMap.Pixel(-24, -24),
textColor: "#fff"
},
{
//10001-100000
url: "//a.amap.com/jsapi_demos/static/images/red.png",
size: new AMap.Size(48, 48),
offset: new AMap.Pixel(-24, -24),
textColor: "#fff"
},
]
},
addMarker2(parking, icon,title,color) {
let marker = new AMap.Marker({
map: this.map,
icon: new AMap.Icon({
image: icon,
size: new AMap.Size(38, 55), //
imageSize: new AMap.Size(38, 55) //
size: new AMap.Size(25, 36), //
imageSize: new AMap.Size(25, 36) //
}),
position: [parking.longitude, parking.latitude],
offset: new AMap.Pixel(-20, -50)
offset: new AMap.Pixel(-12.5, -36)
});
this.markers.push(marker);
console.log("title============="+title)
// Text
let text = new AMap.Text({
text: title,
anchor: 'center', //
position: [parking.longitude, parking.latitude],
offset: new AMap.Pixel(0, -70),
offset: new AMap.Pixel(0, -50),
style: {
'background-color': color, //
'border': 'none', //
'border-radius': '5px', // 5px
'color': 'white', //
'font-size': '14px', //
'padding': '5px 10px' //
'font-size': '12px', //
}
});
//
this.map.add(text);
console.log("text=============",text)
this.labels.push(text)
},
deviceMarker(){
listDevice({pageNum: 1,pageSize: 999}).then(response => {
@ -180,63 +357,27 @@
//
if (device.longitude !== null && device.latitude !== null &&
!isNaN(device.longitude) && !isNaN(device.latitude)) {
this.addMarker(device.longitude, device.latitude, device.status, device.onlineStatus,device.sn);
this.data.push({
lnglat: [device.longitude, device.latitude],
status: device.status,
onlineStatus: device.onlineStatus,
sn: device.sn
});
// this.addMarker(device.longitude, device.latitude, device.status, device.onlineStatus,device.sn);
} else {
console.warn(`无效的经纬度值: 经度=${device.longitude}, 纬度=${device.latitude}`);
}
});
//
this.freshMarker(this.data);
}).catch(error => {
console.error('获取设备列表失败:', error);
});
},
addMarker(lng, lat, status, onlineStatus,title) {
function formarStatus(status,onlineStatus) {
if(onlineStatus == "0"){
return globalConfig.icon.red;
}else{
if(status == "0"){
return globalConfig.icon.gray;
}else if(status == "1"){
return globalConfig.icon.blue;
}else if(status == "2"){
return globalConfig.icon.yellow;
}else if(status == "3"){
return globalConfig.icon.yellow;
}else if(status == "4"){
return globalConfig.icon.light_blue;
}else if(status == "8"){
return globalConfig.icon.gray;
}else if(status == "9"){
return globalConfig.icon.gray;
}
}
}
let marker = new AMap.Marker({
map: this.map,
icon: formarStatus(status,onlineStatus),
position: [lng, lat],
offset: new AMap.Pixel(-20, -40)
});
// Text
let text = new AMap.Text({
text: title,
anchor: 'center', //
position: [lng, lat],
offset: new AMap.Pixel(0, -55),
style: {
'background-color': '#1890ff', //
'border': 'none', //
'border-radius': '5px', // 5px
'color': 'white', //
'font-size': '14px', //
'padding': '5px 10px' //
}
});
//
this.map.add(text);
},
//
@ -289,21 +430,6 @@
});
});
this.map.add(polygon);
//
// let text = new AMap.Text({
// text: title,
// anchor: 'center', //
// style: {
// 'background-color': 'transparent', //
// 'border': 'none', //
// 'color': '#ff0000', //
// 'font-size': '14px'
// },
// position: [lon,lat] //
// });
//
// this.map.add(text);
},
addNoParking(data) {
let polygon = new AMap.Polygon({
@ -354,21 +480,6 @@
});
});
this.map.add(polygon);
//
// let text = new AMap.Text({
// text: title,
// anchor: 'center', //
// style: {
// 'background-color': 'transparent', //
// 'border': 'none', //
// 'color': '#ff0000', //
// 'font-size': '14px'
// },
// position: [lon,lat] //
// });
//
// this.map.add(text);
}
},
};
@ -388,4 +499,51 @@
right: 15px;
}
}
.tips{
display: flex;
flex-direction: column;
position: absolute;
top: 15px;
left: 15px;
.tip-item {
display: flex;
align-items: center; /* 垂直居中 */
margin-bottom: 10px; /* 可以根据需要调整间距 */
color: #38383b;
.span-class{
background-color: rgba(255, 255, 255, 0.5);
padding: 3px 5px;
border-radius: 5px;
font-weight: 600;
font-size: 13px;
}
}
img{
width: 25px;
padding-top: 5px;
height: auto; /* 保持图片高度自适应 */
margin-right: 10px; /* 图片与文字间距,根据需要调整 */
}
}
</style>
<style lang="scss">
.apiary-marker{
position: relative;
top: -19px;
left: -19px;
display: flex;
flex-direction: column;
align-items: center;
.apiary-marker-img{
width: 25px;
}
.apiary-marker-name{
background-color: #1890ff;
border: none;
border-radius: 5px;
color: white;
font-size: 12px;
padding: 5px;
}
}
</style>

View File

@ -70,7 +70,7 @@
<!-- <el-table-column label="订单id" align="center" prop="orderId" />-->
<el-table-column label="区域" align="center" prop="area" />
<el-table-column label="订单号" align="center" prop="orderNo" width="200"/>
<el-table-column label="用户" align="center" prop="userName" />
<el-table-column label="用户" align="center" prop="userName" width="100"/>
<el-table-column label="设备SN" align="center" prop="sn" />
<el-table-column label="车牌号" align="center" prop="vehicleNum" />
<el-table-column label="状态" align="center" prop="status">
@ -78,27 +78,27 @@
<dict-tag :options="dict.type.et_order_status" :value="scope.row.status"/>
</template>
</el-table-column>
<el-table-column label="支付时间" align="center" prop="payTime" width="140">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.payTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span>
</template>
</el-table-column>
<el-table-column label="开始骑行时间" align="center" prop="unlockTime" width="140">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.unlockTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span>
</template>
</el-table-column>
<el-table-column label="结束骑行时间" align="center" prop="returnTime" width="140">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.returnTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span>
</template>
</el-table-column>
<el-table-column label="创建时间" align="center" prop="createTime" width="140">
<el-table-column label="创建时间" align="center" prop="createTime" width="90">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.createTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span>
</template>
</el-table-column>
<el-table-column label="支付方式" align="center" prop="payType">
<el-table-column label="开始骑行" align="center" prop="unlockTime" width="90">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.unlockTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span>
</template>
</el-table-column>
<el-table-column label="结束骑行" align="center" prop="returnTime" width="90">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.returnTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span>
</template>
</el-table-column>
<el-table-column label="支付时间" align="center" prop="payTime" width="90">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.payTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span>
</template>
</el-table-column>
<el-table-column label="支付方式" align="center" prop="payType" width="80">
<template slot-scope="scope">
<dict-tag :options="dict.type.et_pay_type" :value="scope.row.payType"/>
</template>
@ -108,10 +108,10 @@
<dict-tag :options="dict.type.et_order_type" :value="scope.row.type"/>
</template>
</el-table-column>
<el-table-column label="金额(元)" align="center" prop="totalFee" />
<el-table-column label="金额(元)" align="center" prop="totalFee" width="70"/>
<el-table-column label="备注" align="center" prop="mark" />
<el-table-column label="订单时长" align="center" prop="duration" :formatter="formatDuration"/>
<el-table-column label="距离(公里)" align="center" prop="distance" :formatter="formatDistance"/>
<el-table-column label="距离" align="center" prop="distance" :formatter="formatDistance"/>
<el-table-column label="操作" align="center" width="150" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
@ -129,6 +129,14 @@
@click="changePrice(scope.row)"
v-hasPermi="['system:order:edit']"
>改价</el-button>
<el-button
size="mini"
type="text"
v-if="scope.row.status == 1 || scope.row.status == 3"
icon="el-icon-edit"
@click="deduction(scope.row)"
v-hasPermi="['system:order:edit']"
>押金抵扣</el-button>
<el-button
size="mini"
type="text"
@ -308,7 +316,17 @@
</template>
<script>
import { listOrder, getOrder, delOrder, addOrder, updateOrder, changePrice, refund,returnVehicle } from '@/api/system/order'
import {
listOrder,
getOrder,
delOrder,
addOrder,
updateOrder,
changePrice,
refund,
returnVehicle,
deduction
} from '@/api/system/order'
import TrajectoryMap from '@/components/Map/TrajectoryMap'
import { optionselect as getAreaOptionselect } from '@/api/system/area'
@ -443,6 +461,16 @@ export default {
this.title2 = "改价";
});
},
//
deduction(row){
this.$modal.confirm('是否确认用押金抵扣?').then(function() {
return deduction({orderNo:row.orderNo});
}).then(() => {
this.getList();
this.$modal.msgSuccess("操作成功");
}).catch(() => {
});
},
refund(row){
// console.log('changePrice')
const orderId = row.orderId || this.ids

View File

@ -261,6 +261,18 @@
</el-radio-group>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="运营区" prop="areaId" >
<el-select v-model="form.areaId" clearable placeholder="请选择运营区">
<el-option
v-for="item in areaOptions"
:key="item.areaId"
:label="item.areaName"
:value="item.areaId"
></el-option>
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
@ -313,6 +325,7 @@ import { listUser, getUser, delUser, addUser, updateUser, resetUserPwd, changeUs
import { getToken } from "@/utils/auth";
import Treeselect from "@riophae/vue-treeselect";
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
import { listArea } from '@/api/system/area'
export default {
name: "User",
@ -334,6 +347,8 @@ export default {
single: true,
//
multiple: true,
//
areaOptions: [],
//
showSearch: true,
//
@ -447,6 +462,9 @@ export default {
this.loading = false;
}
);
listArea(this.queryParams).then(response => {
this.areaOptions = response.rows;
});
},
/** 查询运营商下拉树结构 */
getDeptTree() {