2023-12-12 18:23:23 +08:00
|
|
|
|
<template>
|
|
|
|
|
|
<div class="fullHeight">
|
|
|
|
|
|
<div class="searchBox whiteBlock">
|
|
|
|
|
|
<!-- 智能张拉——设备管理 -->
|
|
|
|
|
|
<el-form :inline="true" ref="searchForm" :model="searchForm" size="medium">
|
|
|
|
|
|
<el-form-item label="设备名称">
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-input v-model="searchForm.devName" placeholder="请输入"></el-input>
|
2023-12-12 18:23:23 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-button type="primary" plain @click="getList">{{
|
|
|
|
|
|
$t("message.energyManage.waybill.query")
|
|
|
|
|
|
}}</el-button>
|
|
|
|
|
|
<el-button type="warning" plain @click="refresh">{{
|
|
|
|
|
|
$t("message.deviceManage.refresh")
|
|
|
|
|
|
}}</el-button>
|
2023-12-12 18:23:23 +08:00
|
|
|
|
<el-button type="primary" size="medium" @click="add">新增</el-button>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
</el-form>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="table_wrap whiteBlock">
|
|
|
|
|
|
<el-table class="tables" :data="List">
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-table-column prop="devName" align="center" label="设备名称"></el-table-column>
|
|
|
|
|
|
<el-table-column prop="devSn" align="center" label="设备编码"></el-table-column>
|
|
|
|
|
|
<el-table-column prop="installLocation" align="center" label="安装位置"></el-table-column>
|
|
|
|
|
|
<el-table-column prop="personInChargeName" align="center" label="负责人"></el-table-column>
|
|
|
|
|
|
<el-table-column prop="phoneNumber" align="center" label="负责人电话"></el-table-column>
|
|
|
|
|
|
<el-table-column prop="image" align="center" label="设备图片">
|
2023-12-12 18:23:23 +08:00
|
|
|
|
<template slot-scope="scope">
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<div class="devImage">
|
|
|
|
|
|
<el-image v-if="JSON.parse(scope.row.image)[0]"
|
|
|
|
|
|
:preview-src-list="JSON.parse(scope.row.image) ? [JSON.parse(scope.row.image)[0].url] : []"
|
|
|
|
|
|
:src="JSON.parse(scope.row.image)[0] ? JSON.parse(scope.row.image)[0].url : []" alt=""></el-image>
|
|
|
|
|
|
</div>
|
2023-12-12 18:23:23 +08:00
|
|
|
|
</template>
|
|
|
|
|
|
</el-table-column>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-table-column prop="remark" align="center" label="备注"></el-table-column>
|
2023-12-15 10:40:14 +08:00
|
|
|
|
<el-table-column label="操作" align="center" width="400px">
|
2023-12-12 18:23:23 +08:00
|
|
|
|
<template slot-scope="scope">
|
|
|
|
|
|
<div class="tableBtns">
|
|
|
|
|
|
<div @click="edit(scope.row)" class="operationText">
|
|
|
|
|
|
<img src="@/assets/images/icon-edit.png" width="15px" height="15px" />
|
|
|
|
|
|
<span style="white-space: nowrap;">编辑</span>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div @click="deleteDev(scope.row)" class="operationText">
|
|
|
|
|
|
<img src="@/assets/images/icon-delete.png" width="15px" height="15px" />
|
|
|
|
|
|
<span style="white-space: nowrap;">删除</span>
|
|
|
|
|
|
</div>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<div @click="setYu(scope.row)" class="operationText">
|
|
|
|
|
|
<img src="@/assets/images/yu.png" width="15px" height="15px" />
|
|
|
|
|
|
<span style="white-space: nowrap;">预警值设置</span>
|
|
|
|
|
|
</div>
|
2023-12-15 10:40:14 +08:00
|
|
|
|
<div @click="setBao(scope.row)" class="operationText">
|
|
|
|
|
|
<img src="@/assets/images/bao.png" width="15px" height="15px" />
|
|
|
|
|
|
<span style="white-space: nowrap;">报警值设置</span>
|
|
|
|
|
|
</div>
|
2023-12-12 18:23:23 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</el-table-column>
|
|
|
|
|
|
</el-table>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-pagination class="pagerBox" @size-change="SizeChange" @current-change="CurrentChange"
|
|
|
|
|
|
:current-page="pagInfo.pageNo" :page-sizes="$store.state.PAGESIZRS" :page-size="pagInfo.pageSize"
|
|
|
|
|
|
layout="total, sizes, prev, pager, next" :total="Number(pagInfo.total)" background></el-pagination>
|
2023-12-12 18:23:23 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
<el-dialog :modal-append-to-body="false" @close="close" :title="title" :visible.sync="dialogShow" width="667px">
|
|
|
|
|
|
<div class="dialog_content">
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-form size="medium" ref="addEditForm" :model="addEditForm" :rules="addEditRules" label-width="120px"
|
|
|
|
|
|
class="dialogFormBox">
|
|
|
|
|
|
<el-form-item label="设备名称" prop="devName">
|
|
|
|
|
|
<el-input :disabled="isDetail" v-model="addEditForm.devName" placeholder="请输入"></el-input>
|
2023-12-12 18:23:23 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="设备编码" prop="devSn">
|
|
|
|
|
|
<el-input :disabled="isDetail" v-model="addEditForm.devSn" placeholder="请输入"></el-input>
|
|
|
|
|
|
</el-form-item>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-form-item label="安装位置" prop="installLocation">
|
|
|
|
|
|
<el-input :disabled="isDetail" v-model="addEditForm.installLocation" placeholder="请输入"></el-input>
|
2023-12-12 18:23:23 +08:00
|
|
|
|
</el-form-item>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-form-item label="负责人" prop="personInCharge">
|
|
|
|
|
|
<el-select v-model="addEditForm.personInCharge" placeholder="请选择" :disabled="isDetail"
|
|
|
|
|
|
@change="dutySelectChange">
|
|
|
|
|
|
<el-option v-for="(item, index) in dutyList" :key="index" :label="item.realName" :value="item.userId">
|
|
|
|
|
|
</el-option>
|
2023-12-12 18:23:23 +08:00
|
|
|
|
</el-select>
|
|
|
|
|
|
</el-form-item>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-form-item label="负责人电话" prop="phoneNumber">
|
|
|
|
|
|
<el-input :disabled="isDetail" v-model="addEditForm.phoneNumber" placeholder="请输入"></el-input>
|
2023-12-12 18:23:23 +08:00
|
|
|
|
</el-form-item>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-form-item label="上传图片">
|
|
|
|
|
|
<el-upload :disabled="isDetail" :action="$store.state.UPLOADURL" list-type="picture-card" multiple
|
|
|
|
|
|
name="files" :limit="1" accept=".png, .jpg, .jpeg" :file-list="fileUplodList"
|
2023-12-12 18:23:23 +08:00
|
|
|
|
:on-exceed="(file, fileList) => handleExceed(file, fileList)"
|
|
|
|
|
|
:on-success="(res, file) => handleSuccess(res, file)"
|
2023-12-13 17:56:32 +08:00
|
|
|
|
:on-remove="(file, fileList) => handleRemove(file, fileList)">
|
2023-12-12 18:23:23 +08:00
|
|
|
|
<i class="el-icon-plus"></i>
|
|
|
|
|
|
</el-upload>
|
|
|
|
|
|
</el-form-item>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-form-item label="备注" prop="remark">
|
|
|
|
|
|
<el-input :disabled="isDetail" v-model="addEditForm.remark" placeholder="请输入"></el-input>
|
|
|
|
|
|
</el-form-item>
|
2023-12-12 18:23:23 +08:00
|
|
|
|
<div class="dialog-footer">
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-button class="cancleBtn" @click="dialogShow = false" icon="el-icon-circle-close" size="medium">{{
|
|
|
|
|
|
$t("message.deviceManage.cancel") }}
|
2023-12-12 18:23:23 +08:00
|
|
|
|
</el-button>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
<el-button type="primary" icon="el-icon-circle-check" @click="submit" size="medium">{{
|
|
|
|
|
|
$t("message.deviceManage.save") }}
|
|
|
|
|
|
</el-button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-dialog>
|
|
|
|
|
|
<el-dialog :modal-append-to-body="false" @close="dialogSetShow = false" title="编辑预警值设置" :visible.sync="dialogSetShow"
|
|
|
|
|
|
width="667px">
|
|
|
|
|
|
<div class="dialog_content">
|
|
|
|
|
|
<el-form size="medium" ref="setEditForm" :model="setEditForm" label-width="120px" class="dialogFormBox">
|
2023-12-15 10:40:14 +08:00
|
|
|
|
<el-form-item label="PH值">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setEditForm.phValueLowWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setEditForm.phValueHighWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
</el-form-item>
|
2023-12-15 10:40:14 +08:00
|
|
|
|
<el-form-item label="电导率(μS/cm)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setEditForm.conductivityLowWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setEditForm.conductivityHighWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
</el-form-item>
|
2023-12-15 10:40:14 +08:00
|
|
|
|
<el-form-item label="水温(℃)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setEditForm.waterTemperatureLowWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setEditForm.waterTemperatureHighWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
</el-form-item>
|
2023-12-15 10:40:14 +08:00
|
|
|
|
<el-form-item label="溶解氧(mg/L)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setEditForm.dissolvedOxygenLowWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setEditForm.dissolvedOxygenHighWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
</el-form-item>
|
2023-12-15 10:40:14 +08:00
|
|
|
|
<el-form-item label="浊度值(NTU)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setEditForm.turbidityValueLowWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setEditForm.turbidityValueHighWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
</el-form-item>
|
2023-12-15 10:40:14 +08:00
|
|
|
|
<el-form-item label="流速(m/s)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setEditForm.flowVelocityLowWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setEditForm.flowVelocityHighWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
</el-form-item>
|
2023-12-15 10:40:14 +08:00
|
|
|
|
<el-form-item label="水位(m)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setEditForm.waterLevelLowWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setEditForm.waterLevelHighWarn" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
2023-12-13 17:56:32 +08:00
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<div class="dialog-footer">
|
|
|
|
|
|
<el-button class="cancleBtn" @click="dialogSetShow = false" icon="el-icon-circle-close" size="medium">{{
|
|
|
|
|
|
$t("message.deviceManage.cancel") }}
|
|
|
|
|
|
</el-button>
|
2023-12-15 10:40:14 +08:00
|
|
|
|
<el-button type="primary" icon="el-icon-circle-check" @click="submitSet('编辑预警值设置')" size="me'dium">{{
|
|
|
|
|
|
$t("message.deviceManage.save") }}
|
|
|
|
|
|
</el-button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-dialog>
|
|
|
|
|
|
<el-dialog :modal-append-to-body="false" @close="dialogBaoSetShow = false" title="编辑报警值设置" :visible.sync="dialogBaoSetShow"
|
|
|
|
|
|
width="667px">
|
|
|
|
|
|
<div class="dialog_content">
|
|
|
|
|
|
<el-form size="medium" ref="setBaoEditForm" :model="setBaoEditForm" label-width="120px" class="dialogFormBox">
|
|
|
|
|
|
<el-form-item label="PH值">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.phValueLowAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.phValueHighAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="电导率(μS/cm)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.conductivityLowAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.conductivityHighAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="水温(℃)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.waterTemperatureLowAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.waterTemperatureHighAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="溶解氧(mg/L)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.dissolvedOxygenLowAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.dissolvedOxygenHighAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="浊度值(NTU)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.turbidityValueLowAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.turbidityValueHighAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="流速(m/s)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.flowVelocityLowAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.flowVelocityHighAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<el-form-item label="水位(m)">
|
|
|
|
|
|
<div class="form-flex">
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.waterLevelLowAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
<div class="center-line">~</div>
|
|
|
|
|
|
<el-input v-model="setBaoEditForm.waterLevelHighAlarm" placeholder="请输入" oninput="value=value.replace(/[^\d]/g,'')"></el-input>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form-item>
|
|
|
|
|
|
<div class="dialog-footer">
|
|
|
|
|
|
<el-button class="cancleBtn" @click="dialogBaoSetShow = false" icon="el-icon-circle-close" size="medium">{{
|
|
|
|
|
|
$t("message.deviceManage.cancel") }}
|
|
|
|
|
|
</el-button>
|
|
|
|
|
|
<el-button type="primary" icon="el-icon-circle-check" @click="submitSet('编辑报警值设置')" size="medium">{{
|
2023-12-13 17:56:32 +08:00
|
|
|
|
$t("message.deviceManage.save") }}
|
2023-12-12 18:23:23 +08:00
|
|
|
|
</el-button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-form>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-dialog>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
<script>
|
|
|
|
|
|
import {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
sewageDevAdd,
|
|
|
|
|
|
sewageDevDelete,
|
|
|
|
|
|
sewageDevEdit,
|
|
|
|
|
|
sewageDevPage,
|
|
|
|
|
|
getCrewListDataApi,
|
|
|
|
|
|
sewageThresholdDetail,
|
|
|
|
|
|
sewageThresholdEdit
|
|
|
|
|
|
} from "@/assets/js/api/sewageMonitor.js";
|
2023-12-12 18:23:23 +08:00
|
|
|
|
export default {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
mounted() { },
|
2023-12-12 18:23:23 +08:00
|
|
|
|
created() {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.getList();
|
|
|
|
|
|
this.getDutyPerson();
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
data() {
|
|
|
|
|
|
return {
|
|
|
|
|
|
isDetail: false, //是否详情
|
|
|
|
|
|
dutyList: [], // 负责人
|
|
|
|
|
|
fileUplodList: [],
|
2023-12-13 17:56:32 +08:00
|
|
|
|
title: "",
|
2023-12-15 10:40:14 +08:00
|
|
|
|
dialogBaoSetShow: false,
|
2023-12-13 17:56:32 +08:00
|
|
|
|
dialogSetShow: false,
|
2023-12-12 18:23:23 +08:00
|
|
|
|
dialogShow: false,
|
|
|
|
|
|
pagInfo: {
|
|
|
|
|
|
pageNo: 1, //页数
|
|
|
|
|
|
pageSize: 10, //条数
|
2023-12-13 17:56:32 +08:00
|
|
|
|
total: 0, //总条数
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
List: [],
|
2023-12-13 17:56:32 +08:00
|
|
|
|
setEditForm: {
|
2023-12-15 10:40:14 +08:00
|
|
|
|
phValueLowWarn: 0,
|
|
|
|
|
|
phValueHighWarn: 100,
|
|
|
|
|
|
conductivityLowWarn: 0,
|
|
|
|
|
|
conductivityHighWarn: 100,
|
|
|
|
|
|
waterTemperatureLowWarn: 0,
|
|
|
|
|
|
waterTemperatureHighWarn: 100,
|
|
|
|
|
|
dissolvedOxygenLowWarn: 0,
|
|
|
|
|
|
dissolvedOxygenHighWarn: 100,
|
|
|
|
|
|
turbidityValueLowWarn: 0,
|
|
|
|
|
|
turbidityValueHighWarn: 100,
|
|
|
|
|
|
flowVelocityLowWarn: 0,
|
|
|
|
|
|
flowVelocityHighWarn: 100,
|
|
|
|
|
|
waterLevelLowWarn: 0,
|
|
|
|
|
|
waterLevelHighWarn: 100,
|
|
|
|
|
|
},
|
|
|
|
|
|
setBaoEditForm: {
|
|
|
|
|
|
phValueLowAlarm: 0,
|
|
|
|
|
|
phValueHighAlarm: 100,
|
|
|
|
|
|
conductivityLowAlarm: 0,
|
|
|
|
|
|
conductivityHighAlarm: 100,
|
|
|
|
|
|
waterTemperatureLowAlarm: 0,
|
|
|
|
|
|
waterTemperatureHighAlarm: 100,
|
|
|
|
|
|
dissolvedOxygenLowAlarm: 0,
|
|
|
|
|
|
dissolvedOxygenHighAlarm: 100,
|
|
|
|
|
|
turbidityValueLowAlarm: 0,
|
|
|
|
|
|
turbidityValueHighAlarm: 100,
|
|
|
|
|
|
flowVelocityLowAlarm: 0,
|
|
|
|
|
|
flowVelocityHighAlarm: 100,
|
|
|
|
|
|
waterLevelLowAlarm: 0,
|
|
|
|
|
|
waterLevelHighAlarm: 100,
|
2023-12-13 17:56:32 +08:00
|
|
|
|
},
|
2023-12-12 18:23:23 +08:00
|
|
|
|
addEditForm: {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
createTime: "",
|
|
|
|
|
|
devSn: "",
|
|
|
|
|
|
installLocation: "",
|
|
|
|
|
|
devName: "",
|
|
|
|
|
|
personInChargeName: "",
|
|
|
|
|
|
personInCharge: "",
|
|
|
|
|
|
phoneNumber: "",
|
|
|
|
|
|
personInCharge: "",
|
|
|
|
|
|
image: "",
|
|
|
|
|
|
remark: "",
|
|
|
|
|
|
projectSn: "",
|
|
|
|
|
|
updateTime: "",
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
addEditRules: {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
devName: [
|
2023-12-12 18:23:23 +08:00
|
|
|
|
{
|
|
|
|
|
|
required: true,
|
2023-12-13 17:56:32 +08:00
|
|
|
|
message: "必填",
|
|
|
|
|
|
trigger: "blur",
|
|
|
|
|
|
},
|
2023-12-12 18:23:23 +08:00
|
|
|
|
],
|
|
|
|
|
|
devSn: [
|
|
|
|
|
|
{
|
|
|
|
|
|
required: true,
|
2023-12-13 17:56:32 +08:00
|
|
|
|
message: "必填",
|
|
|
|
|
|
trigger: "blur",
|
|
|
|
|
|
},
|
2023-12-12 18:23:23 +08:00
|
|
|
|
],
|
2023-12-13 17:56:32 +08:00
|
|
|
|
phoneNumber: [
|
2023-12-12 18:23:23 +08:00
|
|
|
|
{
|
2023-12-13 17:56:32 +08:00
|
|
|
|
message: "请输入正确的手机号码",
|
|
|
|
|
|
trigger: "blur",
|
|
|
|
|
|
pattern: /^1(3|4|5|6|7|8|9)\d{9}$/,
|
|
|
|
|
|
},
|
|
|
|
|
|
],
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
searchForm: {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
devName: "",
|
|
|
|
|
|
},
|
|
|
|
|
|
};
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
methods: {
|
2023-12-15 10:40:14 +08:00
|
|
|
|
// 设置报警值
|
|
|
|
|
|
async setBao(obj) {
|
|
|
|
|
|
const res = await sewageThresholdDetail({ devSn: obj.devSn })
|
|
|
|
|
|
let initForm = JSON.parse(JSON.stringify(this.setBaoEditForm))
|
|
|
|
|
|
this.setBaoEditForm = { ...this.setBaoEditForm, ...res.result }
|
|
|
|
|
|
for (let i in initForm) {
|
|
|
|
|
|
if (!this.setBaoEditForm[i]) {
|
|
|
|
|
|
this.setBaoEditForm[i] = 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
this.dialogBaoSetShow = true;
|
|
|
|
|
|
},
|
2023-12-13 17:56:32 +08:00
|
|
|
|
// 设置阈值
|
|
|
|
|
|
async setYu(obj) {
|
|
|
|
|
|
const res = await sewageThresholdDetail({ devSn: obj.devSn })
|
|
|
|
|
|
let initForm = JSON.parse(JSON.stringify(this.setEditForm))
|
|
|
|
|
|
this.setEditForm = { ...this.setEditForm, ...res.result }
|
2023-12-15 10:40:14 +08:00
|
|
|
|
for (let i in initForm) {
|
|
|
|
|
|
if (!this.setEditForm[i]) {
|
|
|
|
|
|
this.setEditForm[i] = 0;
|
2023-12-13 17:56:32 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
this.dialogSetShow = true;
|
|
|
|
|
|
},
|
2023-12-12 18:23:23 +08:00
|
|
|
|
// 负责人下拉回调
|
|
|
|
|
|
dutySelectChange(e) {
|
|
|
|
|
|
const item = this.dutyList.find(item => item.userId === e);
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.addEditForm.personInChargeName = item.realName
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
//查询负责人下拉
|
|
|
|
|
|
getDutyPerson() {
|
|
|
|
|
|
let data = {
|
|
|
|
|
|
projectSn: this.$store.state.projectSn,
|
2023-12-13 17:56:32 +08:00
|
|
|
|
};
|
|
|
|
|
|
getCrewListDataApi(data).then((res) => {
|
2023-12-12 18:23:23 +08:00
|
|
|
|
if (res.code == 200) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.dutyList = res.result;
|
|
|
|
|
|
console.log("获取负责人下拉", this.dutyList);
|
2023-12-12 18:23:23 +08:00
|
|
|
|
} else {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.$message.error(res.message);
|
2023-12-12 18:23:23 +08:00
|
|
|
|
}
|
2023-12-13 17:56:32 +08:00
|
|
|
|
});
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
//查询列表
|
|
|
|
|
|
getList() {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
sewageDevPage({
|
2023-12-12 18:23:23 +08:00
|
|
|
|
pageNo: this.pagInfo.pageNo,
|
|
|
|
|
|
pageSize: this.pagInfo.pageSize,
|
|
|
|
|
|
projectSn: this.$store.state.projectSn,
|
2023-12-13 17:56:32 +08:00
|
|
|
|
devName: this.searchForm.devName,
|
|
|
|
|
|
}).then((result) => {
|
2023-12-12 18:23:23 +08:00
|
|
|
|
if (result.success) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.List = result.result.records;
|
|
|
|
|
|
this.pagInfo.total = result.result.total;
|
2023-12-12 18:23:23 +08:00
|
|
|
|
}
|
2023-12-13 17:56:32 +08:00
|
|
|
|
});
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
add() {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.title = "新增";
|
|
|
|
|
|
this.dialogShow = true;
|
|
|
|
|
|
this.fileUplodList = [];
|
|
|
|
|
|
this.close();
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
edit(obj) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.title = "编辑";
|
|
|
|
|
|
this.dialogShow = true;
|
|
|
|
|
|
this.addEditForm = JSON.parse(JSON.stringify(obj));
|
|
|
|
|
|
this.fileUplodList = JSON.parse(obj.image);
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
2023-12-15 10:40:14 +08:00
|
|
|
|
submitSet(title) {
|
|
|
|
|
|
let params;
|
|
|
|
|
|
if(title == '编辑预警值设置'){
|
|
|
|
|
|
params = JSON.parse(JSON.stringify(this.setEditForm));
|
|
|
|
|
|
} else if(title == '编辑报警值设置') {
|
|
|
|
|
|
params = JSON.parse(JSON.stringify(this.setBaoEditForm));
|
|
|
|
|
|
}
|
2023-12-13 17:56:32 +08:00
|
|
|
|
sewageThresholdEdit(params).then((result) => {
|
|
|
|
|
|
if (result.success) {
|
|
|
|
|
|
this.$message.success(result.message);
|
|
|
|
|
|
this.getList();
|
|
|
|
|
|
this.dialogSetShow = false;
|
2023-12-15 10:40:14 +08:00
|
|
|
|
this.dialogBaoSetShow = false;
|
2023-12-13 17:56:32 +08:00
|
|
|
|
}
|
|
|
|
|
|
});
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
submit() {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
let params = JSON.parse(JSON.stringify(this.addEditForm));
|
|
|
|
|
|
params.projectSn = this.$store.state.projectSn;
|
|
|
|
|
|
params.image = JSON.stringify(this.fileUplodList);
|
2023-12-12 18:23:23 +08:00
|
|
|
|
// if (this.fileUplodList.length > 0) {
|
|
|
|
|
|
// this.$message.error('请上传照片')
|
|
|
|
|
|
// return false
|
|
|
|
|
|
// }
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.$refs.addEditForm.validate((valid) => {
|
2023-12-12 18:23:23 +08:00
|
|
|
|
if (valid) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
if (this.title == "新增") {
|
|
|
|
|
|
sewageDevAdd(params).then((result) => {
|
2023-12-12 18:23:23 +08:00
|
|
|
|
if (result.success) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.$message.success(result.message);
|
|
|
|
|
|
this.getList();
|
2023-12-12 18:23:23 +08:00
|
|
|
|
}
|
2023-12-13 17:56:32 +08:00
|
|
|
|
});
|
|
|
|
|
|
} else if (this.title == "编辑") {
|
|
|
|
|
|
sewageDevEdit(params).then((result) => {
|
2023-12-12 18:23:23 +08:00
|
|
|
|
if (result.success) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.$message.success(result.message);
|
|
|
|
|
|
this.getList();
|
2023-12-12 18:23:23 +08:00
|
|
|
|
}
|
2023-12-13 17:56:32 +08:00
|
|
|
|
});
|
2023-12-12 18:23:23 +08:00
|
|
|
|
}
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.dialogShow = false;
|
2023-12-12 18:23:23 +08:00
|
|
|
|
} else {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
return false;
|
2023-12-12 18:23:23 +08:00
|
|
|
|
}
|
2023-12-13 17:56:32 +08:00
|
|
|
|
});
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
deleteDev(obj) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.$confirm("此操作将永久删除, 是否继续?", "提示", {
|
|
|
|
|
|
confirmButtonText: "确定",
|
|
|
|
|
|
cancelButtonText: "取消",
|
|
|
|
|
|
type: "warning",
|
2023-12-12 18:23:23 +08:00
|
|
|
|
})
|
|
|
|
|
|
.then(() => {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
sewageDevDelete({ id: obj.id }).then((res) => {
|
2023-12-12 18:23:23 +08:00
|
|
|
|
if (res.success) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.getList();
|
2023-12-12 18:23:23 +08:00
|
|
|
|
this.$message({
|
2023-12-13 17:56:32 +08:00
|
|
|
|
type: "success",
|
|
|
|
|
|
message: "删除成功!",
|
|
|
|
|
|
});
|
2023-12-12 18:23:23 +08:00
|
|
|
|
} else {
|
|
|
|
|
|
this.$message({
|
2023-12-13 17:56:32 +08:00
|
|
|
|
type: "error",
|
|
|
|
|
|
message: res.message,
|
|
|
|
|
|
});
|
2023-12-12 18:23:23 +08:00
|
|
|
|
}
|
2023-12-13 17:56:32 +08:00
|
|
|
|
});
|
2023-12-12 18:23:23 +08:00
|
|
|
|
})
|
|
|
|
|
|
.catch(() => {
|
|
|
|
|
|
this.$message({
|
2023-12-13 17:56:32 +08:00
|
|
|
|
type: "info",
|
|
|
|
|
|
message: "已取消删除",
|
|
|
|
|
|
});
|
|
|
|
|
|
});
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
// 删除
|
|
|
|
|
|
handleRemove(file, fileList) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.fileUplodList = fileList;
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
handleExceed(file, fileList) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
console.log("超出限制", file);
|
|
|
|
|
|
this.$message.warning("只能上传一张图片");
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
handleSuccess(res, file, type) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
if (res.status == "SUCCESS") {
|
|
|
|
|
|
console.log(res);
|
2023-12-12 18:23:23 +08:00
|
|
|
|
this.fileUplodList.push({
|
|
|
|
|
|
name: file.name,
|
2023-12-13 17:56:32 +08:00
|
|
|
|
url: this.$store.state.FILEURL + file.response.data[0].imageUrl,
|
|
|
|
|
|
});
|
2023-12-12 18:23:23 +08:00
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
close() {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.isDetail = false;
|
|
|
|
|
|
this.addEditForm = {};
|
|
|
|
|
|
this.fileUplodList = [];
|
2023-12-12 18:23:23 +08:00
|
|
|
|
this.$nextTick(() => {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.$refs.addEditForm.clearValidate();
|
|
|
|
|
|
});
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
SizeChange(val) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.pagInfo.pageSize = val;
|
|
|
|
|
|
this.getList();
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
CurrentChange(val) {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.pagInfo.pageNo = val;
|
|
|
|
|
|
this.getList();
|
2023-12-12 18:23:23 +08:00
|
|
|
|
},
|
|
|
|
|
|
refresh() {
|
2023-12-13 17:56:32 +08:00
|
|
|
|
this.searchForm = {};
|
|
|
|
|
|
this.pagInfo.pageNo = 1; //页数
|
|
|
|
|
|
this.pagInfo.pageSize = 10; //条数
|
|
|
|
|
|
this.getList();
|
|
|
|
|
|
},
|
|
|
|
|
|
},
|
|
|
|
|
|
};
|
2023-12-12 18:23:23 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
<style lang="less" scoped>
|
2023-12-15 10:40:14 +08:00
|
|
|
|
.flex {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
2023-12-12 18:23:23 +08:00
|
|
|
|
}
|
2023-12-13 17:56:32 +08:00
|
|
|
|
|
|
|
|
|
|
.devImage {
|
|
|
|
|
|
/deep/ .el-image {
|
|
|
|
|
|
width: 80px;
|
|
|
|
|
|
height: 50px;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2023-12-15 10:40:14 +08:00
|
|
|
|
.dialogFormBox {
|
|
|
|
|
|
.form-flex {
|
|
|
|
|
|
.flex();
|
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
|
.center-line {
|
|
|
|
|
|
height: 36px;
|
|
|
|
|
|
line-height: 36px;
|
|
|
|
|
|
margin: 0 10px;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
/deep/.el-form-item__content{
|
|
|
|
|
|
line-height: 0px;
|
|
|
|
|
|
}
|
|
|
|
|
|
}</style>
|