救援新功能1/2

This commit is contained in:
xiao-fajia 2024-08-26 16:16:12 +08:00
parent aaa1de240e
commit e9ecc30ed5
2 changed files with 162 additions and 8 deletions

View File

@ -28,4 +28,33 @@ export function delRescueRoad(id) {
})
}
export function getDictStaff(ids) {
return request({
url: '/system/rescueInfo/getDictStaff/' + ids,
method: 'get',
})
}
export function getDrivers() {
return request({
url: '/system/rescueInfo/getDrivers',
method: 'get',
})
}
export function getManages() {
return request({
url: '/system/rescueInfo/getManages',
method: 'get',
})
}
export function bindDictStaff(data) {
return request({
url: '/system/rescueInfo/bindDictStaff',
method: 'post',
data
})
}

View File

@ -34,7 +34,7 @@
<span>{{ scope.$index + 1 }}</span>
</template>
</el-table-column>
<el-table-column label="排序" align="center" prop="sort" />
<!-- <el-table-column label="排序" align="center" prop="sort" />-->
<el-table-column label="路段" align="center" prop="dictLabel">
<template slot-scope="scope">
@ -42,6 +42,8 @@
<el-tag v-else :type="scope.row.listClass == 'primary' ? '' : scope.row.listClass">{{scope.row.label}}</el-tag>
</template>
</el-table-column>
<el-table-column label = "救援经理" align="center" prop="manageName" />
<el-table-column label = "救援司机" align="center" prop="driverNames" />
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
@ -50,6 +52,12 @@
icon="el-icon-delete"
@click="handleDelete(scope.row)"
>删除</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-setting"
@click="handleBind(scope.row)"
>绑定人员</el-button>
</template>
</el-table-column>
</el-table>
@ -73,11 +81,56 @@
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
<!-- 配置绑定路段人员 -->
<el-dialog :title="bindTitle" :visible.sync="bindOpen" width="500px" append-to-body>
<el-form ref="bindForm" :model="bindForm" :rules="bindRules" label-width="80px">
<el-form-item label="救援路段" prop="dictLabel">
{{bindForm.dictLabel}}
</el-form-item>
<el-form-item label="救援经理" prop="manageId">
<el-select
style="width: 100%"
filterable
clearable
v-model="bindForm.manageId" placeholder="请选择救援经理"
>
<el-option
v-for="(item, index) in manages"
:key="index"
:label="item.name"
:value="item.userId"
>
</el-option>
</el-select>
</el-form-item>
<el-form-item label="救援司机" prop="manageId">
<el-select
style="width: 100%"
filterable
clearable
v-model="bindForm.driverIds" multiple placeholder="请选择救援司机"
>
<el-option
v-for="(item, index) in drivers"
:key="index"
:label="item.name"
:value="item.userId"
>
</el-option>
</el-select>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="bindSubmitForm"> </el-button>
<el-button @click="bindOpen = false"> </el-button>
</div>
</el-dialog>
</div>
</template>
<script>
import {getRescueRoad,addRescueRoad,delRescueRoad} from "./api/rescueRoad";
import {bindDictStaff, getRescueRoad,addRescueRoad,delRescueRoad, getDictStaff, getDrivers, getManages} from "./api/rescueRoad";
export default {
name: "Data",
@ -149,7 +202,22 @@ export default {
dictSort: [
{ required: true, message: "数据顺序不能为空", trigger: "blur" }
]
}
},
bindTitle: null,
bindForm: {
id: null,
dictLabel: null,
dictId: "",
manageId: "",
driverIds: ""
},
bindRules:{
manageId: [{required: true, message: "救援经理不能为空", trigger: "blur"}],
driverIds: [{required: true, message: "救援司机不能为空", trigger: "blur"}]
},
bindOpen: false,
manages: [],
drivers: [],
};
},
created() {
@ -157,12 +225,29 @@ export default {
},
methods: {
/** 查询字典数据列表 */
getList() {
async getList() {
this.loading = true;
getRescueRoad(this.queryParams).then(response => {
console.log(response)
try {
const response = await getRescueRoad(this.queryParams);
this.dataList = response.data;
this.loading = false;
const ids = this.dataList.map(item => item.id);
await this.listDictStaff(ids);
} finally {
this.loading = false; // 使 loading
}
},
async listDictStaff(ids){
const res = await getDictStaff(ids);
//
this.dataList = this.dataList.map((item, index) => {
const staffItem = res.data[index];
return {
...item,
manageId: staffItem ? staffItem.manageId : null,
driverIds: staffItem ? staffItem.driverIds : null,
manageName: staffItem ? staffItem.manageName : null,
driverNames: staffItem ? staffItem.driverNames : null
};
});
},
//
@ -248,7 +333,47 @@ export default {
this.download('system/dict/data/export', {
...this.queryParams
}, `data_${new Date().getTime()}.xlsx`)
}
},
handleBind(row){
this.bindTitle = "绑定人员"
this.bindForm = {
dictLabel: row.label,
manageId: row.manageId,
driverIds: row.driverIds ? row.driverIds.split(",").map(item => parseInt(item)) : null,
dictId: row.id
}
getDictStaff(row.id).then(res => {
if (res.data[0]){
this.bindForm.id = res.data[0]
}
})
this.listDrivers();
this.listManages();
this.bindOpen = true
},
listManages(){
getManages().then(res => {
this.manages = res.data
})
},
listDrivers(){
getDrivers().then(res => {
this.drivers = res.data
})
},
/** 提交按钮 */
bindSubmitForm: function() {
this.$refs["bindForm"].validate(valid => {
if (valid) {
this.bindForm.driverIds = this.bindForm.driverIds ? this.bindForm.driverIds.join(",") : null
bindDictStaff(this.bindForm).then(response => {
this.$modal.msgSuccess("绑定成功");
this.bindOpen = false;
this.getList();
});
}
});
},
}
};
</script>