调整
This commit is contained in:
parent
29924c6da7
commit
f402635178
Binary file not shown.
Before Width: | Height: | Size: 5.5 KiB After Width: | Height: | Size: 17 KiB |
|
@ -78,3 +78,12 @@ export function returnVehicle(data) {
|
|||
params: data
|
||||
})
|
||||
}
|
||||
|
||||
// 押金抵扣
|
||||
export function deduction(data) {
|
||||
return request({
|
||||
url: '/appVerify/order/deduction',
|
||||
method: 'post',
|
||||
params: data
|
||||
})
|
||||
}
|
||||
|
|
|
@ -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 |
|
@ -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;
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
|
|
|
@ -18,8 +18,11 @@ export default {
|
|||
icon: {
|
||||
'blue': '',
|
||||
'red': '',
|
||||
'light_blue': '',
|
||||
'gray': '',
|
||||
'yellow': '',
|
||||
'green':'',
|
||||
'orange':'',
|
||||
'orangered':'',
|
||||
'redyellow':'',
|
||||
}
|
||||
}
|
||||
|
|
|
@ -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) {
|
||||
|
|
|
@ -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);
|
||||
|
|
|
@ -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);
|
||||
|
|
|
@ -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} 米`;
|
||||
|
|
|
@ -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);
|
||||
|
|
|
@ -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, // 申请好的Web端开发者Key,首次调用 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>
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -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() {
|
||||
|
|
Loading…
Reference in New Issue
Block a user