边代设备申请接入

This commit is contained in:
jjLv 2024-09-20 10:19:56 +08:00
parent 7bf085ec89
commit 8ce3670063
8 changed files with 834 additions and 13 deletions

View File

@ -57,3 +57,8 @@ export const queryEdgeDeviceByIdApi = (id) => {
export const deleteEdgeDeviceApi = (id) => {
return request.delete(`/base/tbBdRecord/${id}`)
}
/** 同意审核 */
export const approveEdgeDeviceApi = (data) => {
return request.post('/base/tbBdRecord/approve', data)
}

View File

@ -0,0 +1,357 @@
<template>
<!-- 工程管理 新增编辑 表单组件 -->
<div>
<el-form
label-width="100px"
size="medium"
ref="projectParamsRef"
:model="projectParams"
:rules="projectParamsRules"
>
<el-row type="flex" justify="space-between" :gutter="24">
<el-col :span="12">
<el-form-item label="项目部" prop="departId" >
<el-select
v-model="projectParams.departId"
clearable
filterable
placeholder="请选择"
@change="departChange"
disabled
>
<el-option
v-for="item in departRange"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="工程名称" prop="proId">
<el-select
v-model="projectParams.proId"
clearable
filterable
placeholder="请选择"
@change="projChange"
disabled
>
<el-option
v-for="item in projRange"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row type="flex" justify="space-between" :gutter="24">
<el-col :span="12">
<el-form-item label="申请人" prop="relUser">
<el-input v-model="projectParams.relUser" placeholder="请输入" disabled/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="联系方式" prop="relPhone">
<el-input v-model="projectParams.relPhone" :maxlength="11" placeholder="请输入" disabled/>
</el-form-item>
</el-col>
</el-row>
<TableModelTwo
:columnsList="columnsListInsert"
ref="tableRef"
@transIdList="getIdList"
:show-btn-crews="false"
:show-right-tools="false"
:show-sel="false"
:show-index="false"
style="margin-bottom: 100px"
>
</TableModelTwo>
<el-form-item label="审核意见" prop="remarks">
<textarea id="remarks" v-model="projectParams.remarks" class="el-textarea" placeholder="请输入审核意见" disabled></textarea>
<!-- <el-input v-model="projectParams.relUser" placeholder="请输入" disabled/> -->
</el-form-item>
<el-row type="flex" justify="space-between" :gutter="24">
<el-col :span="12">
<el-form-item label="审批人" prop="auditUserName">
<el-input v-model="projectParams.auditUserName" placeholder="请输入审批人" disabled/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="审批时间" prop="auditTime">
<el-input v-model="projectParams.auditTime" placeholder="请输入审批时间" disabled/>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div
style="display: flex; justify-content: right"
>
<el-button type="danger" @click="onReturn">驳回</el-button>
<el-button type="success" @click="onSubmit">同意</el-button>
<!-- <el-button
@click="
() => {
this.$emit('closeDialog')
}
"
>驳回</el-button -->
</div>
</div>
</template>
<script>
import { columnsListInsert } from '../config-insert'
// import { formLabelApprove,columnsListApprove} from '../config-approve'
import {
// addEdgeDeviceApi,
// editEdgeDeviceApi,
approveEdgeDeviceApi,
queryEdgeDeviceByIdApi
} from '@/api/base/insert'
import {
queryProjApi
} from '@/api/base/crew'
import {
queryProjDeptListApi
} from '@/api/base/projDept'
export default {
name: 'FormProject',
props: {
editParams: {
type: Object,
default: () => null,
},
},
components: { },
created() {
this.getRanges()
},
mounted() {
console.log(this.editParams)
if (this.editParams) {
Object.assign(this.projectParams, this.editParams)
// this.projectParams.auditUserName = this.editParams.auditUserName
// this.projectParams.remarks = ''
//
queryEdgeDeviceByIdApi(this.editParams.id).then(res => {
res.data.recordList.forEach(item => {
this.$refs.tableRef.tableList.unshift(item)
})
}).catch(err => {})
this.subSort = 2
} else {
this.subSort = 1
}
},
data() {
return {
columnsListInsert,
exportList: [],
subSort: '', // 1 / 2
projectParams: {
departId: undefined, //
proId: undefined, //
relUser: undefined, //
relPhone: undefined, //
remarks: undefined, //
auditStatus: undefined, //
auditUserName: undefined, //
auditTime: undefined, //
},
//
projectParamsRules: {
departId: [
{
required: true,
message: '请输入项目部名称',
trigger: 'blur',
},
],
proId: [
{
required: true,
message: '请输入工程名称',
trigger: 'blur',
},
],
relUser: [
{
required: true,
message: '请输入申请人',
trigger: 'blur',
},
],
relPhone: [
{
required: true,
message: '手机号格式不正确',
validator: this.validatePhone,
trigger: 'blur',
},
],
remarks: [
{
required: true,
message: '请输入审核意见',
trigger: 'blur',
},
],
},
//
departRange: [],
projRange: [],
//
phoneReg: /^(?:(?:\+|00)86)?1[3-9]\d{9}$/,
testId: 1
}
},
methods: {
/** 校验手机号 */
validatePhone(rule, value, callback) {
if(!this.phoneReg.test(value)) {
callback(new Error('手机号格式不正确'))
} else {
callback()
}
},
getIdList(idList) {
this.exportList = []
console.log(idList)
},
handleAddEdge() {
let setObj = {}
this.$set(setObj, 'testId', this.testId)
this.testId++
this.$set(setObj, 'devName', undefined)
this.$set(setObj, 'devCode', undefined)
this.$set(setObj, 'unitName', undefined)
this.$set(setObj, 'areaName', undefined)
this.$set(setObj, 'devUser', undefined)
this.$set(setObj, 'devUserPhone', undefined)
this.$refs.tableRef.tableList.push(setObj)
},
handleDeleteEdge(v) {
this.$modal
.confirm('是否确认删除该数据项?')
.then(() => {
this.$refs.tableRef.tableList.forEach((item, index) => {
if(item.testId === v.testId) {
this.$refs.tableRef.tableList.splice(index, 1)
}
})
})
.catch(() => {})
},
/** 获取各类下拉框 */
async getRanges() {
//
let deptRes = await queryProjDeptListApi({
isAll: 0
})
this.departRange = deptRes.data.map(item => {
return {
label: item.departName,
value: item.id
}
})
//
let projRes = await queryProjApi({
isAll: 0
})
this.projRange = projRes.data.map(item => {
return {
label: item.proName,
value: item.id
}
})
},
departChange(e) {
this.departRange.forEach(item => {
if(e === item.value) {
this.projectParams.departName = item.label
}
})
},
projChange(e) {
this.projRange.forEach(item => {
if(e === item.value) {
this.projectParams.proName = item.label
}
})
},
/** 改变树结构 */
changeTree(leaf) {
leaf.map(item => {
item.value = item.id
if(item.children) {
this.changeTree(item.children)
}
})
return leaf
},
/** 确认按钮 */
onSubmit() {
console.log(this.$refs.tableRef.tableList, this.projectParams)
this.$refs.projectParamsRef.validate(async valid => {
if (valid) {
this.projectParams.recordList = this.$refs.tableRef.tableList
this.projectParams.auditStatus = 1
// if(this.subSort === 1) {
// let res = await addEdgeDeviceApi(this.projectParams)
// if(res.code === 200) {
// this.$modal.msgSuccess('')
// this.$emit('closeDialog', true)
// }
// } else {
let res = await approveEdgeDeviceApi(this.projectParams)
if(res.code === 200) {
this.$modal.msgSuccess('操作成功')
this.$emit('closeDialogApprove', true)
}
}
})
},
onReturn() {
this.$refs.projectParamsRef.validate(async valid => {
if (valid) {
this.projectParams.recordList = this.$refs.tableRef.tableList
this.projectParams.auditStatus = 2
let res = await approveEdgeDeviceApi(this.projectParams)
if(res.code === 200) {
this.$modal.msgSuccess('操作成功')
this.$emit('closeDialogApprove', true)
}
}
})
},
},
}
</script>
<style scoped>
::v-deep .el-select {
width: 100%;
}
::v-deep .el-form-item__label{
font-weight: normal;
}
.el-textarea {
width: 100%;
height: 100px;
resize: none;
}
</style>

View File

@ -0,0 +1,342 @@
<template>
<!-- 工程管理 新增编辑 表单组件 -->
<div>
<el-form
label-width="100px"
size="medium"
ref="projectParamsRef"
:model="projectParams"
:rules="projectParamsRules"
>
<el-row type="flex" justify="space-between" :gutter="24">
<el-col :span="12">
<el-form-item label="项目部" prop="departId" >
<el-select
v-model="projectParams.departId"
clearable
filterable
placeholder="请选择"
@change="departChange"
disabled
>
<el-option
v-for="item in departRange"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="工程名称" prop="proId">
<el-select
v-model="projectParams.proId"
clearable
filterable
placeholder="请选择"
@change="projChange"
disabled
>
<el-option
v-for="item in projRange"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row type="flex" justify="space-between" :gutter="24">
<el-col :span="12">
<el-form-item label="申请人" prop="relUser">
<el-input v-model="projectParams.relUser" placeholder="请输入" disabled/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="联系方式" prop="relPhone">
<el-input v-model="projectParams.relPhone" :maxlength="11" placeholder="请输入" disabled/>
</el-form-item>
</el-col>
</el-row>
<TableModelTwo
:columnsList="columnsListInsert"
ref="tableRef"
@transIdList="getIdList"
:show-btn-crews="false"
:show-right-tools="false"
:show-sel="false"
:show-index="false"
style="margin-bottom: 100px"
>
</TableModelTwo>
<el-form-item label="审核意见" prop="remarks">
<textarea id="remarks" v-model="projectParams.remarks" class="el-textarea" placeholder="请输入审核意见" ></textarea>
<!-- <el-input v-model="projectParams.relUser" placeholder="请输入" disabled/> -->
</el-form-item>
</el-form>
<div
style="display: flex; justify-content: right"
>
<el-button type="danger" @click="onReturn">驳回</el-button>
<el-button type="success" @click="onSubmit">同意</el-button>
<!-- <el-button
@click="
() => {
this.$emit('closeDialog')
}
"
>驳回</el-button -->
</div>
</div>
</template>
<script>
import { columnsListInsert } from '../config-insert'
// import { formLabelApprove,columnsListApprove} from '../config-approve'
import {
// addEdgeDeviceApi,
// editEdgeDeviceApi,
approveEdgeDeviceApi,
queryEdgeDeviceByIdApi
} from '@/api/base/insert'
import {
queryProjApi
} from '@/api/base/crew'
import {
queryProjDeptListApi
} from '@/api/base/projDept'
export default {
name: 'FormProject',
props: {
editParams: {
type: Object,
default: () => null,
},
},
components: { },
created() {
this.getRanges()
},
mounted() {
console.log(this.editParams)
if (this.editParams) {
Object.assign(this.projectParams, this.editParams)
this.projectParams.remarks = ''
//
queryEdgeDeviceByIdApi(this.editParams.id).then(res => {
res.data.recordList.forEach(item => {
this.$refs.tableRef.tableList.unshift(item)
})
}).catch(err => {})
this.subSort = 2
} else {
this.subSort = 1
}
},
data() {
return {
columnsListInsert,
exportList: [],
subSort: '', // 1 / 2
projectParams: {
departId: undefined, //
proId: undefined, //
relUser: undefined, //
relPhone: undefined, //
remarks: undefined, //
auditStatus: undefined, //
},
//
projectParamsRules: {
departId: [
{
required: true,
message: '请输入项目部名称',
trigger: 'blur',
},
],
proId: [
{
required: true,
message: '请输入工程名称',
trigger: 'blur',
},
],
relUser: [
{
required: true,
message: '请输入申请人',
trigger: 'blur',
},
],
relPhone: [
{
required: true,
message: '手机号格式不正确',
validator: this.validatePhone,
trigger: 'blur',
},
],
remarks: [
{
required: true,
message: '请输入审核意见',
trigger: 'blur',
},
],
},
//
departRange: [],
projRange: [],
//
phoneReg: /^(?:(?:\+|00)86)?1[3-9]\d{9}$/,
testId: 1
}
},
methods: {
/** 校验手机号 */
validatePhone(rule, value, callback) {
if(!this.phoneReg.test(value)) {
callback(new Error('手机号格式不正确'))
} else {
callback()
}
},
getIdList(idList) {
this.exportList = []
console.log(idList)
},
handleAddEdge() {
let setObj = {}
this.$set(setObj, 'testId', this.testId)
this.testId++
this.$set(setObj, 'devName', undefined)
this.$set(setObj, 'devCode', undefined)
this.$set(setObj, 'unitName', undefined)
this.$set(setObj, 'areaName', undefined)
this.$set(setObj, 'devUser', undefined)
this.$set(setObj, 'devUserPhone', undefined)
this.$refs.tableRef.tableList.push(setObj)
},
handleDeleteEdge(v) {
this.$modal
.confirm('是否确认删除该数据项?')
.then(() => {
this.$refs.tableRef.tableList.forEach((item, index) => {
if(item.testId === v.testId) {
this.$refs.tableRef.tableList.splice(index, 1)
}
})
})
.catch(() => {})
},
/** 获取各类下拉框 */
async getRanges() {
//
let deptRes = await queryProjDeptListApi({
isAll: 0
})
this.departRange = deptRes.data.map(item => {
return {
label: item.departName,
value: item.id
}
})
//
let projRes = await queryProjApi({
isAll: 0
})
this.projRange = projRes.data.map(item => {
return {
label: item.proName,
value: item.id
}
})
},
departChange(e) {
this.departRange.forEach(item => {
if(e === item.value) {
this.projectParams.departName = item.label
}
})
},
projChange(e) {
this.projRange.forEach(item => {
if(e === item.value) {
this.projectParams.proName = item.label
}
})
},
/** 改变树结构 */
changeTree(leaf) {
leaf.map(item => {
item.value = item.id
if(item.children) {
this.changeTree(item.children)
}
})
return leaf
},
/** 确认按钮 */
onSubmit() {
console.log(this.$refs.tableRef.tableList, this.projectParams)
this.$refs.projectParamsRef.validate(async valid => {
if (valid) {
this.projectParams.recordList = this.$refs.tableRef.tableList
this.projectParams.auditStatus = 1
// if(this.subSort === 1) {
// let res = await addEdgeDeviceApi(this.projectParams)
// if(res.code === 200) {
// this.$modal.msgSuccess('')
// this.$emit('closeDialog', true)
// }
// } else {
let res = await approveEdgeDeviceApi(this.projectParams)
if(res.code === 200) {
this.$modal.msgSuccess('操作成功')
this.$emit('closeDialogApprove', true)
}
}
})
},
onReturn() {
this.$refs.projectParamsRef.validate(async valid => {
if (valid) {
this.projectParams.recordList = this.$refs.tableRef.tableList
this.projectParams.auditStatus = 2
let res = await approveEdgeDeviceApi(this.projectParams)
if(res.code === 200) {
this.$modal.msgSuccess('操作成功')
this.$emit('closeDialogApprove', true)
}
}
})
},
},
}
</script>
<style scoped>
::v-deep .el-select {
width: 100%;
}
::v-deep .el-form-item__label{
font-weight: normal;
}
.el-textarea {
width: 100%;
height: 100px;
resize: none;
}
</style>

View File

@ -0,0 +1,23 @@
export const formLabelAll = [
{ f_label: '边代名称', f_model: 'departName', f_type: 'ipt' },
{ f_label: '边代编号', f_model: 'departName', f_type: 'ipt' },
{ f_label: '工程名称', f_model: 'headUser', f_type: 'ipt' },
{ f_label: '杆塔编号', f_model: 'headUser', f_type: 'ipt' },
{ f_label: '绑定时间', f_model: 'headUser', f_type: 'date' },
]
export const columnsListAll = [
{ t_props: 'departName', t_label: '申请项目部', },
{ t_props: 'proName', t_label: '工程名称' },
{ t_props: 'bdTotal', t_label: '申请接入数量' },
{ t_props: 'relUser', t_label: '申请人', },
{ t_props: 'relPhone', t_label: '联系方式', t_slot: 'relPhone' },
{ t_props: 'createTime', t_label: '申请时间', },
{ t_props: 'auditStatus', t_label: '申请状态', t_slot: 'auditStatus' },
]
export const dialogConfigAll = {
outerWidth: '70%',
outerTitle: '接入申请明细',
outerVisible: false,
}

View File

@ -0,0 +1,23 @@
export const formLabelApprove = [
{ f_label: '边代名称', f_model: 'departName', f_type: 'ipt' },
{ f_label: '边代编号', f_model: 'departName', f_type: 'ipt' },
{ f_label: '工程名称', f_model: 'headUser', f_type: 'ipt' },
{ f_label: '杆塔编号', f_model: 'headUser', f_type: 'ipt' },
{ f_label: '绑定时间', f_model: 'headUser', f_type: 'date' },
]
export const columnsListApprove = [
{ t_props: 'departName', t_label: '申请项目部', },
{ t_props: 'proName', t_label: '工程名称' },
{ t_props: 'bdTotal', t_label: '申请接入数量' },
{ t_props: 'relUser', t_label: '申请人', },
{ t_props: 'relPhone', t_label: '联系方式', t_slot: 'relPhone' },
{ t_props: 'createTime', t_label: '申请时间', },
{ t_props: 'auditStatus', t_label: '申请状态', t_slot: 'auditStatus' },
]
export const dialogConfigApprove = {
outerWidth: '70%',
outerTitle: '审核',
outerVisible: false,
}

View File

@ -1,9 +1,9 @@
export const columnsListInsert = [
{ t_props: 'devName', t_label: '设备名称', t_slot: 'devName' },
{ t_props: 'devCode', t_label: '设备编码', t_slot: 'devCode' },
{ t_props: 'unitName', t_label: '所属单位', t_slot: 'unitName' },
{ t_props: 'areaName', t_label: '所属区域', t_slot: 'areaName' },
{ t_props: 'devUser', t_label: '设备负责人', t_slot: 'devUser' },
{ t_props: 'devUserPhone', t_label: '负责人电话', t_slot: 'devUserPhone' },
{ t_props: 'devName', t_label: '设备名称', },
{ t_props: 'devCode', t_label: '设备编码', },
{ t_props: 'unitName', t_label: '所属单位', },
{ t_props: 'areaName', t_label: '所属区域', },
{ t_props: 'devUser', t_label: '设备负责人', },
{ t_props: 'devUserPhone', t_label: '负责人电话', },
]

View File

@ -19,4 +19,5 @@ export const dialogConfig = {
outerWidth: '70%',
outerTitle: '',
outerVisible: false,
}
};

View File

@ -29,12 +29,21 @@
<el-button
type="primary"
size="mini"
v-if="data.auditStatus === 1 || data.auditStatus === 2"
@click="handleAllData(data)"
>详情</el-button
>
<el-button
type="primary"
size="mini"
v-if="data.auditStatus === 2"
@click="handleEditData(data)"
>编辑</el-button
>
<el-button
type="primary"
size="mini"
v-if="data.auditStatus === 0"
@click="handleExamData(data)"
>审核</el-button
>
@ -50,9 +59,9 @@
{{ phoneCrypto(data.relPhone) }}
</template>
<template slot="auditStatus" slot-scope="{ data }">
<span v-if="data.auditStatus === 0">审核</span>
<span v-if="data.auditStatus === 1">通过</span>
<span v-if="data.auditStatus === 2">驳回</span>
<span v-if="data.auditStatus === 0">审核</span>
<span v-if="data.auditStatus === 1">通过</span>
<span v-if="data.auditStatus === 2">驳回</span>
</template>
</TableModel>
@ -69,17 +78,49 @@
/>
</template>
</DialogModel>
<!-- 审核时的弹框 -->
<DialogModel
:dialogConfig="dialogConfigApprove"
@closeDialogOuter="closeDialogOuterApprove"
>
<template slot="outerContent">
<!-- 审核的表单组件 -->
<FormApprove
:editParams="editParams"
@closeDialogApprove="closeDialogApprove"
/>
</template>
</DialogModel>
<!-- 详情时的弹框 -->
<DialogModel
:dialogConfig="dialogConfigAll"
@closeDialogOuter="closeDialogOuterAll"
>
<template slot="outerContent">
<!-- 详情的表单组件 -->
<FormAll
:editParams="editParams"
@closeDialogAll="closeDialogAll"
/>
</template>
</DialogModel>
</div>
</template>
<script>
import { formLabel, columnsList, dialogConfig } from './config'
import { formLabel, columnsList, dialogConfig} from './config'
import { dialogConfigApprove} from './config-approve'
import { dialogConfigAll} from './config-all'
import { commonMixin } from '../mixins/common'
import {
queryEdgeDeviceListApi,
deleteEdgeDeviceApi
} from '@/api/base/insert'
import FormInsert from './components/form-insert.vue'
import FormApprove from './components/form-insert-approve.vue'
import FormAll from './components/form-insert-all.vue'
export default {
name: 'ProjectDepart',
methods: {
@ -92,12 +133,39 @@ export default {
})
},
handleExamData(v) {
this.editParams = v
this.dialogConfigApprove.outerVisible = true
this.dialogConfigApprove.outerTitle = '审核'
// this.dialogConfig.dialogWidth = '50%'
// this.dialogConfig.dialogHeight = '50%'
// this.dialogConfig.dialogType = 'exam'
},
handleAllData(v) {
console.log(v)
}
this.editParams = v
this.dialogConfigAll.outerVisible = true
this.dialogConfigAll.outerTitle = '接入申请明细'
},
closeDialogOuterApprove() {
this.dialogConfigApprove.outerVisible = false
this.$refs.tableRef.getTableList()
},
closeDialogApprove() {
this.dialogConfigApprove.outerVisible = false
this.$refs.tableRef.getTableList()
},
closeDialogOuterAll() {
this.dialogConfigAll.outerVisible = false
this.$refs.tableRef.getTableList()
},
closeDialogAll() {
this.dialogConfigAll.outerVisible = false
this.$refs.tableRef.getTableList()
},
},
mixins: [commonMixin],
components: {
FormInsert
FormInsert,FormApprove,FormAll
},
created() {
@ -110,6 +178,8 @@ export default {
exportList: [],
//
columnsList,
dialogConfigApprove,
dialogConfigAll,
//
dialogConfig,
//