diff --git a/src/views/system/dept/deptDetail.vue b/src/views/system/dept/deptDetail.vue index 2dfdc04..1a7a074 100644 --- a/src/views/system/dept/deptDetail.vue +++ b/src/views/system/dept/deptDetail.vue @@ -50,25 +50,25 @@ <!-- {{detail.limitRefundReason | defaultValue}}--> <!-- </el-descriptions-item>--> <el-descriptions-item label="服务费"> - {{ detail.platformServiceFee }}% + {{ detail.platformServiceFee }}% </el-descriptions-item> <el-descriptions-item label="充值手续费"> - {{ detail.handlingCharge }}% + {{ detail.handlingCharge }}‰ </el-descriptions-item> <el-descriptions-item label="提现手续费"> - {{ detail.withdrawHandlingCharge }}% + {{ detail.withdrawHandlingCharge }}‰ </el-descriptions-item> <el-descriptions-item label="已提现"> - {{ deptInfo.withdraw }}元 + {{ deptInfo.withdraw }}元 </el-descriptions-item> <el-descriptions-item label="待结算"> {{ deptInfo.settlementAmount }} </el-descriptions-item> <el-descriptions-item label="营收"> - {{ deptInfo.todayIncome }}元 | {{ deptInfo.totalIncome }}元 + {{ deptInfo.todayIncome }}元 | {{ deptInfo.totalIncome }}元 </el-descriptions-item> <el-descriptions-item label="订单数"> - {{ deptInfo.todayOrderCount}}元 | {{ deptInfo.totalOrderCount }}元 + {{ deptInfo.todayOrderCount }}笔 | {{ deptInfo.totalOrderCount }}笔 </el-descriptions-item> <el-descriptions-item label="订单金额"> {{ deptInfo.todayOrderFee }}元 | {{ deptInfo.totalOrderFee }}元 @@ -83,47 +83,112 @@ </div> <el-tabs> - <el-tab-pane label="车辆信息"> + <el-tab-pane label="车辆信息(单位:辆)"> <el-descriptions :column="3"> - <el-descriptions-item label="车辆"> - {{ deptInfo.vehicleVo.offlineDevices.length}}辆 | {{ deptInfo.vehicleVo.allNum}}辆 + <el-descriptions-item label="总数"> + <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 label="仓库"> - {{deptInfo.offlineStatusCount.inStashNum }}辆 | {{ deptInfo.vehicleVo.inStashNum }}辆 - </el-descriptions-item> - <el-descriptions-item label=" 投放" > - <template> - <!-- <pre></pre> --> - <div @click="noline">{{ deptInfo.vehicleVo.offlineDevices.length-deptInfo.offlineStatusCount.inStashNum}}辆 | {{ deptInfo.vehicleVo.inOperation}}辆</div> - </template> - + <span + :style="{ color: deptInfo.offlineStatusCount.inStashNum > 0 ? 'red' : 'gray' }"> + {{ deptInfo.offlineStatusCount.inStashNum }} + </span> | + <span + > + {{ deptInfo.vehicleVo.inStashNum }} + </span> </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="订单"> - {{ 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 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 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 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 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 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> - </el-tab-pane> + </el-tabs> </div> </el-card> @@ -153,7 +218,7 @@ <!-- <recharge :query="{deptId: detail.deptId}" :view="views.user"/> --> </el-tab-pane> <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 label="订单" lazy> @@ -179,6 +244,9 @@ </el-tab-pane> + <el-tab-pane label="管理员列表" lazy> + <user :deptId="detail.deptId" v-if="detail.deptId" /> + </el-tab-pane> </el-tabs> </el-card> @@ -186,7 +254,7 @@ <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> </template> @@ -224,7 +292,7 @@ import refund from "@/views/system/refund/index"; import audit from "@/views/system/audit/index"; import flow from "@/views/system/flow/index"; import withdraw from "@/views/system/withdrawAudit/index"; - +import user from "@/views/system/user/index"; // import Withdraw from '@/views/system/withdraw/index.vue' // import RealName from '@/views/ss/realName/index.vue' @@ -236,7 +304,7 @@ import withdraw from "@/views/system/withdrawAudit/index"; export default { name: 'User/:deptId', mixins: [$view, $serviceType], - components: { Area, Fees, Model, device, order, partner, refund, audit, flow, withdraw, BooleanTag, Recharge, UserRechargeReport, UserConfigDialog, UserAccount, UserDevice, LineChart }, + components: { Area, Fees,user, Model, device, order, partner, refund, audit, flow, withdraw, BooleanTag, Recharge, UserRechargeReport, UserConfigDialog, UserAccount, UserDevice, LineChart }, dicts: ['sys_normal_disable', 'sys_yes_no'], computed: { SmUserType() { @@ -246,7 +314,7 @@ export default { return (type) => { return type === '2' ? '元' : '%'; } - } + } }, data() { return { @@ -254,7 +322,7 @@ export default { loading: false, showConfigDialog: false, deptInfo: {}, - defaultValue:0, + defaultValue: 0, activeTab: '运营区', // 默认激活的标签页 } }, @@ -283,46 +351,47 @@ export default { getDeptInfo(this.$route.params.deptId).then(response => { this.deptInfo = response.data; - // 初始化离线状态统计对象 - this.deptInfo.offlineStatusCount = { - inStashNum: 0, // 仓库中 - normalNum: 0, // 待租 - inAppointmentNum: 0, // 预约中 - ridingNum: 0, // 骑行中 - temporarilyLockNum: 0, // 临时锁车中 - dispatchingNum: 0, // 调度中 - offlineNum: 0 // 下线 - }; + // 初始化离线状态统计对象 + this.deptInfo.offlineStatusCount = { + inStashNum: 0, // 仓库中 + normalNum: 0, // 待租 + inAppointmentNum: 0, // 预约中 + ridingNum: 0, // 骑行中 + temporarilyLockNum: 0, // 临时锁车中 + dispatchingNum: 0, // 调度中 + offlineNum: 0 // 下线 + }; - // 根据 status 进行分类统计 - this.deptInfo.vehicleVo.offlineDevices.forEach(device => { - switch (device.status) { - case 0: - this.deptInfo.offlineStatusCount.inStashNum += 1; - break; - case 1: - this.deptInfo.offlineStatusCount.normalNum += 1; - break; - case 2: - this.deptInfo.offlineStatusCount.inAppointmentNum += 1; - break; - case 3: - this.deptInfo.offlineStatusCount.ridingNum += 1; - break; - case 4: - this.deptInfo.offlineStatusCount.temporarilyLockNum += 1; - break; - case 6: - this.deptInfo.offlineStatusCount.dispatchingNum += 1; - break; - case 8: - this.deptInfo.offlineStatusCount.offlineNum += 1; - break; - } - }); - }).finally(() => { - // 加载完成后可以进行其他操作 - }); + // 根据 status 进行分类统计 + this.deptInfo.vehicleVo.offlineDevices.forEach(device => { + switch (device.status) { + case '0': + this.deptInfo.offlineStatusCount.inStashNum += 1; + break; + case '1': + this.deptInfo.offlineStatusCount.normalNum += 1; + break; + case '2': + this.deptInfo.offlineStatusCount.inAppointmentNum += 1; + break; + case '3': + this.deptInfo.offlineStatusCount.ridingNum += 1; + break; + case '4': + this.deptInfo.offlineStatusCount.temporarilyLockNum += 1; + break; + case '6': + this.deptInfo.offlineStatusCount.dispatchingNum += 1; + break; + case '8': + this.deptInfo.offlineStatusCount.offlineNum += 1; + break; + } + }); + // console.log(this.deptInfo.vehicleVo,'this.deptInfo.offlineStatusCountthis.deptInfo.offlineStatusCount'); + }).finally(() => { + // 加载完成后可以进行其他操作 + }); }, } } diff --git a/src/views/system/device/index.vue b/src/views/system/device/index.vue index 156ea99..beaa33b 100644 --- a/src/views/system/device/index.vue +++ b/src/views/system/device/index.vue @@ -1498,6 +1498,9 @@ export default { listModel(this.queryParams).then((response) => { this.modelOptions = response.rows; }); + // listModel(this.queryParams).then((response) => { + // this.modelOptions = response.rows; + // }); listArea(this.queryParams).then((response) => { this.areaOptions = response.rows; }); @@ -1513,13 +1516,9 @@ export default { } ); } - // console.log(88888888888888); - // listModel(this.queryParams).then((response) => { - // this.modelOptions = response.rows; - // }); - // listArea(this.queryParams).then((response) => { - // this.areaOptions = response.rows; - // }); + listArea(this.queryParams).then((response) => { + this.areaOptions = response.rows; + }); }, /** 搜索按钮操作 */ handleQuery() { @@ -1542,6 +1541,11 @@ export default { this.reset(); this.open = true; this.title = "添加设备"; + this.$nextTick(() => { + if(this.deptId){ + this.form.deptId=this.deptId + } + }) }, /** 详情按钮 */ handleView(row) { diff --git a/src/views/system/fee/index.vue b/src/views/system/fee/index.vue index e63a139..5b8bcf4 100644 --- a/src/views/system/fee/index.vue +++ b/src/views/system/fee/index.vue @@ -583,6 +583,9 @@ export default { this.reset(); this.open = true; this.title = "添加收费方式"; + if(this.deptId){ + this.form.deptId=this.deptId + } }, handleUpdate(row) { this.reset(); diff --git a/src/views/system/model/index.vue b/src/views/system/model/index.vue index 399e2b6..d70b5aa 100644 --- a/src/views/system/model/index.vue +++ b/src/views/system/model/index.vue @@ -439,6 +439,9 @@ export default { this.reset(); this.open = true; this.title = "添加车辆型号"; + if(this.deptId){ + this.form.operator=this.deptId + } }, /** 修改按钮操作 */ handleUpdate(row) { diff --git a/src/views/system/partner/index.vue b/src/views/system/partner/index.vue index 45cc75b..edd27ca 100644 --- a/src/views/system/partner/index.vue +++ b/src/views/system/partner/index.vue @@ -515,7 +515,11 @@ export default { getUser().then(response => { this.postOptions = response.posts; 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.title = "添加合伙人"; this.form.password = this.initPassword; diff --git a/src/views/system/user/index.vue b/src/views/system/user/index.vue index b3f9d65..6b7a149 100644 --- a/src/views/system/user/index.vue +++ b/src/views/system/user/index.vue @@ -265,6 +265,13 @@ export default { return this.userName === 'admin' ? 21 : 24; } }, + props: { + // 用户id + deptId: { + type: Number, + default: null, + } + }, data() { return { options: [], @@ -333,7 +340,7 @@ export default { userName: undefined, phonenumber: undefined, status: undefined, - deptId: undefined, + deptId: this.deptId, typeList: "00,03" }, // 列信息 @@ -518,6 +525,7 @@ export default { getDeptTree() { deptTreeSelect().then(response => { this.deptOptions = response.data; + }); }, // 筛选节点 @@ -611,6 +619,10 @@ export default { this.open = true; this.title = "添加用户"; this.form.password = this.initPassword; + if(this.deptId){ + this.form.deptId=this.deptId + } + }); }, /** 修改按钮操作 */