This commit is contained in:
tx 2024-11-08 09:38:40 +08:00
parent 121f975387
commit 03aca53ea4
5 changed files with 161 additions and 78 deletions

View File

@ -50,25 +50,25 @@
<!-- {{detail.limitRefundReason | defaultValue}}--> <!-- {{detail.limitRefundReason | defaultValue}}-->
<!-- </el-descriptions-item>--> <!-- </el-descriptions-item>-->
<el-descriptions-item label="服务费"> <el-descriptions-item label="服务费">
{{ detail.platformServiceFee }}% {{ detail.platformServiceFee }}%
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="充值手续费"> <el-descriptions-item label="充值手续费">
{{ detail.handlingCharge }}% {{ detail.handlingCharge }}
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="提现手续费"> <el-descriptions-item label="提现手续费">
{{ detail.withdrawHandlingCharge }}% {{ detail.withdrawHandlingCharge }}
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="已提现"> <el-descriptions-item label="已提现">
{{ deptInfo.withdraw }} {{ deptInfo.withdraw }}
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="待结算"> <el-descriptions-item label="待结算">
{{ deptInfo.settlementAmount }} {{ deptInfo.settlementAmount }}
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="营收"> <el-descriptions-item label="营收">
{{ deptInfo.todayIncome }} | {{ deptInfo.totalIncome }} {{ deptInfo.todayIncome }} | {{ deptInfo.totalIncome }}
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="订单数"> <el-descriptions-item label="订单数">
{{ deptInfo.todayOrderCount}} | {{ deptInfo.totalOrderCount }} {{ deptInfo.todayOrderCount }} | {{ deptInfo.totalOrderCount }}
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="订单金额"> <el-descriptions-item label="订单金额">
{{ deptInfo.todayOrderFee }} | {{ deptInfo.totalOrderFee }} {{ deptInfo.todayOrderFee }} | {{ deptInfo.totalOrderFee }}
@ -83,47 +83,112 @@
</div> </div>
<el-tabs> <el-tabs>
<el-tab-pane label="车辆信息"> <el-tab-pane label="车辆信息(单位:辆)">
<el-descriptions :column="3"> <el-descriptions :column="3">
<el-descriptions-item label="车辆"> <el-descriptions-item label="总数">
{{ deptInfo.vehicleVo.offlineDevices.length}} | {{ deptInfo.vehicleVo.allNum}} <span
:style="{ color: deptInfo.vehicleVo.offlineDevices.length > 0 ? 'red' : 'gray' }">
{{ deptInfo.vehicleVo.offlineDevices.length }}
</span> |
<span >
{{ deptInfo.vehicleVo.allNum }}
</span>
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="仓库"> <el-descriptions-item label="仓库">
{{deptInfo.offlineStatusCount.inStashNum }} | {{ deptInfo.vehicleVo.inStashNum }} <span
</el-descriptions-item> :style="{ color: deptInfo.offlineStatusCount.inStashNum > 0 ? 'red' : 'gray' }">
<el-descriptions-item label=" 投放" > {{ deptInfo.offlineStatusCount.inStashNum }}
<template> </span> |
<!-- <pre></pre> --> <span
<div @click="noline">{{ deptInfo.vehicleVo.offlineDevices.length-deptInfo.offlineStatusCount.inStashNum}} | {{ deptInfo.vehicleVo.inOperation}}</div> >
</template> {{ deptInfo.vehicleVo.inStashNum }}
</span>
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="投放">
<div @click="noline">
<span
:style="{ color: (deptInfo.vehicleVo.offlineDevices.length - deptInfo.offlineStatusCount.inStashNum) > 0 ? 'red' : 'gray' }">
{{ deptInfo.vehicleVo.offlineDevices.length -
deptInfo.offlineStatusCount.inStashNum }}
</span> |
<span
>
{{ deptInfo.vehicleVo.inOperation }}
</span>
</div>
</el-descriptions-item>
<el-descriptions-item label="订单"> <el-descriptions-item label="订单">
{{ deptInfo.offlineStatusCount.ridingNum +deptInfo.offlineStatusCount.temporarilyLockNum}} | {{deptInfo.vehicleVo.ridingNum+ deptInfo.vehicleVo.temporarilyLockNum}} <span
:style="{ color: (deptInfo.offlineStatusCount.ridingNum + deptInfo.offlineStatusCount.temporarilyLockNum) > 0 ? 'red' : 'gray' }">
{{ deptInfo.offlineStatusCount.ridingNum +
deptInfo.offlineStatusCount.temporarilyLockNum }}
</span> |
<span
>
{{ deptInfo.vehicleVo.ridingNum + deptInfo.vehicleVo.temporarilyLockNum
}}
</span>
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="骑行"> <el-descriptions-item label="骑行">
{{ deptInfo.offlineStatusCount.ridingNum }} | {{ deptInfo.vehicleVo.ridingNum }} <span
:style="{ color: deptInfo.offlineStatusCount.ridingNum > 0 ? 'red' : 'gray' }">
{{ deptInfo.offlineStatusCount.ridingNum }}
</span> |
<span >
{{ deptInfo.vehicleVo.ridingNum }}
</span>
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="锁车 ">
{{ deptInfo.offlineStatusCount.temporarilyLockNum }} | {{ deptInfo.vehicleVo.temporarilyLockNum}} <el-descriptions-item label="锁车">
<span
:style="{ color: deptInfo.offlineStatusCount.temporarilyLockNum > 0 ? 'red' : 'gray' }">
{{ deptInfo.offlineStatusCount.temporarilyLockNum }}
</span> |
<span
>
{{ deptInfo.vehicleVo.temporarilyLockNum }}
</span>
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="待租"> <el-descriptions-item label="待租">
{{ deptInfo.offlineStatusCount.normalNum }} | {{ deptInfo.vehicleVo.normalNum}} <span
:style="{ color: deptInfo.offlineStatusCount.normalNum > 0 ? 'red' : 'gray' }">
{{ deptInfo.offlineStatusCount.normalNum }}
</span> |
<span >
{{ deptInfo.vehicleVo.normalNum }}
</span>
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label=" 预约">
{{ deptInfo.offlineStatusCount.inAppointmentNum }} | {{ deptInfo.vehicleVo.inAppointmentNum }} <el-descriptions-item label="预约">
<span
:style="{ color: deptInfo.offlineStatusCount.inAppointmentNum > 0 ? 'red' : 'gray' }">
{{ deptInfo.offlineStatusCount.inAppointmentNum }}
</span> |
<span
>
{{ deptInfo.vehicleVo.inAppointmentNum }}
</span>
</el-descriptions-item> </el-descriptions-item>
<el-descriptions-item label="禁用 ">
{{ deptInfo.offlineStatusCount.offlineNum }} | {{ deptInfo.vehicleVo.disabledNum}} <el-descriptions-item label="禁用">
<span
:style="{ color: deptInfo.offlineStatusCount.offlineNum > 0 ? 'red' : 'gray' }">
{{ deptInfo.offlineStatusCount.offlineNum }}
</span> |
<span
>
{{ deptInfo.vehicleVo.disabledNum }}
</span>
</el-descriptions-item> </el-descriptions-item>
</el-descriptions> </el-descriptions>
</el-tab-pane> </el-tab-pane>
</el-tabs> </el-tabs>
</div> </div>
</el-card> </el-card>
@ -153,7 +218,7 @@
<!-- <recharge :query="{deptId: detail.deptId}" :view="views.user"/> --> <!-- <recharge :query="{deptId: detail.deptId}" :view="views.user"/> -->
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="车辆列表" lazy name="车辆列表"> <el-tab-pane label="车辆列表" lazy name="车辆列表">
<device ref="deviceComponent" :deptId="detail.deptId" v-if="detail.deptId" /> <device ref="deviceComponent" :deptId="detail.deptId" v-if="detail.deptId" />
</el-tab-pane> </el-tab-pane>
<el-tab-pane label="订单" lazy> <el-tab-pane label="订单" lazy>
@ -186,7 +251,7 @@
<el-empty v-else description="用户不存在" /> <el-empty v-else description="用户不存在" />
<!--用户设置--> <!--用户设置-->
<user-config-dialog :show.sync="showConfigDialog" :deptId="detail.deptId" v-if="detail.deptId" /> <user-config-dialog :show.sync="showConfigDialog" :deptId="detail.deptId" v-if="detail.deptId" />
</div> </div>
</template> </template>
@ -246,7 +311,7 @@ export default {
return (type) => { return (type) => {
return type === '2' ? '元' : '%'; return type === '2' ? '元' : '%';
} }
} }
}, },
data() { data() {
return { return {
@ -254,7 +319,7 @@ export default {
loading: false, loading: false,
showConfigDialog: false, showConfigDialog: false,
deptInfo: {}, deptInfo: {},
defaultValue:0, defaultValue: 0,
activeTab: '运营区', // activeTab: '运营区', //
} }
}, },
@ -283,46 +348,47 @@ export default {
getDeptInfo(this.$route.params.deptId).then(response => { getDeptInfo(this.$route.params.deptId).then(response => {
this.deptInfo = response.data; this.deptInfo = response.data;
// 线 // 线
this.deptInfo.offlineStatusCount = { this.deptInfo.offlineStatusCount = {
inStashNum: 0, // inStashNum: 0, //
normalNum: 0, // normalNum: 0, //
inAppointmentNum: 0, // inAppointmentNum: 0, //
ridingNum: 0, // ridingNum: 0, //
temporarilyLockNum: 0, // temporarilyLockNum: 0, //
dispatchingNum: 0, // dispatchingNum: 0, //
offlineNum: 0 // 线 offlineNum: 0 // 线
}; };
// status // status
this.deptInfo.vehicleVo.offlineDevices.forEach(device => { this.deptInfo.vehicleVo.offlineDevices.forEach(device => {
switch (device.status) { switch (device.status) {
case 0: case '0':
this.deptInfo.offlineStatusCount.inStashNum += 1; this.deptInfo.offlineStatusCount.inStashNum += 1;
break; break;
case 1: case '1':
this.deptInfo.offlineStatusCount.normalNum += 1; this.deptInfo.offlineStatusCount.normalNum += 1;
break; break;
case 2: case '2':
this.deptInfo.offlineStatusCount.inAppointmentNum += 1; this.deptInfo.offlineStatusCount.inAppointmentNum += 1;
break; break;
case 3: case '3':
this.deptInfo.offlineStatusCount.ridingNum += 1; this.deptInfo.offlineStatusCount.ridingNum += 1;
break; break;
case 4: case '4':
this.deptInfo.offlineStatusCount.temporarilyLockNum += 1; this.deptInfo.offlineStatusCount.temporarilyLockNum += 1;
break; break;
case 6: case '6':
this.deptInfo.offlineStatusCount.dispatchingNum += 1; this.deptInfo.offlineStatusCount.dispatchingNum += 1;
break; break;
case 8: case '8':
this.deptInfo.offlineStatusCount.offlineNum += 1; this.deptInfo.offlineStatusCount.offlineNum += 1;
break; break;
} }
}); });
}).finally(() => { // console.log(this.deptInfo.vehicleVo,'this.deptInfo.offlineStatusCountthis.deptInfo.offlineStatusCount');
// }).finally(() => {
}); //
});
}, },
} }
} }

View File

@ -1449,9 +1449,9 @@ export default {
} }
); );
} }
listModel(this.queryParams).then((response) => { // listModel(this.queryParams).then((response) => {
this.modelOptions = response.rows; // this.modelOptions = response.rows;
}); // });
listArea(this.queryParams).then((response) => { listArea(this.queryParams).then((response) => {
this.areaOptions = response.rows; this.areaOptions = response.rows;
}); });
@ -1468,9 +1468,9 @@ export default {
} }
); );
} }
listModel(this.queryParams).then((response) => { // listModel(this.queryParams).then((response) => {
this.modelOptions = response.rows; // this.modelOptions = response.rows;
}); // });
listArea(this.queryParams).then((response) => { listArea(this.queryParams).then((response) => {
this.areaOptions = response.rows; this.areaOptions = response.rows;
}); });
@ -1496,6 +1496,13 @@ export default {
this.reset(); this.reset();
this.open = true; this.open = true;
this.title = "添加设备"; this.title = "添加设备";
this.$nextTick(() => {
if(this.deptId){
this.form.deptId=this.deptId
}
})
}, },
/** 详情按钮 */ /** 详情按钮 */
handleView(row) { handleView(row) {

View File

@ -583,6 +583,9 @@ export default {
this.reset(); this.reset();
this.open = true; this.open = true;
this.title = "添加收费方式"; this.title = "添加收费方式";
if(this.deptId){
this.form.deptId=this.deptId
}
}, },
handleUpdate(row) { handleUpdate(row) {
this.reset(); this.reset();

View File

@ -439,6 +439,9 @@ export default {
this.reset(); this.reset();
this.open = true; this.open = true;
this.title = "添加车辆型号"; this.title = "添加车辆型号";
if(this.deptId){
this.form.operator=this.deptId
}
}, },
/** 修改按钮操作 */ /** 修改按钮操作 */
handleUpdate(row) { handleUpdate(row) {

View File

@ -514,7 +514,11 @@ export default {
getUser().then(response => { getUser().then(response => {
this.postOptions = response.posts; this.postOptions = response.posts;
this.roleOptions = response.roles; this.roleOptions = response.roles;
this.areaOptions = response.areas; if (this.deptId) {
this.areaOptions = response.areas.filter(area => area.deptId === this.deptId);
} else {
this.areaOptions = response.areas;
}
this.open = true; this.open = true;
this.title = "添加合伙人"; this.title = "添加合伙人";
this.form.password = this.initPassword; this.form.password = this.initPassword;