fix: 人员管理和车辆黑白名单管理添加下发状态筛选

This commit is contained in:
kun 2024-06-15 13:48:27 +08:00
parent 153e8d9687
commit dea1172cdd
5 changed files with 2088 additions and 888 deletions

View File

@ -249,6 +249,8 @@
? 'red' ? 'red'
: row.sendSuccessStatus === 3 : row.sendSuccessStatus === 3
? 'yellow' ? 'yellow'
: row.sendSuccessStatus === 4
? 'red'
: '', : '',
]" ]"
> >
@ -259,6 +261,8 @@
? "失败" ? "失败"
: row.sendSuccessStatus === 3 : row.sendSuccessStatus === 3
? "部分成功" ? "部分成功"
: row.sendSuccessStatus === 4
? '未下发'
: "" : ""
}}</span }}</span
> >
@ -1075,6 +1079,8 @@
? 'red' ? 'red'
: entityDetail.sendSuccessStatus === 3 : entityDetail.sendSuccessStatus === 3
? 'yellow' ? 'yellow'
: entityDetail.sendSuccessStatus === 4
? 'red'
: '', : '',
]" ]"
> >
@ -1085,6 +1091,8 @@
? "失败" ? "失败"
: entityDetail.sendSuccessStatus === 3 : entityDetail.sendSuccessStatus === 3
? "部分成功" ? "部分成功"
: entityDetail.sendSuccessStatus === 4
? '未下发'
: "" : ""
}}</span }}</span
> >
@ -1310,6 +1318,7 @@ export default {
}; };
return { return {
sendStatusArr: [ sendStatusArr: [
{ name: "未下发", value: 4 },
{ name: "成功", value: 1 }, { name: "成功", value: 1 },
{ name: "失败", value: 2 }, { name: "失败", value: 2 },
{ name: "部分成功", value: 3 }, { name: "部分成功", value: 3 },

View File

@ -5,15 +5,36 @@
<el-form-item> <el-form-item>
<!-- v-permission="{ key: 'datavalidation_staffmanualcheck', menuPath: '/project/labor/dataValidation' }" --> <!-- v-permission="{ key: 'datavalidation_staffmanualcheck', menuPath: '/project/labor/dataValidation' }" -->
<!-- 人员手动校验 --> <!-- 人员手动校验 -->
<el-button type="primary" @click="onStaffIsCarManualCheck(1)"> <el-button
type="primary"
@click="onStaffIsCarManualCheck(1)"
v-permission="{
key: 'dataValidation_member_validator',
menuPath: '/project/labor/dataValidation',
}"
>
人员手动校验 人员手动校验
</el-button> </el-button>
<!-- 车辆手动校验 --> <!-- 车辆手动校验 -->
<el-button @click="onStaffIsCarManualCheck(2)" type="primary"> <el-button
@click="onStaffIsCarManualCheck(2)"
type="primary"
v-permission="{
key: 'dataValidation_car_validator',
menuPath: '/project/labor/dataValidation',
}"
>
车辆手动校验 车辆手动校验
</el-button> </el-button>
<!-- 批量同步 --> <!-- 批量同步 -->
<el-button @click="onBatchSynchronization()" type="primary"> <el-button
@click="onBatchSynchronization()"
type="primary"
v-permission="{
key: 'dataValidation_batch_sync',
menuPath: '/project/labor/dataValidation',
}"
>
批量同步 批量同步
</el-button> </el-button>
<el-button type="warning" plain @click="resetForm()"> <el-button type="warning" plain @click="resetForm()">
@ -37,35 +58,74 @@
</el-form> </el-form>
</div> </div>
<div class="table_wrap whiteBlock"> <div class="table_wrap whiteBlock">
<el-tabs v-model="activeName" @tab-click="handleClick" style="padding: 0 15px"> <el-tabs
v-model="activeName"
@tab-click="handleClick"
style="padding: 0 15px"
>
<el-tab-pane label="人员组织" name="1"></el-tab-pane> <el-tab-pane label="人员组织" name="1"></el-tab-pane>
<el-tab-pane label="人员信息" name="2"></el-tab-pane> <el-tab-pane label="人员信息" name="2"></el-tab-pane>
<el-tab-pane label="人员照片" name="3"></el-tab-pane> <el-tab-pane label="人员照片" name="3"></el-tab-pane>
<el-tab-pane label="车辆信息" name="4"></el-tab-pane> <el-tab-pane label="车辆信息" name="4"></el-tab-pane>
</el-tabs> </el-tabs>
<el-table ref="multipleTable" class="tables" row-key="id" :data="tableList" @selection-change="handleSelectionChange"> <el-table
<el-table-column align="center" type="selection" width="55" :reserve-selection="true"> ref="multipleTable"
class="tables"
row-key="id"
:data="tableList"
@selection-change="handleSelectionChange"
>
<el-table-column
align="center"
type="selection"
width="55"
:reserve-selection="true"
>
</el-table-column> </el-table-column>
<el-table-column show-overflow-tooltip v-if="activeName == '1'" align="center" prop="orgName" <el-table-column
label="组织名称"></el-table-column> show-overflow-tooltip
<el-table-column show-overflow-tooltip v-else-if="activeName == '2' || activeName == '3'" align="center" v-if="activeName == '1'"
prop="workerName" label="人员姓名"></el-table-column> align="center"
<el-table-column show-overflow-tooltip v-else-if="activeName == '4'" align="center" prop="carNumber" prop="orgName"
label="车牌号"></el-table-column> label="组织名称"
<el-table-column show-overflow-tooltip v-if="activeName == '2' || activeName == '3'" align="center" prop="idCard" ></el-table-column>
label="身份证号"></el-table-column> <el-table-column
show-overflow-tooltip
v-else-if="activeName == '2' || activeName == '3'"
align="center"
prop="workerName"
label="人员姓名"
></el-table-column>
<el-table-column
show-overflow-tooltip
v-else-if="activeName == '4'"
align="center"
prop="carNumber"
label="车牌号"
></el-table-column>
<el-table-column
show-overflow-tooltip
v-if="activeName == '2' || activeName == '3'"
align="center"
prop="idCard"
label="身份证号"
></el-table-column>
<el-table-column align="center" label="ISC校验结果"> <el-table-column align="center" label="ISC校验结果">
<template slot-scope="scope"> <template slot-scope="scope">
<div :class="scope.row.existIsc == 1 ? 'refreshbtn' : 'unrefreshbtn'"> <div
:class="scope.row.existIsc == 1 ? 'refreshbtn' : 'unrefreshbtn'"
>
{{ scope.row.existIsc == 1 ? "存在" : "不存在" }} {{ scope.row.existIsc == 1 ? "存在" : "不存在" }}
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column align="center" label="平台校验结果"> <el-table-column align="center" label="平台校验结果">
<template slot-scope="scope"> <template slot-scope="scope">
<div :class=" <div
:class="
scope.row.existMyPlatform == 1 ? 'refreshbtn' : 'unrefreshbtn' scope.row.existMyPlatform == 1 ? 'refreshbtn' : 'unrefreshbtn'
"> "
>
{{ scope.row.existMyPlatform == 1 ? "存在" : "不存在" }} {{ scope.row.existMyPlatform == 1 ? "存在" : "不存在" }}
</div> </div>
<!-- scope.row --> <!-- scope.row -->
@ -73,9 +133,14 @@
</el-table-column> </el-table-column>
<el-table-column align="center" label="同步结果"> <el-table-column align="center" label="同步结果">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button class="synchronization" disabled :type="scope.row.syncResult == 1 ? 'info' : 'danger'">{{ <el-button
class="synchronization"
disabled
:type="scope.row.syncResult == 1 ? 'info' : 'danger'"
>{{
scope.row.syncResult == 1 ? "未同步" : "同步失败" scope.row.syncResult == 1 ? "未同步" : "同步失败"
}}</el-button> }}</el-button
>
<!-- <el-button class="synchronization" disabled type="danger">同步失败</el-button> <!-- <el-button class="synchronization" disabled type="danger">同步失败</el-button>
<el-button class="synchronization" disabled type="success">同步成功</el-button> --> <el-button class="synchronization" disabled type="success">同步成功</el-button> -->
</template> </template>
@ -83,17 +148,32 @@
<el-table-column align="center" label="操作"> <el-table-column align="center" label="操作">
<template slot-scope="scope"> <template slot-scope="scope">
<!-- unrefreshbtn --> <!-- unrefreshbtn -->
<div @click="onHikvisionSync(scope.row.id)" <div
:class="scope.row.syncResult == 1 ? 'refreshbtn' : 'unrefreshbtn'" class="accessory"> v-permission="{
key: 'dataValidation_sync',
menuPath: '/project/labor/dataValidation',
}"
@click="onHikvisionSync(scope.row.id)"
:class="scope.row.syncResult == 1 ? 'refreshbtn' : 'unrefreshbtn'"
class="accessory"
>
<i class="el-icon-refresh"></i> <i class="el-icon-refresh"></i>
{{ scope.row.syncResult == 1 ? "同步" : "重试" }} {{ scope.row.syncResult == 1 ? "同步" : "重试" }}
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<el-pagination class="pagerBox" @size-change="sizeChange" @current-change="currentChange" <el-pagination
:current-page="pagInfo.pageNo" :page-sizes="pageSizeList" :page-size="pagInfo.pageSize" class="pagerBox"
layout="total, sizes, prev, pager, next" :total="Number(pagInfo.total)" background></el-pagination> @size-change="sizeChange"
@current-change="currentChange"
:current-page="pagInfo.pageNo"
:page-sizes="pageSizeList"
:page-size="pagInfo.pageSize"
layout="total, sizes, prev, pager, next"
:total="Number(pagInfo.total)"
background
></el-pagination>
</div> </div>
</div> </div>
</template> </template>
@ -254,8 +334,10 @@ export default {
if (res.code == 200) { if (res.code == 200) {
this.tableList = res.result.records; this.tableList = res.result.records;
this.pagInfo.total = res.result.total; this.pagInfo.total = res.result.total;
if(+res.result.total>this.pageSizeList[this.pageSizeList.length - 1]){ if (
this.pageSizeList.push(+res.result.total) +res.result.total > this.pageSizeList[this.pageSizeList.length - 1]
) {
this.pageSizeList.push(+res.result.total);
} }
} }
}); });
@ -266,7 +348,9 @@ export default {
// console.log(val.name); // console.log(val.name);
this.activeName = val.name; this.activeName = val.name;
this.$refs.multipleTable.clearSelection(); this.$refs.multipleTable.clearSelection();
this.pageSizeList = JSON.parse(JSON.stringify(this.$store.state.PAGESIZRS)); this.pageSizeList = JSON.parse(
JSON.stringify(this.$store.state.PAGESIZRS)
);
this.initClear(); this.initClear();
this.getHikvisionPage(); this.getHikvisionPage();
}, },

View File

@ -213,7 +213,8 @@
></i> ></i>
</div> </div>
<div class="laborComponent_table_wrap whiteBlock"> <div class="laborComponent_table_wrap whiteBlock">
<div class="search_wrap" :class="{ flex: COMPANY != 'nanchang' }"> <!-- :class="{ flex: COMPANY != 'nanchang' }" -->
<div class="search_wrap">
<!-- 人员录入 --> <!-- 人员录入 -->
<el-button <el-button
v-permission="{ v-permission="{
@ -289,17 +290,45 @@
size="medium" size="medium"
@click="passEquipment()" @click="passEquipment()"
type="primary" type="primary"
style="margin-left: 5px; margin-right: 10px" style="margin-left: 5px;"
:disabled="checkedWorker.length <= 0"
>下发通行设备</el-button >下发通行设备</el-button
> >
<!-- <br /> --> <el-button
v-if="isIscDevice"
v-permission="{
key: 'rygl_distributeAccessEquipment',
menuPath: '/project/labor/personManage',
}"
size="medium"
@click="checkAllFn()"
type="primary"
style="margin-left: 5px;"
>全选</el-button
>
<br />
<el-form <el-form
:inline="true" :inline="true"
:model="tableParameter" :model="tableParameter"
size="medium" size="medium"
class="demo-form-inline" class="demo-form-inline"
style="margin-left: 5px" style="margin-top: 5px;"
> >
<el-form-item label="人员下发状态" v-if="isIscDevice">
<el-select
size="medium"
v-model="tableParameter.sendSuccessStatus"
placeholder="请选择"
style="width: 120px"
>
<el-option
v-for="(item, index) in sendStatusArr"
:key="index"
:label="item.name"
:value="item.value"
></el-option>
</el-select>
</el-form-item>
<el-form-item :label="$t('message.laborMange.workingState')"> <el-form-item :label="$t('message.laborMange.workingState')">
<el-select <el-select
v-model="tableParameter.inserviceType" v-model="tableParameter.inserviceType"
@ -388,12 +417,9 @@
key: 'rygl_refresh', key: 'rygl_refresh',
menuPath: '/project/labor/personManage', menuPath: '/project/labor/personManage',
}" --> }" -->
<el-button <el-button type="warning" @click="refreshBtn" plain>{{
type="warning" $t("message.laborMange.refresh")
@click="refreshBtn" }}</el-button>
plain
>{{ $t("message.laborMange.refresh") }}</el-button
>
<!-- 导出 --> <!-- 导出 -->
<el-button <el-button
title="按班组导出" title="按班组导出"
@ -415,7 +441,7 @@
</el-form-item> </el-form-item>
</el-form> </el-form>
</div> </div>
<vue-scroll style="height: calc(100% - 80px)"> <vue-scroll style="height: calc(100% - 100px)">
<el-table <el-table
ref="multipleTable" ref="multipleTable"
:data="tableListData" :data="tableListData"
@ -567,12 +593,8 @@
v-if="scope.row.inserviceType == 1" v-if="scope.row.inserviceType == 1"
>{{ $t("message.laborMange.bowOutWith") }}</el-button >{{ $t("message.laborMange.bowOutWith") }}</el-button
> >
<!-- 删除人员 --> <!-- 再次进场 -->
<el-button <el-button
v-permission="{
key: 'rygl_delete',
menuPath: '/project/labor/personManage',
}"
size="medium" size="medium"
type="text" type="text"
class="operationText" class="operationText"
@ -580,7 +602,12 @@
v-if="scope.row.inserviceType == 2" v-if="scope.row.inserviceType == 2"
>{{ $t("message.laborMange.toPlayAgain") }}</el-button >{{ $t("message.laborMange.toPlayAgain") }}</el-button
> >
<!-- 删除人员 -->
<div <div
v-permission="{
key: 'rygl_delete',
menuPath: '/project/labor/personManage',
}"
class="operationText" class="operationText"
@click="removeWorkerInfo(scope.row)" @click="removeWorkerInfo(scope.row)"
> >
@ -665,6 +692,7 @@
@size-change="handleSizeChange" @size-change="handleSizeChange"
@current-change="handleCurrentChange" @current-change="handleCurrentChange"
:current-page="page" :current-page="page"
:page-sizes="pageSizeList"
:page-size="pageSize" :page-size="pageSize"
layout="total, sizes, prev, pager, next" layout="total, sizes, prev, pager, next"
:total="Number(total)" :total="Number(total)"
@ -2413,6 +2441,13 @@ export default {
}, },
data() { data() {
return { return {
pageSizeList: [],
sendStatusArr: [
{ name: "未下发", value: 4 },
{ name: "成功", value: 1 },
{ name: "失败", value: 2 },
{ name: "部分成功", value: 3 },
],
issuePointList: [], issuePointList: [],
typeRadio: 1, typeRadio: 1,
refreshPage: true, // refreshPage: true, //
@ -2501,6 +2536,7 @@ export default {
teamId: "", teamId: "",
workerName: "", workerName: "",
inserviceType: "", inserviceType: "",
sendSuccessStatus: null,
enterDate: "", enterDate: "",
codeState: "", codeState: "",
}, },
@ -2609,6 +2645,7 @@ export default {
}; };
}, },
created() { created() {
this.pageSizeList = JSON.parse(JSON.stringify(this.$store.state.PAGESIZRS));
this.projectSn = this.$store.state.projectSn; this.projectSn = this.$store.state.projectSn;
this.uploadUrl = this.$store.state.UPLOADURL; this.uploadUrl = this.$store.state.UPLOADURL;
this.fileUrl = this.$store.state.FILEURL; this.fileUrl = this.$store.state.FILEURL;
@ -2772,14 +2809,23 @@ export default {
this.imgFileList = []; this.imgFileList = [];
this.imgImportDialog = true; this.imgImportDialog = true;
}, },
checkAllFn() {
//
this.$refs.multipleTable.toggleAllSelection();
},
// //
passEquipment() { passEquipment() {
sendBatchWokerApi({ let requestData = {
projectSn: this.projectSn, projectSn: this.projectSn,
personType: "1", personType: "1",
userId: this.$store.state.userInfo.userId, userId: this.$store.state.userInfo.userId,
enterpriseId: this.checkedId, enterpriseId: this.checkedId
}).then((res) => { }
if(this.checkedWorker.length > 0){
const ids = this.checkedWorker.map((item) => item.id).join(",");
requestData.workerIds = ids
}
sendBatchWokerApi(requestData).then((res) => {
if (res.code == 200) { if (res.code == 200) {
this.$message({ this.$message({
message: "操作成功,已在后台下发,请稍后查看!", message: "操作成功,已在后台下发,请稍后查看!",
@ -2995,7 +3041,7 @@ export default {
if (result.success) { if (result.success) {
if (result.result) { if (result.result) {
this.isUploadToHouse = result.result.housing ? true : false; this.isUploadToHouse = result.result.housing ? true : false;
this.isIscDevice = result.result.supplierType == 9 ? true: false; this.isIscDevice = result.result.supplierType == 9 ? true : false;
} }
} }
}); });
@ -3443,6 +3489,11 @@ export default {
this.checkAllStatus = this.checkAllStatus =
this.tableListData.length == 0 ? true : boole ? true : false; this.tableListData.length == 0 ? true : boole ? true : false;
this.total = res.result.total; this.total = res.result.total;
if (
+res.result.total > this.pageSizeList[this.pageSizeList.length - 1]
) {
this.pageSizeList.push(+res.result.total);
}
} }
}); });
}, },
@ -3948,6 +3999,7 @@ export default {
this.tableParameter.idCard = ""; this.tableParameter.idCard = "";
this.tableParameter.workerName = ""; this.tableParameter.workerName = "";
this.tableParameter.inserviceType = ""; this.tableParameter.inserviceType = "";
this.tableParameter.sendSuccessStatus = null;
this.tableParameter.enterDate = ""; this.tableParameter.enterDate = "";
this.tableParameter.codeState = ""; this.tableParameter.codeState = "";
this.getTableData(); this.getTableData();
@ -3971,7 +4023,7 @@ export default {
this.$message.error(this.$t("message.companyDiagram.uploadMsg")); // this.$message.error(this.$t("message.companyDiagram.uploadMsg")); //
return false; return false;
} else if (type == 7) { } else if (type == 7) {
console.log(file) console.log(file);
if ( if (
file.type != "image/jpeg" && file.type != "image/jpeg" &&
file.type != "image/jpg" file.type != "image/jpg"
@ -3981,9 +4033,9 @@ export default {
return false; return false;
} }
let imgSize = Number(file.size / 1024); let imgSize = Number(file.size / 1024);
console.log(11111111, imgSize) console.log(11111111, imgSize);
if (imgSize <= 10 || imgSize >= 200) { if (imgSize <= 10 || imgSize >= 200) {
this.$message.error("文件大小不能超过200kb小于10kb,请重新上传!") this.$message.error("文件大小不能超过200kb小于10kb,请重新上传!");
return false; return false;
} }
} }
@ -4692,13 +4744,13 @@ export default {
}); });
}, },
tableRowClassName({ row, rowIndex }) { tableRowClassName({ row, rowIndex }) {
if(!this.isIscDevice){ if (!this.isIscDevice) {
return return;
} }
if (row.sendSuccessStatus === 1) { if (row.sendSuccessStatus === 1) {
return "green2"; return "green2";
} }
if (row.sendSuccessStatus === 2) { if (row.sendSuccessStatus === 2 || row.sendSuccessStatus === 4) {
return "red2"; return "red2";
} }
if (row.sendSuccessStatus === 3) { if (row.sendSuccessStatus === 3) {

View File

@ -180,8 +180,22 @@
@click="memberRegister" @click="memberRegister"
>人员录入</el-button >人员录入</el-button
> >
<el-button type="primary" @click="checkAllFn">全选</el-button> <el-button
<el-button type="primary" @click="onBatchSynchronization" type="primary"
@click="checkAllFn"
v-permission="{
key: 'hmc_batch_authorization',
menuPath: '/project/labor/roster',
}"
>全选</el-button
>
<el-button
type="primary"
@click="onBatchSynchronization"
v-permission="{
key: 'hmc_batch_authorization',
menuPath: '/project/labor/roster',
}"
>批量授权门禁权限</el-button >批量授权门禁权限</el-button
> >
</el-form-item> </el-form-item>
@ -388,7 +402,7 @@
: row.sendSuccessStatus === 3 : row.sendSuccessStatus === 3
? 'yellow' ? 'yellow'
: row.sendSuccessStatus === 4 : row.sendSuccessStatus === 4
? '' ? 'red'
: '', : '',
]" ]"
> >
@ -1625,7 +1639,7 @@ export default {
if (row.sendSuccessStatus === 1) { if (row.sendSuccessStatus === 1) {
return "green2"; return "green2";
} }
if (row.sendSuccessStatus === 2) { if (row.sendSuccessStatus === 2 || row.sendSuccessStatus === 4) {
return "red2"; return "red2";
} }
if (row.sendSuccessStatus === 3) { if (row.sendSuccessStatus === 3) {