Commit 7b81a862 authored by xinzhedeai's avatar xinzhedeai

自然资源 、 水利系统

parent a3fff3e2
<template>
<div class="app-container">
<!--工具栏-->
<!-- <span style="color: red;font-size: 10px;">* 原型图菜单叫监控数据,但其他2处监控叫实时数据,此页面查询的也是最新的测点数据,为措辞统一,这里也叫实时数据了。</span>
<span style="color: red;font-size: 10px;">* 测点类型在新增时是填写的,在这里是选择的?在填过的内容里选择吗?等对接了硬件可能会更清楚这个类型是干什么用的。</span> -->
<div class="head-container">
<div>
<el-input clearable size="small" placeholder="测点名称" style="width: 200px;" class="filter-item" />
<el-select v-model="value" placeholder="测点类型?" style="width: 200px;" class="filter-item">
<el-option label="测点类型?" value="1" />
</el-select>
<el-button class="filter-item" size="mini" type="success" icon="el-icon-search" @click="$message('等待硬件对接中')">搜索</el-button>
<el-button class="filter-item" size="mini" type="warning" icon="el-icon-refresh-left">重置</el-button>
</div>
</div>
<!--表格-->
<el-table ref="table" v-loading="searching" :data="tableData" row-key="id">
<el-table-column :show-overflow-tooltip="true" prop="id" label="编号" width="100px" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="mineName" label="测点名称" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="name" label="测点编号" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="code" label="监测值" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="monitoringType" label="监测时间" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="unit" label="报警状态" align="center" />
</el-table>
<el-pagination
:page-sizes="[10, 20, 50, 100]"
:current-page.sync="searchParam.page"
:page-size.sync="searchParam.count"
:total="searchResult.total"
layout="total, sizes, prev, pager, next, jumper"
@size-change="searchSubmit"
@current-change="searchSubmit"
/>
</div>
</template>
<script>
export default {
name: 'EIotEnvironmentData', // 本页面名
data() {
return {
searching: false,
searchParam: {},
searchResult: {
results: []
}
}
},
computed: {
tableData() {
// 此处对返回值进行算法重组
return this.searchResult.results
}
},
mounted() {
},
methods: {
}
}
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
::v-deep .el-input-number .el-input__inner {
text-align: left;
}
::v-deep .vue-treeselect__control,::v-deep .vue-treeselect__placeholder,::v-deep .vue-treeselect__single-value {
height: 30px;
line-height: 30px;
}
</style>
\ No newline at end of file
<template>
<div class="app-container">
<!--工具栏-->
<div class="head-container">
<div>
<el-input v-model="searchParam.nameLike" clearable size="small" placeholder="测点名称" style="width: 200px;" class="filter-item" />
<el-button class="filter-item" size="mini" type="success" icon="el-icon-search" @click="searchSubmit">搜索</el-button>
<el-button class="filter-item" size="mini" type="warning" icon="el-icon-refresh-left" @click="searchParamReset">重置</el-button>
<el-tooltip class="item" effect="dark" content="按当前查询条件导出" placement="top">
<el-button :loading="exporting" class="filter-item" size="mini" type="info" plain icon="el-icon-download" @click="exportSubmit">导出</el-button>
</el-tooltip>
</div>
<el-button class="filter-item" size="mini" type="primary" icon="el-icon-plus" @click="doAdd()">新增</el-button>
<el-upload
class="filter-item"
action="/api/iot-normal-machine/environment/import"
multiple
:data="{mineType:selectedMine.mineType,mineId:selectedMine.id}"
:headers="httpHeaders"
:before-upload="beforeImport"
:on-success="importSuccess"
:on-error="importError"
:show-file-list="false"
>
<el-button :loading="dialog3Saving" size="mini" type="success" icon="el-icon-upload2">导入</el-button>
</el-upload>
</div>
<!--弹出框1-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog1Show" :title="editState==1?'新增':editState==2?'修改':'查看'" width="960px">
<el-form ref="dialog1Form" :hide-required-asterisk="!dialog1Editing" :model="dialog1Data" :rules="dialog1Rules" size="mini" label-width="180px" style="margin-right: 80px;">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点编号:" prop="code">
<span v-show="!dialog1Editing">{{ dialog1Data.code }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.code" :disabled="editState==2" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="测点名称:" prop="name">
<span v-show="!dialog1Editing">{{ dialog1Data.name }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.name" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点类型:" prop="monitoringType">
<span v-show="!dialog1Editing">{{ (getMonitoringTypeByCode(dialog1Data.code)||{}).name }}</span>
<el-input v-show="dialog1Editing" :disabled="true" :value="(getMonitoringTypeByCode(dialog1Data.code)||{}).name" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="监测点数值类型:" prop="monitoringPointDataType">
<span v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" v-show="!dialog1Editing && item.key==dialog1Data.monitoringPointDataType" :key="item.key">
{{ item.value }}
</span>
<el-select v-show="dialog1Editing" v-model="dialog1Data.monitoringPointDataType" placeholder="请选择" style="width: 100%;">
<el-option v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" :key="item.key" :label="item.value" :value="item.key" />
</el-select>
</el-form-item>
</el-col>
</el-row>
<template v-if="dialog1Data.monitoringPointDataType==2">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点单位:" prop="unit">
<span v-show="!dialog1Editing">{{ dialog1Data.unit }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.unit" maxlength="10" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="量程上限:" prop="rangeMax">
<span v-show="!dialog1Editing">{{ dialog1Data.rangeMax }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.rangeMax" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="量程下限:" prop="rangeMin">
<span v-show="!dialog1Editing">{{ dialog1Data.rangeMin }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.rangeMin" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="报警超上限阈值:" prop="thresholdLevel1">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel1 }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel1" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="报警上限阈值:" prop="thresholdLevel2">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel2 }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel2" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="报警下限阈值:" prop="thresholdLevel2Low">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel2Low }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel2Low" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="报警超下限阈值:" prop="thresholdLevel1Low">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel1Low }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel1Low" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
</template>
<template v-if="dialog1Data.monitoringPointDataType==1">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="开描述:" prop="trueInfo">
<span v-show="!dialog1Editing">{{ dialog1Data.trueInfo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.trueInfo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="停描述:" prop="falseInfo">
<span v-show="!dialog1Editing">{{ dialog1Data.falseInfo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.falseInfo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
</template>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="安装位置:" prop="place">
<span v-show="!dialog1Editing">{{ dialog1Data.place }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.place" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="安装位置描述:" prop="placeNote">
<span v-show="!dialog1Editing">{{ dialog1Data.placeNote }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.placeNote" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="高程:" prop="elevation">
<span v-show="!dialog1Editing">{{ dialog1Data.elevation }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.elevation" :precision="2" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="监测对象:" prop="monitoringTo">
<span v-show="!dialog1Editing">{{ dialog1Data.monitoringTo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.monitoringTo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="经度:" prop="longitude">
<span v-show="!dialog1Editing">{{ dialog1Data.longitude }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.longitude" :precision="6" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="纬度:" prop="latitude">
<span v-show="!dialog1Editing">{{ dialog1Data.latitude }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.latitude" :precision="6" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="24">
<el-form-item v-show="dialog1Editing || dialog1Data.longitude && dialog1Data.latitude" label="位置地图:">
<AMapSearchPoint :is-search="dialog1Editing" :point="mapPoint" @choosePoint="choosePoint" />
</el-form-item>
</el-col>
</el-row>
</el-form>
<div v-show="dialog1Editing" slot="footer" class="dialog-footer">
<el-button type="text" @click="dialog1Show=false">取消</el-button>
<el-button :loading="dialog1Saving" type="primary" @click="dialog1Submit">确认</el-button>
</div>
</el-dialog>
<!--弹出框2-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog2Show" :title="'确认删除'" width="580px">
<div>
<span>确认要环境监测测点吗?</span>
</div>
<div>
<span>测点删除后,此测点的监测数据会一同删除!</span>
</div>
<div slot="footer" class="dialog-footer">
<el-button type="text" @click="dialog2Show=false">取消</el-button>
<el-button :loading="dialog2Saving" type="primary" @click="dialog2Submit">确认</el-button>
</div>
</el-dialog>
<!--弹出框3-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog3Show" :title="'导入结果'" width="580px">
<div>
<span>共计成功导入:</span>
<span style="font-weight: bold;">{{ dialog3Data.successCount + dialog3Data.failCount }}</span>
<span>条,请核对总数。</span>
</div>
<div>
<span>其中,成功:</span>
<span style="color: #67C23A;">{{ dialog3Data.successCount }}</span>
<span>条;失败:</span>
<span style="color: #F56C6C;">{{ dialog3Data.failCount }}</span>
<span>条。</span>
</div>
<br>
<div v-if="dialog3Data.failCount">
<div><span>失败信息:</span></div>
<br>
<div v-for="failReason in dialog3Data.failReasonList" :key="failReason.index">
<span>{{ failReason.index }}条数据</span>
<span v-if="failReason.row" style="font-size: 10px;color: #909399;">{{ failReason.row }}</span>
<span v-if="failReason.col" style="font-size: 10px;color: #909399;">{{ failReason.col }}</span>
<span v-if="failReason.data" style="margin-left: 10px; color: #F56C6C;">{{ failReason.data }}</span>
<span style="margin-left: 10px;">{{ failReason.reason }}</span>
</div>
</div>
</el-dialog>
<!--表格-->
<el-table ref="table" v-loading="searching" :data="tableData" row-key="id">
<el-table-column :show-overflow-tooltip="true" prop="id" label="编号" width="100px" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="code" label="测点编号" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="name" label="测点名称" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="monitoringType" label="测点类型" align="center">
<template slot-scope="scope">
<span>{{ (getMonitoringTypeByCode(scope.row.code)||{}).name }}</span>
</template>
</el-table-column>
<el-table-column :show-overflow-tooltip="true" prop="monitoringPointDataType" label="测点数值类型" align="center">
<template slot-scope="scope">
<span v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" v-show="item.key==scope.row.monitoringPointDataType" :key="item.key">
{{ item.value }}
</span>
</template>
</el-table-column>
<el-table-column :show-overflow-tooltip="true" prop="unit" label="单位" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="xxx" label="状态" align="center" /><!-- TODO 状态 -->
<el-table-column label="操作" width="300px" align="center" fixed="right">
<template slot-scope="scope">
<el-button size="mini" round @click="doEdit(scope.row.id,false)">查看</el-button>
<el-button size="mini" round @click="doEdit(scope.row.id,true)">修改</el-button>
<el-button size="mini" round @click="doDelete(scope.row.id)">删除</el-button>
</template>
</el-table-column>
</el-table>
<el-pagination
:page-sizes="[10, 20, 50, 100]"
:current-page.sync="searchParam.page"
:page-size.sync="searchParam.count"
:total="searchResult.total"
layout="total, sizes, prev, pager, next, jumper"
@size-change="searchSubmit"
@current-change="searchSubmit"
/>
</div>
</template>
<script>
import iotEnvironmentMachineApi from '@/api/kd/iotEnvironmentMachine'
import AMapSearchPoint from '@/components/AMap/AMapSearchPoint'
import { getToken } from '@/utils/auth'
import { mapGetters } from 'vuex'
import { downloadFile } from '@/utils'
const searchParam = {// 默认搜索条件
page: 1,
count: 10,
searchCount: true
}
export default {
name: 'EIotEnvironmentMachine', // 本页面名
components: { AMapSearchPoint },
data() {
return {
selectedMine: {},
httpHeaders: {
'Authorization': getToken()
},
iotEnvironmentMachineApi: iotEnvironmentMachineApi,
searching: false,
exporting: false,
searchParam: {},
searchResult: {
total: 0,
results: [] // 搜索结果
},
dialog1Show: false,
dialog1Editing: false,
dialog1Saving: false,
dialog1Data: {},
dialog1Rules: {
code: [{ required: true, message: '请填写' }],
name: [{ required: true, message: '请填写' }],
monitoringPointDataType: [{ required: true, message: '请选择' }]
},
editState: 0, // (刚打开窗口时)记录了上次窗口作用;(保存编辑时)记录了当前窗口作用; 0无 1新增 2修改 3查看
addingData: {}, // 上次正在新增时的内容,下次打开dialog1窗口时记录下来
dialog2Show: false,
dialog2Saving: false,
dialog2Data: {},
dialog3Show: false,
dialog3Data: {},
dialog3Saving: false
}
},
computed: {
...mapGetters([
'user'
]),
tableData() {
// 此处对返回值进行算法重组
return this.searchResult.results
},
mapPoint() {
if (this.dialog1Data.longitude && this.dialog1Data.latitude) {
return [this.dialog1Data.longitude * 1, this.dialog1Data.latitude * 1]
}
return null
}
},
mounted() {
const selectedMineJson = window.localStorage.getItem('kd.selected.mine')
let noMine = false
if (!selectedMineJson) {
noMine = true
} else {
const selectedMine = JSON.parse(selectedMineJson)
if (!selectedMine || selectedMine.enterpriseId !== this.user.enterpriseId) {
noMine = true
} else {
this.selectedMine = selectedMine
}
}
// if (noMine) {
// this.$message.error('当前未选择矿山')
// this.$router.replace('/dashboard')
// }
this.searchParamReset()
this.searchSubmit()
},
methods: {
searchParamReset() {
this.searchParam = JSON.parse(JSON.stringify(searchParam))
},
searchSubmit() {
this.searching = true
this.searchParam.mineType = this.selectedMine.mineType
this.searchParam.mineId = this.selectedMine.id
iotEnvironmentMachineApi.getPage(this.searchParam).then(response => {
this.searching = false
this.searchResult = response
}).catch(() => {
this.searching = false
})
},
exportSubmit() {
this.exporting = true
this.searchParam.mineType = this.selectedMine.mineType
this.searchParam.mineId = this.selectedMine.id
iotEnvironmentMachineApi.export(this.searchParam).then(response => {
downloadFile(response, '环境监测设备', 'xlsx')
this.exporting = false
}).catch(() => {
this.exporting = false
})
},
getMonitoringTypeByCode(code) {
return iotEnvironmentMachineApi.getMonitoringTypeByCode(code)
},
dialog1Submit() {
this.$refs['dialog1Form'].validate(valid => {
if (!valid) {
return
} else if (!this.getMonitoringTypeByCode(this.dialog1Data.code)) {
this.$message.error('请正确填写编号,需解析出【监测类型】')
} else {
this.dialog1Saving = true
this.removeOtherMonitoringPoint(this.dialog1Data)
if (this.editState === 1) { // 新增
this.dialog1Data.mineType = this.selectedMine.mineType
this.dialog1Data.mineId = this.selectedMine.id
iotEnvironmentMachineApi.add(this.dialog1Data).then(() => {
this.dialog1Show = false
this.$message.success('保存成功')
setTimeout(() => { // 立即清除会导致输入框Validate一闪变红
this.dialog1Data = {}
this.dialog1Saving = false
}, 500)
this.searchSubmit()
}).catch(() => {
this.dialog1Saving = false
})
} else if (this.editState === 2) { // 修改
iotEnvironmentMachineApi.set(this.dialog1Data).then(() => {
this.dialog1Show = false
this.$message.success('修改成功')
setTimeout(() => { // 立即清除会导致输入框Validate一闪变红
this.dialog1Data = {}
this.dialog1Saving = false
}, 500)
this.searchSubmit()
}).catch(() => {
this.dialog1Saving = false
})
} else {
this.$message.error('出错啦,请重试')
this.dialog1Saving = false
}
}
})
},
beforeDialog1Open() { // 窗口打开前的统一操作
if (this.editState === 1) {
this.addingData = this.dialog1Data
}
},
doAdd() {
this.beforeDialog1Open()
this.editState = 1
this.dialog1Editing = true
this.dialog1Data = this.addingData // 初始值:上次编辑的内容
this.dialog1Show = true
this.$nextTick(() => {
this.$refs['dialog1Form'].clearValidate()
})
},
doEdit(id, isEdit) {
this.beforeDialog1Open()
this.editState = isEdit ? 2 : 3
iotEnvironmentMachineApi.getById(id).then(response => {
this.dialog1Data = response
this.dialog1Editing = isEdit
this.dialog1Show = true
this.$nextTick(() => {
this.$refs['dialog1Form'].clearValidate()
})
}).catch(() => {
this.searchSubmit()
})
},
dialog2Submit() {
this.dialog2Saving = true
iotEnvironmentMachineApi.del(this.dialog2Data).then(() => {
this.dialog2Show = false
this.$message.success('删除成功')
this.dialog2Data = {}
this.dialog2Saving = false
this.searchSubmit()
}).catch(() => {
this.dialog2Saving = false
})
},
doDelete(id) {
iotEnvironmentMachineApi.getById(id).then(response => {
this.dialog2Data = response
this.dialog2Show = true
}).catch(() => {
this.searchSubmit()
})
},
choosePoint(lnglat) {
if (lnglat) {
this.$set(this.dialog1Data, 'longitude', lnglat[0])
this.$set(this.dialog1Data, 'latitude', lnglat[1])
} else {
this.$set(this.dialog1Data, 'longitude', null)
this.$set(this.dialog1Data, 'latitude', null)
}
},
beforeImport() {
this.dialog3Saving = true
},
importSuccess(response, file, fileList) {
this.dialog3Data = response
this.dialog3Show = true
this.searchSubmit()
this.dialog3Saving = false
},
importError(error) {
this.$message.error('导入失败')
console.error('导入失败', error)
this.dialog3Saving = false
},
/**
* 按照测点数据类型移除不属于此类型的多余数据。
* 例如:开关量时,移除量程、报警阈值等。
* @param {Object} data 将要提交的machine对象
*/
removeOtherMonitoringPoint(data) {
if (data.monitoringPointDataType !== 1) {
data.trueInfo = null
data.falseInfo = null
}
if (data.monitoringPointDataType !== 2) {
data.unit = null
data.rangeMax = null
data.rangeMin = null
data.thresholdLevel1 = null
data.thresholdLevel2 = null
data.thresholdLevel2Low = null
data.thresholdLevel1Low = null
}
}
}
}
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
::v-deep .el-input-number .el-input__inner {
text-align: left;
}
::v-deep .vue-treeselect__control,::v-deep .vue-treeselect__placeholder,::v-deep .vue-treeselect__single-value {
height: 30px;
line-height: 30px;
}
</style>
<template>
<div class="app-container">
<!--工具栏-->
<!-- <span style="color: red;font-size: 10px;">* 原型图菜单叫监控数据,但其他2处监控叫实时数据,此页面查询的也是最新的测点数据,为措辞统一,这里也叫实时数据了。</span>
<span style="color: red;font-size: 10px;">* 测点类型在新增时是填写的,在这里是选择的?在填过的内容里选择吗?等对接了硬件可能会更清楚这个类型是干什么用的。</span> -->
<div class="head-container">
<div>
<el-input clearable size="small" placeholder="测点名称" style="width: 200px;" class="filter-item" />
<el-select v-model="value" placeholder="测点类型?" style="width: 200px;" class="filter-item">
<el-option label="测点类型?" value="1" />
</el-select>
<el-button class="filter-item" size="mini" type="success" icon="el-icon-search" @click="$message('等待硬件对接中')">搜索</el-button>
<el-button class="filter-item" size="mini" type="warning" icon="el-icon-refresh-left">重置</el-button>
</div>
</div>
<!--表格-->
<el-table ref="table" v-loading="searching" :data="tableData" row-key="id">
<el-table-column :show-overflow-tooltip="true" prop="id" label="编号" width="100px" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="mineName" label="测点名称" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="name" label="测点编号" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="code" label="监测值" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="monitoringType" label="监测时间" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="unit" label="报警状态" align="center" />
</el-table>
<el-pagination
:page-sizes="[10, 20, 50, 100]"
:current-page.sync="searchParam.page"
:page-size.sync="searchParam.count"
:total="searchResult.total"
layout="total, sizes, prev, pager, next, jumper"
@size-change="searchSubmit"
@current-change="searchSubmit"
/>
</div>
</template>
<script>
export default {
name: 'EIotEnvironmentData', // 本页面名
data() {
return {
searching: false,
searchParam: {},
searchResult: {
results: []
}
}
},
computed: {
tableData() {
// 此处对返回值进行算法重组
return this.searchResult.results
}
},
mounted() {
},
methods: {
}
}
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
::v-deep .el-input-number .el-input__inner {
text-align: left;
}
::v-deep .vue-treeselect__control,::v-deep .vue-treeselect__placeholder,::v-deep .vue-treeselect__single-value {
height: 30px;
line-height: 30px;
}
</style>
\ No newline at end of file
<template>
<div class="app-container">
<!--工具栏-->
<div class="head-container">
<div>
<el-input v-model="searchParam.nameLike" clearable size="small" placeholder="测点名称" style="width: 200px;" class="filter-item" />
<el-button class="filter-item" size="mini" type="success" icon="el-icon-search" @click="searchSubmit">搜索</el-button>
<el-button class="filter-item" size="mini" type="warning" icon="el-icon-refresh-left" @click="searchParamReset">重置</el-button>
<el-tooltip class="item" effect="dark" content="按当前查询条件导出" placement="top">
<el-button :loading="exporting" class="filter-item" size="mini" type="info" plain icon="el-icon-download" @click="exportSubmit">导出</el-button>
</el-tooltip>
</div>
<el-button class="filter-item" size="mini" type="primary" icon="el-icon-plus" @click="doAdd()">新增</el-button>
<el-upload
class="filter-item"
action="/api/iot-normal-machine/environment/import"
multiple
:data="{mineType:selectedMine.mineType,mineId:selectedMine.id}"
:headers="httpHeaders"
:before-upload="beforeImport"
:on-success="importSuccess"
:on-error="importError"
:show-file-list="false"
>
<el-button :loading="dialog3Saving" size="mini" type="success" icon="el-icon-upload2">导入</el-button>
</el-upload>
</div>
<!--弹出框1-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog1Show" :title="editState==1?'新增':editState==2?'修改':'查看'" width="960px">
<el-form ref="dialog1Form" :hide-required-asterisk="!dialog1Editing" :model="dialog1Data" :rules="dialog1Rules" size="mini" label-width="180px" style="margin-right: 80px;">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点编号:" prop="code">
<span v-show="!dialog1Editing">{{ dialog1Data.code }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.code" :disabled="editState==2" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="测点名称:" prop="name">
<span v-show="!dialog1Editing">{{ dialog1Data.name }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.name" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点类型:" prop="monitoringType">
<span v-show="!dialog1Editing">{{ (getMonitoringTypeByCode(dialog1Data.code)||{}).name }}</span>
<el-input v-show="dialog1Editing" :disabled="true" :value="(getMonitoringTypeByCode(dialog1Data.code)||{}).name" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="监测点数值类型:" prop="monitoringPointDataType">
<span v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" v-show="!dialog1Editing && item.key==dialog1Data.monitoringPointDataType" :key="item.key">
{{ item.value }}
</span>
<el-select v-show="dialog1Editing" v-model="dialog1Data.monitoringPointDataType" placeholder="请选择" style="width: 100%;">
<el-option v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" :key="item.key" :label="item.value" :value="item.key" />
</el-select>
</el-form-item>
</el-col>
</el-row>
<template v-if="dialog1Data.monitoringPointDataType==2">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点单位:" prop="unit">
<span v-show="!dialog1Editing">{{ dialog1Data.unit }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.unit" maxlength="10" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="量程上限:" prop="rangeMax">
<span v-show="!dialog1Editing">{{ dialog1Data.rangeMax }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.rangeMax" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="量程下限:" prop="rangeMin">
<span v-show="!dialog1Editing">{{ dialog1Data.rangeMin }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.rangeMin" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="报警超上限阈值:" prop="thresholdLevel1">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel1 }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel1" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="报警上限阈值:" prop="thresholdLevel2">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel2 }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel2" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="报警下限阈值:" prop="thresholdLevel2Low">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel2Low }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel2Low" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="报警超下限阈值:" prop="thresholdLevel1Low">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel1Low }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel1Low" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
</template>
<template v-if="dialog1Data.monitoringPointDataType==1">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="开描述:" prop="trueInfo">
<span v-show="!dialog1Editing">{{ dialog1Data.trueInfo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.trueInfo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="停描述:" prop="falseInfo">
<span v-show="!dialog1Editing">{{ dialog1Data.falseInfo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.falseInfo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
</template>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="安装位置:" prop="place">
<span v-show="!dialog1Editing">{{ dialog1Data.place }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.place" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="安装位置描述:" prop="placeNote">
<span v-show="!dialog1Editing">{{ dialog1Data.placeNote }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.placeNote" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="高程:" prop="elevation">
<span v-show="!dialog1Editing">{{ dialog1Data.elevation }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.elevation" :precision="2" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="监测对象:" prop="monitoringTo">
<span v-show="!dialog1Editing">{{ dialog1Data.monitoringTo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.monitoringTo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="经度:" prop="longitude">
<span v-show="!dialog1Editing">{{ dialog1Data.longitude }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.longitude" :precision="6" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="纬度:" prop="latitude">
<span v-show="!dialog1Editing">{{ dialog1Data.latitude }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.latitude" :precision="6" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="24">
<el-form-item v-show="dialog1Editing || dialog1Data.longitude && dialog1Data.latitude" label="位置地图:">
<AMapSearchPoint :is-search="dialog1Editing" :point="mapPoint" @choosePoint="choosePoint" />
</el-form-item>
</el-col>
</el-row>
</el-form>
<div v-show="dialog1Editing" slot="footer" class="dialog-footer">
<el-button type="text" @click="dialog1Show=false">取消</el-button>
<el-button :loading="dialog1Saving" type="primary" @click="dialog1Submit">确认</el-button>
</div>
</el-dialog>
<!--弹出框2-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog2Show" :title="'确认删除'" width="580px">
<div>
<span>确认要环境监测测点吗?</span>
</div>
<div>
<span>测点删除后,此测点的监测数据会一同删除!</span>
</div>
<div slot="footer" class="dialog-footer">
<el-button type="text" @click="dialog2Show=false">取消</el-button>
<el-button :loading="dialog2Saving" type="primary" @click="dialog2Submit">确认</el-button>
</div>
</el-dialog>
<!--弹出框3-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog3Show" :title="'导入结果'" width="580px">
<div>
<span>共计成功导入:</span>
<span style="font-weight: bold;">{{ dialog3Data.successCount + dialog3Data.failCount }}</span>
<span>条,请核对总数。</span>
</div>
<div>
<span>其中,成功:</span>
<span style="color: #67C23A;">{{ dialog3Data.successCount }}</span>
<span>条;失败:</span>
<span style="color: #F56C6C;">{{ dialog3Data.failCount }}</span>
<span>条。</span>
</div>
<br>
<div v-if="dialog3Data.failCount">
<div><span>失败信息:</span></div>
<br>
<div v-for="failReason in dialog3Data.failReasonList" :key="failReason.index">
<span>{{ failReason.index }}条数据</span>
<span v-if="failReason.row" style="font-size: 10px;color: #909399;">{{ failReason.row }}</span>
<span v-if="failReason.col" style="font-size: 10px;color: #909399;">{{ failReason.col }}</span>
<span v-if="failReason.data" style="margin-left: 10px; color: #F56C6C;">{{ failReason.data }}</span>
<span style="margin-left: 10px;">{{ failReason.reason }}</span>
</div>
</div>
</el-dialog>
<!--表格-->
<el-table ref="table" v-loading="searching" :data="tableData" row-key="id">
<el-table-column :show-overflow-tooltip="true" prop="id" label="编号" width="100px" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="code" label="测点编号" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="name" label="测点名称" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="monitoringType" label="测点类型" align="center">
<template slot-scope="scope">
<span>{{ (getMonitoringTypeByCode(scope.row.code)||{}).name }}</span>
</template>
</el-table-column>
<el-table-column :show-overflow-tooltip="true" prop="monitoringPointDataType" label="测点数值类型" align="center">
<template slot-scope="scope">
<span v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" v-show="item.key==scope.row.monitoringPointDataType" :key="item.key">
{{ item.value }}
</span>
</template>
</el-table-column>
<el-table-column :show-overflow-tooltip="true" prop="unit" label="单位" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="xxx" label="状态" align="center" /><!-- TODO 状态 -->
<el-table-column label="操作" width="300px" align="center" fixed="right">
<template slot-scope="scope">
<el-button size="mini" round @click="doEdit(scope.row.id,false)">查看</el-button>
<el-button size="mini" round @click="doEdit(scope.row.id,true)">修改</el-button>
<el-button size="mini" round @click="doDelete(scope.row.id)">删除</el-button>
</template>
</el-table-column>
</el-table>
<el-pagination
:page-sizes="[10, 20, 50, 100]"
:current-page.sync="searchParam.page"
:page-size.sync="searchParam.count"
:total="searchResult.total"
layout="total, sizes, prev, pager, next, jumper"
@size-change="searchSubmit"
@current-change="searchSubmit"
/>
</div>
</template>
<script>
import iotEnvironmentMachineApi from '@/api/kd/iotEnvironmentMachine'
import AMapSearchPoint from '@/components/AMap/AMapSearchPoint'
import { getToken } from '@/utils/auth'
import { mapGetters } from 'vuex'
import { downloadFile } from '@/utils'
const searchParam = {// 默认搜索条件
page: 1,
count: 10,
searchCount: true
}
export default {
name: 'EIotEnvironmentMachine', // 本页面名
components: { AMapSearchPoint },
data() {
return {
selectedMine: {},
httpHeaders: {
'Authorization': getToken()
},
iotEnvironmentMachineApi: iotEnvironmentMachineApi,
searching: false,
exporting: false,
searchParam: {},
searchResult: {
total: 0,
results: [] // 搜索结果
},
dialog1Show: false,
dialog1Editing: false,
dialog1Saving: false,
dialog1Data: {},
dialog1Rules: {
code: [{ required: true, message: '请填写' }],
name: [{ required: true, message: '请填写' }],
monitoringPointDataType: [{ required: true, message: '请选择' }]
},
editState: 0, // (刚打开窗口时)记录了上次窗口作用;(保存编辑时)记录了当前窗口作用; 0无 1新增 2修改 3查看
addingData: {}, // 上次正在新增时的内容,下次打开dialog1窗口时记录下来
dialog2Show: false,
dialog2Saving: false,
dialog2Data: {},
dialog3Show: false,
dialog3Data: {},
dialog3Saving: false
}
},
computed: {
...mapGetters([
'user'
]),
tableData() {
// 此处对返回值进行算法重组
return this.searchResult.results
},
mapPoint() {
if (this.dialog1Data.longitude && this.dialog1Data.latitude) {
return [this.dialog1Data.longitude * 1, this.dialog1Data.latitude * 1]
}
return null
}
},
mounted() {
const selectedMineJson = window.localStorage.getItem('kd.selected.mine')
let noMine = false
if (!selectedMineJson) {
noMine = true
} else {
const selectedMine = JSON.parse(selectedMineJson)
if (!selectedMine || selectedMine.enterpriseId !== this.user.enterpriseId) {
noMine = true
} else {
this.selectedMine = selectedMine
}
}
// if (noMine) {
// this.$message.error('当前未选择矿山')
// this.$router.replace('/dashboard')
// }
this.searchParamReset()
this.searchSubmit()
},
methods: {
searchParamReset() {
this.searchParam = JSON.parse(JSON.stringify(searchParam))
},
searchSubmit() {
this.searching = true
this.searchParam.mineType = this.selectedMine.mineType
this.searchParam.mineId = this.selectedMine.id
iotEnvironmentMachineApi.getPage(this.searchParam).then(response => {
this.searching = false
this.searchResult = response
}).catch(() => {
this.searching = false
})
},
exportSubmit() {
this.exporting = true
this.searchParam.mineType = this.selectedMine.mineType
this.searchParam.mineId = this.selectedMine.id
iotEnvironmentMachineApi.export(this.searchParam).then(response => {
downloadFile(response, '环境监测设备', 'xlsx')
this.exporting = false
}).catch(() => {
this.exporting = false
})
},
getMonitoringTypeByCode(code) {
return iotEnvironmentMachineApi.getMonitoringTypeByCode(code)
},
dialog1Submit() {
this.$refs['dialog1Form'].validate(valid => {
if (!valid) {
return
} else if (!this.getMonitoringTypeByCode(this.dialog1Data.code)) {
this.$message.error('请正确填写编号,需解析出【监测类型】')
} else {
this.dialog1Saving = true
this.removeOtherMonitoringPoint(this.dialog1Data)
if (this.editState === 1) { // 新增
this.dialog1Data.mineType = this.selectedMine.mineType
this.dialog1Data.mineId = this.selectedMine.id
iotEnvironmentMachineApi.add(this.dialog1Data).then(() => {
this.dialog1Show = false
this.$message.success('保存成功')
setTimeout(() => { // 立即清除会导致输入框Validate一闪变红
this.dialog1Data = {}
this.dialog1Saving = false
}, 500)
this.searchSubmit()
}).catch(() => {
this.dialog1Saving = false
})
} else if (this.editState === 2) { // 修改
iotEnvironmentMachineApi.set(this.dialog1Data).then(() => {
this.dialog1Show = false
this.$message.success('修改成功')
setTimeout(() => { // 立即清除会导致输入框Validate一闪变红
this.dialog1Data = {}
this.dialog1Saving = false
}, 500)
this.searchSubmit()
}).catch(() => {
this.dialog1Saving = false
})
} else {
this.$message.error('出错啦,请重试')
this.dialog1Saving = false
}
}
})
},
beforeDialog1Open() { // 窗口打开前的统一操作
if (this.editState === 1) {
this.addingData = this.dialog1Data
}
},
doAdd() {
this.beforeDialog1Open()
this.editState = 1
this.dialog1Editing = true
this.dialog1Data = this.addingData // 初始值:上次编辑的内容
this.dialog1Show = true
this.$nextTick(() => {
this.$refs['dialog1Form'].clearValidate()
})
},
doEdit(id, isEdit) {
this.beforeDialog1Open()
this.editState = isEdit ? 2 : 3
iotEnvironmentMachineApi.getById(id).then(response => {
this.dialog1Data = response
this.dialog1Editing = isEdit
this.dialog1Show = true
this.$nextTick(() => {
this.$refs['dialog1Form'].clearValidate()
})
}).catch(() => {
this.searchSubmit()
})
},
dialog2Submit() {
this.dialog2Saving = true
iotEnvironmentMachineApi.del(this.dialog2Data).then(() => {
this.dialog2Show = false
this.$message.success('删除成功')
this.dialog2Data = {}
this.dialog2Saving = false
this.searchSubmit()
}).catch(() => {
this.dialog2Saving = false
})
},
doDelete(id) {
iotEnvironmentMachineApi.getById(id).then(response => {
this.dialog2Data = response
this.dialog2Show = true
}).catch(() => {
this.searchSubmit()
})
},
choosePoint(lnglat) {
if (lnglat) {
this.$set(this.dialog1Data, 'longitude', lnglat[0])
this.$set(this.dialog1Data, 'latitude', lnglat[1])
} else {
this.$set(this.dialog1Data, 'longitude', null)
this.$set(this.dialog1Data, 'latitude', null)
}
},
beforeImport() {
this.dialog3Saving = true
},
importSuccess(response, file, fileList) {
this.dialog3Data = response
this.dialog3Show = true
this.searchSubmit()
this.dialog3Saving = false
},
importError(error) {
this.$message.error('导入失败')
console.error('导入失败', error)
this.dialog3Saving = false
},
/**
* 按照测点数据类型移除不属于此类型的多余数据。
* 例如:开关量时,移除量程、报警阈值等。
* @param {Object} data 将要提交的machine对象
*/
removeOtherMonitoringPoint(data) {
if (data.monitoringPointDataType !== 1) {
data.trueInfo = null
data.falseInfo = null
}
if (data.monitoringPointDataType !== 2) {
data.unit = null
data.rangeMax = null
data.rangeMin = null
data.thresholdLevel1 = null
data.thresholdLevel2 = null
data.thresholdLevel2Low = null
data.thresholdLevel1Low = null
}
}
}
}
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
::v-deep .el-input-number .el-input__inner {
text-align: left;
}
::v-deep .vue-treeselect__control,::v-deep .vue-treeselect__placeholder,::v-deep .vue-treeselect__single-value {
height: 30px;
line-height: 30px;
}
</style>
<template>
<div class="app-container">
<!--工具栏-->
<!-- <span style="color: red;font-size: 10px;">* 原型图菜单叫监控数据,但其他2处监控叫实时数据,此页面查询的也是最新的测点数据,为措辞统一,这里也叫实时数据了。</span>
<span style="color: red;font-size: 10px;">* 测点类型在新增时是填写的,在这里是选择的?在填过的内容里选择吗?等对接了硬件可能会更清楚这个类型是干什么用的。</span> -->
<div class="head-container">
<div>
<el-input clearable size="small" placeholder="测点名称" style="width: 200px;" class="filter-item" />
<el-select v-model="value" placeholder="测点类型?" style="width: 200px;" class="filter-item">
<el-option label="测点类型?" value="1" />
</el-select>
<el-button class="filter-item" size="mini" type="success" icon="el-icon-search" @click="$message('等待硬件对接中')">搜索</el-button>
<el-button class="filter-item" size="mini" type="warning" icon="el-icon-refresh-left">重置</el-button>
</div>
</div>
<!--表格-->
<el-table ref="table" v-loading="searching" :data="tableData" row-key="id">
<el-table-column :show-overflow-tooltip="true" prop="id" label="编号" width="100px" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="mineName" label="测点名称" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="name" label="测点编号" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="code" label="监测值" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="monitoringType" label="监测时间" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="unit" label="报警状态" align="center" />
</el-table>
<el-pagination
:page-sizes="[10, 20, 50, 100]"
:current-page.sync="searchParam.page"
:page-size.sync="searchParam.count"
:total="searchResult.total"
layout="total, sizes, prev, pager, next, jumper"
@size-change="searchSubmit"
@current-change="searchSubmit"
/>
</div>
</template>
<script>
export default {
name: 'EIotEnvironmentData', // 本页面名
data() {
return {
searching: false,
searchParam: {},
searchResult: {
results: []
}
}
},
computed: {
tableData() {
// 此处对返回值进行算法重组
return this.searchResult.results
}
},
mounted() {
},
methods: {
}
}
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
::v-deep .el-input-number .el-input__inner {
text-align: left;
}
::v-deep .vue-treeselect__control,::v-deep .vue-treeselect__placeholder,::v-deep .vue-treeselect__single-value {
height: 30px;
line-height: 30px;
}
</style>
\ No newline at end of file
<template>
<div class="app-container">
<!--工具栏-->
<div class="head-container">
<div>
<el-input v-model="searchParam.nameLike" clearable size="small" placeholder="测点名称" style="width: 200px;" class="filter-item" />
<el-button class="filter-item" size="mini" type="success" icon="el-icon-search" @click="searchSubmit">搜索</el-button>
<el-button class="filter-item" size="mini" type="warning" icon="el-icon-refresh-left" @click="searchParamReset">重置</el-button>
<el-tooltip class="item" effect="dark" content="按当前查询条件导出" placement="top">
<el-button :loading="exporting" class="filter-item" size="mini" type="info" plain icon="el-icon-download" @click="exportSubmit">导出</el-button>
</el-tooltip>
</div>
<el-button class="filter-item" size="mini" type="primary" icon="el-icon-plus" @click="doAdd()">新增</el-button>
<el-upload
class="filter-item"
action="/api/iot-normal-machine/environment/import"
multiple
:data="{mineType:selectedMine.mineType,mineId:selectedMine.id}"
:headers="httpHeaders"
:before-upload="beforeImport"
:on-success="importSuccess"
:on-error="importError"
:show-file-list="false"
>
<el-button :loading="dialog3Saving" size="mini" type="success" icon="el-icon-upload2">导入</el-button>
</el-upload>
</div>
<!--弹出框1-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog1Show" :title="editState==1?'新增':editState==2?'修改':'查看'" width="960px">
<el-form ref="dialog1Form" :hide-required-asterisk="!dialog1Editing" :model="dialog1Data" :rules="dialog1Rules" size="mini" label-width="180px" style="margin-right: 80px;">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点编号:" prop="code">
<span v-show="!dialog1Editing">{{ dialog1Data.code }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.code" :disabled="editState==2" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="测点名称:" prop="name">
<span v-show="!dialog1Editing">{{ dialog1Data.name }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.name" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点类型:" prop="monitoringType">
<span v-show="!dialog1Editing">{{ (getMonitoringTypeByCode(dialog1Data.code)||{}).name }}</span>
<el-input v-show="dialog1Editing" :disabled="true" :value="(getMonitoringTypeByCode(dialog1Data.code)||{}).name" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="监测点数值类型:" prop="monitoringPointDataType">
<span v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" v-show="!dialog1Editing && item.key==dialog1Data.monitoringPointDataType" :key="item.key">
{{ item.value }}
</span>
<el-select v-show="dialog1Editing" v-model="dialog1Data.monitoringPointDataType" placeholder="请选择" style="width: 100%;">
<el-option v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" :key="item.key" :label="item.value" :value="item.key" />
</el-select>
</el-form-item>
</el-col>
</el-row>
<template v-if="dialog1Data.monitoringPointDataType==2">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点单位:" prop="unit">
<span v-show="!dialog1Editing">{{ dialog1Data.unit }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.unit" maxlength="10" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="量程上限:" prop="rangeMax">
<span v-show="!dialog1Editing">{{ dialog1Data.rangeMax }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.rangeMax" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="量程下限:" prop="rangeMin">
<span v-show="!dialog1Editing">{{ dialog1Data.rangeMin }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.rangeMin" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="报警超上限阈值:" prop="thresholdLevel1">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel1 }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel1" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="报警上限阈值:" prop="thresholdLevel2">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel2 }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel2" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="报警下限阈值:" prop="thresholdLevel2Low">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel2Low }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel2Low" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="报警超下限阈值:" prop="thresholdLevel1Low">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel1Low }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel1Low" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
</template>
<template v-if="dialog1Data.monitoringPointDataType==1">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="开描述:" prop="trueInfo">
<span v-show="!dialog1Editing">{{ dialog1Data.trueInfo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.trueInfo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="停描述:" prop="falseInfo">
<span v-show="!dialog1Editing">{{ dialog1Data.falseInfo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.falseInfo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
</template>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="安装位置:" prop="place">
<span v-show="!dialog1Editing">{{ dialog1Data.place }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.place" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="安装位置描述:" prop="placeNote">
<span v-show="!dialog1Editing">{{ dialog1Data.placeNote }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.placeNote" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="高程:" prop="elevation">
<span v-show="!dialog1Editing">{{ dialog1Data.elevation }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.elevation" :precision="2" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="监测对象:" prop="monitoringTo">
<span v-show="!dialog1Editing">{{ dialog1Data.monitoringTo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.monitoringTo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="经度:" prop="longitude">
<span v-show="!dialog1Editing">{{ dialog1Data.longitude }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.longitude" :precision="6" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="纬度:" prop="latitude">
<span v-show="!dialog1Editing">{{ dialog1Data.latitude }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.latitude" :precision="6" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="24">
<el-form-item v-show="dialog1Editing || dialog1Data.longitude && dialog1Data.latitude" label="位置地图:">
<AMapSearchPoint :is-search="dialog1Editing" :point="mapPoint" @choosePoint="choosePoint" />
</el-form-item>
</el-col>
</el-row>
</el-form>
<div v-show="dialog1Editing" slot="footer" class="dialog-footer">
<el-button type="text" @click="dialog1Show=false">取消</el-button>
<el-button :loading="dialog1Saving" type="primary" @click="dialog1Submit">确认</el-button>
</div>
</el-dialog>
<!--弹出框2-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog2Show" :title="'确认删除'" width="580px">
<div>
<span>确认要环境监测测点吗?</span>
</div>
<div>
<span>测点删除后,此测点的监测数据会一同删除!</span>
</div>
<div slot="footer" class="dialog-footer">
<el-button type="text" @click="dialog2Show=false">取消</el-button>
<el-button :loading="dialog2Saving" type="primary" @click="dialog2Submit">确认</el-button>
</div>
</el-dialog>
<!--弹出框3-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog3Show" :title="'导入结果'" width="580px">
<div>
<span>共计成功导入:</span>
<span style="font-weight: bold;">{{ dialog3Data.successCount + dialog3Data.failCount }}</span>
<span>条,请核对总数。</span>
</div>
<div>
<span>其中,成功:</span>
<span style="color: #67C23A;">{{ dialog3Data.successCount }}</span>
<span>条;失败:</span>
<span style="color: #F56C6C;">{{ dialog3Data.failCount }}</span>
<span>条。</span>
</div>
<br>
<div v-if="dialog3Data.failCount">
<div><span>失败信息:</span></div>
<br>
<div v-for="failReason in dialog3Data.failReasonList" :key="failReason.index">
<span>{{ failReason.index }}条数据</span>
<span v-if="failReason.row" style="font-size: 10px;color: #909399;">{{ failReason.row }}</span>
<span v-if="failReason.col" style="font-size: 10px;color: #909399;">{{ failReason.col }}</span>
<span v-if="failReason.data" style="margin-left: 10px; color: #F56C6C;">{{ failReason.data }}</span>
<span style="margin-left: 10px;">{{ failReason.reason }}</span>
</div>
</div>
</el-dialog>
<!--表格-->
<el-table ref="table" v-loading="searching" :data="tableData" row-key="id">
<el-table-column :show-overflow-tooltip="true" prop="id" label="编号" width="100px" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="code" label="测点编号" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="name" label="测点名称" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="monitoringType" label="测点类型" align="center">
<template slot-scope="scope">
<span>{{ (getMonitoringTypeByCode(scope.row.code)||{}).name }}</span>
</template>
</el-table-column>
<el-table-column :show-overflow-tooltip="true" prop="monitoringPointDataType" label="测点数值类型" align="center">
<template slot-scope="scope">
<span v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" v-show="item.key==scope.row.monitoringPointDataType" :key="item.key">
{{ item.value }}
</span>
</template>
</el-table-column>
<el-table-column :show-overflow-tooltip="true" prop="unit" label="单位" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="xxx" label="状态" align="center" /><!-- TODO 状态 -->
<el-table-column label="操作" width="300px" align="center" fixed="right">
<template slot-scope="scope">
<el-button size="mini" round @click="doEdit(scope.row.id,false)">查看</el-button>
<el-button size="mini" round @click="doEdit(scope.row.id,true)">修改</el-button>
<el-button size="mini" round @click="doDelete(scope.row.id)">删除</el-button>
</template>
</el-table-column>
</el-table>
<el-pagination
:page-sizes="[10, 20, 50, 100]"
:current-page.sync="searchParam.page"
:page-size.sync="searchParam.count"
:total="searchResult.total"
layout="total, sizes, prev, pager, next, jumper"
@size-change="searchSubmit"
@current-change="searchSubmit"
/>
</div>
</template>
<script>
import iotEnvironmentMachineApi from '@/api/kd/iotEnvironmentMachine'
import AMapSearchPoint from '@/components/AMap/AMapSearchPoint'
import { getToken } from '@/utils/auth'
import { mapGetters } from 'vuex'
import { downloadFile } from '@/utils'
const searchParam = {// 默认搜索条件
page: 1,
count: 10,
searchCount: true
}
export default {
name: 'EIotEnvironmentMachine', // 本页面名
components: { AMapSearchPoint },
data() {
return {
selectedMine: {},
httpHeaders: {
'Authorization': getToken()
},
iotEnvironmentMachineApi: iotEnvironmentMachineApi,
searching: false,
exporting: false,
searchParam: {},
searchResult: {
total: 0,
results: [] // 搜索结果
},
dialog1Show: false,
dialog1Editing: false,
dialog1Saving: false,
dialog1Data: {},
dialog1Rules: {
code: [{ required: true, message: '请填写' }],
name: [{ required: true, message: '请填写' }],
monitoringPointDataType: [{ required: true, message: '请选择' }]
},
editState: 0, // (刚打开窗口时)记录了上次窗口作用;(保存编辑时)记录了当前窗口作用; 0无 1新增 2修改 3查看
addingData: {}, // 上次正在新增时的内容,下次打开dialog1窗口时记录下来
dialog2Show: false,
dialog2Saving: false,
dialog2Data: {},
dialog3Show: false,
dialog3Data: {},
dialog3Saving: false
}
},
computed: {
...mapGetters([
'user'
]),
tableData() {
// 此处对返回值进行算法重组
return this.searchResult.results
},
mapPoint() {
if (this.dialog1Data.longitude && this.dialog1Data.latitude) {
return [this.dialog1Data.longitude * 1, this.dialog1Data.latitude * 1]
}
return null
}
},
mounted() {
const selectedMineJson = window.localStorage.getItem('kd.selected.mine')
let noMine = false
if (!selectedMineJson) {
noMine = true
} else {
const selectedMine = JSON.parse(selectedMineJson)
if (!selectedMine || selectedMine.enterpriseId !== this.user.enterpriseId) {
noMine = true
} else {
this.selectedMine = selectedMine
}
}
// if (noMine) {
// this.$message.error('当前未选择矿山')
// this.$router.replace('/dashboard')
// }
this.searchParamReset()
this.searchSubmit()
},
methods: {
searchParamReset() {
this.searchParam = JSON.parse(JSON.stringify(searchParam))
},
searchSubmit() {
this.searching = true
this.searchParam.mineType = this.selectedMine.mineType
this.searchParam.mineId = this.selectedMine.id
iotEnvironmentMachineApi.getPage(this.searchParam).then(response => {
this.searching = false
this.searchResult = response
}).catch(() => {
this.searching = false
})
},
exportSubmit() {
this.exporting = true
this.searchParam.mineType = this.selectedMine.mineType
this.searchParam.mineId = this.selectedMine.id
iotEnvironmentMachineApi.export(this.searchParam).then(response => {
downloadFile(response, '环境监测设备', 'xlsx')
this.exporting = false
}).catch(() => {
this.exporting = false
})
},
getMonitoringTypeByCode(code) {
return iotEnvironmentMachineApi.getMonitoringTypeByCode(code)
},
dialog1Submit() {
this.$refs['dialog1Form'].validate(valid => {
if (!valid) {
return
} else if (!this.getMonitoringTypeByCode(this.dialog1Data.code)) {
this.$message.error('请正确填写编号,需解析出【监测类型】')
} else {
this.dialog1Saving = true
this.removeOtherMonitoringPoint(this.dialog1Data)
if (this.editState === 1) { // 新增
this.dialog1Data.mineType = this.selectedMine.mineType
this.dialog1Data.mineId = this.selectedMine.id
iotEnvironmentMachineApi.add(this.dialog1Data).then(() => {
this.dialog1Show = false
this.$message.success('保存成功')
setTimeout(() => { // 立即清除会导致输入框Validate一闪变红
this.dialog1Data = {}
this.dialog1Saving = false
}, 500)
this.searchSubmit()
}).catch(() => {
this.dialog1Saving = false
})
} else if (this.editState === 2) { // 修改
iotEnvironmentMachineApi.set(this.dialog1Data).then(() => {
this.dialog1Show = false
this.$message.success('修改成功')
setTimeout(() => { // 立即清除会导致输入框Validate一闪变红
this.dialog1Data = {}
this.dialog1Saving = false
}, 500)
this.searchSubmit()
}).catch(() => {
this.dialog1Saving = false
})
} else {
this.$message.error('出错啦,请重试')
this.dialog1Saving = false
}
}
})
},
beforeDialog1Open() { // 窗口打开前的统一操作
if (this.editState === 1) {
this.addingData = this.dialog1Data
}
},
doAdd() {
this.beforeDialog1Open()
this.editState = 1
this.dialog1Editing = true
this.dialog1Data = this.addingData // 初始值:上次编辑的内容
this.dialog1Show = true
this.$nextTick(() => {
this.$refs['dialog1Form'].clearValidate()
})
},
doEdit(id, isEdit) {
this.beforeDialog1Open()
this.editState = isEdit ? 2 : 3
iotEnvironmentMachineApi.getById(id).then(response => {
this.dialog1Data = response
this.dialog1Editing = isEdit
this.dialog1Show = true
this.$nextTick(() => {
this.$refs['dialog1Form'].clearValidate()
})
}).catch(() => {
this.searchSubmit()
})
},
dialog2Submit() {
this.dialog2Saving = true
iotEnvironmentMachineApi.del(this.dialog2Data).then(() => {
this.dialog2Show = false
this.$message.success('删除成功')
this.dialog2Data = {}
this.dialog2Saving = false
this.searchSubmit()
}).catch(() => {
this.dialog2Saving = false
})
},
doDelete(id) {
iotEnvironmentMachineApi.getById(id).then(response => {
this.dialog2Data = response
this.dialog2Show = true
}).catch(() => {
this.searchSubmit()
})
},
choosePoint(lnglat) {
if (lnglat) {
this.$set(this.dialog1Data, 'longitude', lnglat[0])
this.$set(this.dialog1Data, 'latitude', lnglat[1])
} else {
this.$set(this.dialog1Data, 'longitude', null)
this.$set(this.dialog1Data, 'latitude', null)
}
},
beforeImport() {
this.dialog3Saving = true
},
importSuccess(response, file, fileList) {
this.dialog3Data = response
this.dialog3Show = true
this.searchSubmit()
this.dialog3Saving = false
},
importError(error) {
this.$message.error('导入失败')
console.error('导入失败', error)
this.dialog3Saving = false
},
/**
* 按照测点数据类型移除不属于此类型的多余数据。
* 例如:开关量时,移除量程、报警阈值等。
* @param {Object} data 将要提交的machine对象
*/
removeOtherMonitoringPoint(data) {
if (data.monitoringPointDataType !== 1) {
data.trueInfo = null
data.falseInfo = null
}
if (data.monitoringPointDataType !== 2) {
data.unit = null
data.rangeMax = null
data.rangeMin = null
data.thresholdLevel1 = null
data.thresholdLevel2 = null
data.thresholdLevel2Low = null
data.thresholdLevel1Low = null
}
}
}
}
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
::v-deep .el-input-number .el-input__inner {
text-align: left;
}
::v-deep .vue-treeselect__control,::v-deep .vue-treeselect__placeholder,::v-deep .vue-treeselect__single-value {
height: 30px;
line-height: 30px;
}
</style>
<template>
<div class="app-container">
<!--工具栏-->
<!-- <span style="color: red;font-size: 10px;">* 原型图菜单叫监控数据,但其他2处监控叫实时数据,此页面查询的也是最新的测点数据,为措辞统一,这里也叫实时数据了。</span>
<span style="color: red;font-size: 10px;">* 测点类型在新增时是填写的,在这里是选择的?在填过的内容里选择吗?等对接了硬件可能会更清楚这个类型是干什么用的。</span> -->
<div class="head-container">
<div>
<el-input clearable size="small" placeholder="测点名称" style="width: 200px;" class="filter-item" />
<el-select v-model="value" placeholder="测点类型?" style="width: 200px;" class="filter-item">
<el-option label="测点类型?" value="1" />
</el-select>
<el-button class="filter-item" size="mini" type="success" icon="el-icon-search" @click="$message('等待硬件对接中')">搜索</el-button>
<el-button class="filter-item" size="mini" type="warning" icon="el-icon-refresh-left">重置</el-button>
</div>
</div>
<!--表格-->
<el-table ref="table" v-loading="searching" :data="tableData" row-key="id">
<el-table-column :show-overflow-tooltip="true" prop="id" label="编号" width="100px" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="mineName" label="测点名称" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="name" label="测点编号" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="code" label="监测值" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="monitoringType" label="监测时间" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="unit" label="报警状态" align="center" />
</el-table>
<el-pagination
:page-sizes="[10, 20, 50, 100]"
:current-page.sync="searchParam.page"
:page-size.sync="searchParam.count"
:total="searchResult.total"
layout="total, sizes, prev, pager, next, jumper"
@size-change="searchSubmit"
@current-change="searchSubmit"
/>
</div>
</template>
<script>
export default {
name: 'EIotEnvironmentData', // 本页面名
data() {
return {
searching: false,
searchParam: {},
searchResult: {
results: []
}
}
},
computed: {
tableData() {
// 此处对返回值进行算法重组
return this.searchResult.results
}
},
mounted() {
},
methods: {
}
}
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
::v-deep .el-input-number .el-input__inner {
text-align: left;
}
::v-deep .vue-treeselect__control,::v-deep .vue-treeselect__placeholder,::v-deep .vue-treeselect__single-value {
height: 30px;
line-height: 30px;
}
</style>
\ No newline at end of file
<template>
<div class="app-container">
<!--工具栏-->
<div class="head-container">
<div>
<el-input v-model="searchParam.nameLike" clearable size="small" placeholder="测点名称" style="width: 200px;" class="filter-item" />
<el-button class="filter-item" size="mini" type="success" icon="el-icon-search" @click="searchSubmit">搜索</el-button>
<el-button class="filter-item" size="mini" type="warning" icon="el-icon-refresh-left" @click="searchParamReset">重置</el-button>
<el-tooltip class="item" effect="dark" content="按当前查询条件导出" placement="top">
<el-button :loading="exporting" class="filter-item" size="mini" type="info" plain icon="el-icon-download" @click="exportSubmit">导出</el-button>
</el-tooltip>
</div>
<el-button class="filter-item" size="mini" type="primary" icon="el-icon-plus" @click="doAdd()">新增</el-button>
<el-upload
class="filter-item"
action="/api/iot-normal-machine/environment/import"
multiple
:data="{mineType:selectedMine.mineType,mineId:selectedMine.id}"
:headers="httpHeaders"
:before-upload="beforeImport"
:on-success="importSuccess"
:on-error="importError"
:show-file-list="false"
>
<el-button :loading="dialog3Saving" size="mini" type="success" icon="el-icon-upload2">导入</el-button>
</el-upload>
</div>
<!--弹出框1-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog1Show" :title="editState==1?'新增':editState==2?'修改':'查看'" width="960px">
<el-form ref="dialog1Form" :hide-required-asterisk="!dialog1Editing" :model="dialog1Data" :rules="dialog1Rules" size="mini" label-width="180px" style="margin-right: 80px;">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点编号:" prop="code">
<span v-show="!dialog1Editing">{{ dialog1Data.code }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.code" :disabled="editState==2" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="测点名称:" prop="name">
<span v-show="!dialog1Editing">{{ dialog1Data.name }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.name" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点类型:" prop="monitoringType">
<span v-show="!dialog1Editing">{{ (getMonitoringTypeByCode(dialog1Data.code)||{}).name }}</span>
<el-input v-show="dialog1Editing" :disabled="true" :value="(getMonitoringTypeByCode(dialog1Data.code)||{}).name" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="监测点数值类型:" prop="monitoringPointDataType">
<span v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" v-show="!dialog1Editing && item.key==dialog1Data.monitoringPointDataType" :key="item.key">
{{ item.value }}
</span>
<el-select v-show="dialog1Editing" v-model="dialog1Data.monitoringPointDataType" placeholder="请选择" style="width: 100%;">
<el-option v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" :key="item.key" :label="item.value" :value="item.key" />
</el-select>
</el-form-item>
</el-col>
</el-row>
<template v-if="dialog1Data.monitoringPointDataType==2">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="测点单位:" prop="unit">
<span v-show="!dialog1Editing">{{ dialog1Data.unit }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.unit" maxlength="10" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="量程上限:" prop="rangeMax">
<span v-show="!dialog1Editing">{{ dialog1Data.rangeMax }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.rangeMax" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="量程下限:" prop="rangeMin">
<span v-show="!dialog1Editing">{{ dialog1Data.rangeMin }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.rangeMin" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="报警超上限阈值:" prop="thresholdLevel1">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel1 }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel1" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="报警上限阈值:" prop="thresholdLevel2">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel2 }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel2" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="报警下限阈值:" prop="thresholdLevel2Low">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel2Low }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel2Low" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="报警超下限阈值:" prop="thresholdLevel1Low">
<span v-show="!dialog1Editing">{{ dialog1Data.thresholdLevel1Low }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.thresholdLevel1Low" :precision="4" :controls="false" style="width: 100%;" :min="0" :max="999999" />
</el-form-item>
</el-col>
</el-row>
</template>
<template v-if="dialog1Data.monitoringPointDataType==1">
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="开描述:" prop="trueInfo">
<span v-show="!dialog1Editing">{{ dialog1Data.trueInfo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.trueInfo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="停描述:" prop="falseInfo">
<span v-show="!dialog1Editing">{{ dialog1Data.falseInfo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.falseInfo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
</template>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="安装位置:" prop="place">
<span v-show="!dialog1Editing">{{ dialog1Data.place }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.place" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="安装位置描述:" prop="placeNote">
<span v-show="!dialog1Editing">{{ dialog1Data.placeNote }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.placeNote" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="高程:" prop="elevation">
<span v-show="!dialog1Editing">{{ dialog1Data.elevation }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.elevation" :precision="2" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="监测对象:" prop="monitoringTo">
<span v-show="!dialog1Editing">{{ dialog1Data.monitoringTo }}</span>
<el-input v-show="dialog1Editing" v-model="dialog1Data.monitoringTo" maxlength="100" show-word-limit />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="12">
<el-form-item label="经度:" prop="longitude">
<span v-show="!dialog1Editing">{{ dialog1Data.longitude }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.longitude" :precision="6" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="纬度:" prop="latitude">
<span v-show="!dialog1Editing">{{ dialog1Data.latitude }}</span>
<el-input-number v-show="dialog1Editing" v-model="dialog1Data.latitude" :precision="6" :controls="false" style="width: 100%;" />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="24">
<el-form-item v-show="dialog1Editing || dialog1Data.longitude && dialog1Data.latitude" label="位置地图:">
<AMapSearchPoint :is-search="dialog1Editing" :point="mapPoint" @choosePoint="choosePoint" />
</el-form-item>
</el-col>
</el-row>
</el-form>
<div v-show="dialog1Editing" slot="footer" class="dialog-footer">
<el-button type="text" @click="dialog1Show=false">取消</el-button>
<el-button :loading="dialog1Saving" type="primary" @click="dialog1Submit">确认</el-button>
</div>
</el-dialog>
<!--弹出框2-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog2Show" :title="'确认删除'" width="580px">
<div>
<span>确认要环境监测测点吗?</span>
</div>
<div>
<span>测点删除后,此测点的监测数据会一同删除!</span>
</div>
<div slot="footer" class="dialog-footer">
<el-button type="text" @click="dialog2Show=false">取消</el-button>
<el-button :loading="dialog2Saving" type="primary" @click="dialog2Submit">确认</el-button>
</div>
</el-dialog>
<!--弹出框3-->
<el-dialog append-to-body :close-on-click-modal="true" :visible.sync="dialog3Show" :title="'导入结果'" width="580px">
<div>
<span>共计成功导入:</span>
<span style="font-weight: bold;">{{ dialog3Data.successCount + dialog3Data.failCount }}</span>
<span>条,请核对总数。</span>
</div>
<div>
<span>其中,成功:</span>
<span style="color: #67C23A;">{{ dialog3Data.successCount }}</span>
<span>条;失败:</span>
<span style="color: #F56C6C;">{{ dialog3Data.failCount }}</span>
<span>条。</span>
</div>
<br>
<div v-if="dialog3Data.failCount">
<div><span>失败信息:</span></div>
<br>
<div v-for="failReason in dialog3Data.failReasonList" :key="failReason.index">
<span>{{ failReason.index }}条数据</span>
<span v-if="failReason.row" style="font-size: 10px;color: #909399;">{{ failReason.row }}</span>
<span v-if="failReason.col" style="font-size: 10px;color: #909399;">{{ failReason.col }}</span>
<span v-if="failReason.data" style="margin-left: 10px; color: #F56C6C;">{{ failReason.data }}</span>
<span style="margin-left: 10px;">{{ failReason.reason }}</span>
</div>
</div>
</el-dialog>
<!--表格-->
<el-table ref="table" v-loading="searching" :data="tableData" row-key="id">
<el-table-column :show-overflow-tooltip="true" prop="id" label="编号" width="100px" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="code" label="测点编号" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="name" label="测点名称" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="monitoringType" label="测点类型" align="center">
<template slot-scope="scope">
<span>{{ (getMonitoringTypeByCode(scope.row.code)||{}).name }}</span>
</template>
</el-table-column>
<el-table-column :show-overflow-tooltip="true" prop="monitoringPointDataType" label="测点数值类型" align="center">
<template slot-scope="scope">
<span v-for="item in iotEnvironmentMachineApi.monitoringPointDataTypes()" v-show="item.key==scope.row.monitoringPointDataType" :key="item.key">
{{ item.value }}
</span>
</template>
</el-table-column>
<el-table-column :show-overflow-tooltip="true" prop="unit" label="单位" align="center" />
<el-table-column :show-overflow-tooltip="true" prop="xxx" label="状态" align="center" /><!-- TODO 状态 -->
<el-table-column label="操作" width="300px" align="center" fixed="right">
<template slot-scope="scope">
<el-button size="mini" round @click="doEdit(scope.row.id,false)">查看</el-button>
<el-button size="mini" round @click="doEdit(scope.row.id,true)">修改</el-button>
<el-button size="mini" round @click="doDelete(scope.row.id)">删除</el-button>
</template>
</el-table-column>
</el-table>
<el-pagination
:page-sizes="[10, 20, 50, 100]"
:current-page.sync="searchParam.page"
:page-size.sync="searchParam.count"
:total="searchResult.total"
layout="total, sizes, prev, pager, next, jumper"
@size-change="searchSubmit"
@current-change="searchSubmit"
/>
</div>
</template>
<script>
import iotEnvironmentMachineApi from '@/api/kd/iotEnvironmentMachine'
import AMapSearchPoint from '@/components/AMap/AMapSearchPoint'
import { getToken } from '@/utils/auth'
import { mapGetters } from 'vuex'
import { downloadFile } from '@/utils'
const searchParam = {// 默认搜索条件
page: 1,
count: 10,
searchCount: true
}
export default {
name: 'EIotEnvironmentMachine', // 本页面名
components: { AMapSearchPoint },
data() {
return {
selectedMine: {},
httpHeaders: {
'Authorization': getToken()
},
iotEnvironmentMachineApi: iotEnvironmentMachineApi,
searching: false,
exporting: false,
searchParam: {},
searchResult: {
total: 0,
results: [] // 搜索结果
},
dialog1Show: false,
dialog1Editing: false,
dialog1Saving: false,
dialog1Data: {},
dialog1Rules: {
code: [{ required: true, message: '请填写' }],
name: [{ required: true, message: '请填写' }],
monitoringPointDataType: [{ required: true, message: '请选择' }]
},
editState: 0, // (刚打开窗口时)记录了上次窗口作用;(保存编辑时)记录了当前窗口作用; 0无 1新增 2修改 3查看
addingData: {}, // 上次正在新增时的内容,下次打开dialog1窗口时记录下来
dialog2Show: false,
dialog2Saving: false,
dialog2Data: {},
dialog3Show: false,
dialog3Data: {},
dialog3Saving: false
}
},
computed: {
...mapGetters([
'user'
]),
tableData() {
// 此处对返回值进行算法重组
return this.searchResult.results
},
mapPoint() {
if (this.dialog1Data.longitude && this.dialog1Data.latitude) {
return [this.dialog1Data.longitude * 1, this.dialog1Data.latitude * 1]
}
return null
}
},
mounted() {
const selectedMineJson = window.localStorage.getItem('kd.selected.mine')
let noMine = false
if (!selectedMineJson) {
noMine = true
} else {
const selectedMine = JSON.parse(selectedMineJson)
if (!selectedMine || selectedMine.enterpriseId !== this.user.enterpriseId) {
noMine = true
} else {
this.selectedMine = selectedMine
}
}
// if (noMine) {
// this.$message.error('当前未选择矿山')
// this.$router.replace('/dashboard')
// }
this.searchParamReset()
this.searchSubmit()
},
methods: {
searchParamReset() {
this.searchParam = JSON.parse(JSON.stringify(searchParam))
},
searchSubmit() {
this.searching = true
this.searchParam.mineType = this.selectedMine.mineType
this.searchParam.mineId = this.selectedMine.id
iotEnvironmentMachineApi.getPage(this.searchParam).then(response => {
this.searching = false
this.searchResult = response
}).catch(() => {
this.searching = false
})
},
exportSubmit() {
this.exporting = true
this.searchParam.mineType = this.selectedMine.mineType
this.searchParam.mineId = this.selectedMine.id
iotEnvironmentMachineApi.export(this.searchParam).then(response => {
downloadFile(response, '环境监测设备', 'xlsx')
this.exporting = false
}).catch(() => {
this.exporting = false
})
},
getMonitoringTypeByCode(code) {
return iotEnvironmentMachineApi.getMonitoringTypeByCode(code)
},
dialog1Submit() {
this.$refs['dialog1Form'].validate(valid => {
if (!valid) {
return
} else if (!this.getMonitoringTypeByCode(this.dialog1Data.code)) {
this.$message.error('请正确填写编号,需解析出【监测类型】')
} else {
this.dialog1Saving = true
this.removeOtherMonitoringPoint(this.dialog1Data)
if (this.editState === 1) { // 新增
this.dialog1Data.mineType = this.selectedMine.mineType
this.dialog1Data.mineId = this.selectedMine.id
iotEnvironmentMachineApi.add(this.dialog1Data).then(() => {
this.dialog1Show = false
this.$message.success('保存成功')
setTimeout(() => { // 立即清除会导致输入框Validate一闪变红
this.dialog1Data = {}
this.dialog1Saving = false
}, 500)
this.searchSubmit()
}).catch(() => {
this.dialog1Saving = false
})
} else if (this.editState === 2) { // 修改
iotEnvironmentMachineApi.set(this.dialog1Data).then(() => {
this.dialog1Show = false
this.$message.success('修改成功')
setTimeout(() => { // 立即清除会导致输入框Validate一闪变红
this.dialog1Data = {}
this.dialog1Saving = false
}, 500)
this.searchSubmit()
}).catch(() => {
this.dialog1Saving = false
})
} else {
this.$message.error('出错啦,请重试')
this.dialog1Saving = false
}
}
})
},
beforeDialog1Open() { // 窗口打开前的统一操作
if (this.editState === 1) {
this.addingData = this.dialog1Data
}
},
doAdd() {
this.beforeDialog1Open()
this.editState = 1
this.dialog1Editing = true
this.dialog1Data = this.addingData // 初始值:上次编辑的内容
this.dialog1Show = true
this.$nextTick(() => {
this.$refs['dialog1Form'].clearValidate()
})
},
doEdit(id, isEdit) {
this.beforeDialog1Open()
this.editState = isEdit ? 2 : 3
iotEnvironmentMachineApi.getById(id).then(response => {
this.dialog1Data = response
this.dialog1Editing = isEdit
this.dialog1Show = true
this.$nextTick(() => {
this.$refs['dialog1Form'].clearValidate()
})
}).catch(() => {
this.searchSubmit()
})
},
dialog2Submit() {
this.dialog2Saving = true
iotEnvironmentMachineApi.del(this.dialog2Data).then(() => {
this.dialog2Show = false
this.$message.success('删除成功')
this.dialog2Data = {}
this.dialog2Saving = false
this.searchSubmit()
}).catch(() => {
this.dialog2Saving = false
})
},
doDelete(id) {
iotEnvironmentMachineApi.getById(id).then(response => {
this.dialog2Data = response
this.dialog2Show = true
}).catch(() => {
this.searchSubmit()
})
},
choosePoint(lnglat) {
if (lnglat) {
this.$set(this.dialog1Data, 'longitude', lnglat[0])
this.$set(this.dialog1Data, 'latitude', lnglat[1])
} else {
this.$set(this.dialog1Data, 'longitude', null)
this.$set(this.dialog1Data, 'latitude', null)
}
},
beforeImport() {
this.dialog3Saving = true
},
importSuccess(response, file, fileList) {
this.dialog3Data = response
this.dialog3Show = true
this.searchSubmit()
this.dialog3Saving = false
},
importError(error) {
this.$message.error('导入失败')
console.error('导入失败', error)
this.dialog3Saving = false
},
/**
* 按照测点数据类型移除不属于此类型的多余数据。
* 例如:开关量时,移除量程、报警阈值等。
* @param {Object} data 将要提交的machine对象
*/
removeOtherMonitoringPoint(data) {
if (data.monitoringPointDataType !== 1) {
data.trueInfo = null
data.falseInfo = null
}
if (data.monitoringPointDataType !== 2) {
data.unit = null
data.rangeMax = null
data.rangeMin = null
data.thresholdLevel1 = null
data.thresholdLevel2 = null
data.thresholdLevel2Low = null
data.thresholdLevel1Low = null
}
}
}
}
</script>
<style rel="stylesheet/scss" lang="scss" scoped>
::v-deep .el-input-number .el-input__inner {
text-align: left;
}
::v-deep .vue-treeselect__control,::v-deep .vue-treeselect__placeholder,::v-deep .vue-treeselect__single-value {
height: 30px;
line-height: 30px;
}
</style>
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment