This commit is contained in:
xiaozhiyong
2026-06-01 10:59:15 +08:00
parent 4f6dad3599
commit 08f0e41baa
10 changed files with 274 additions and 26 deletions

View File

@@ -0,0 +1,121 @@
<template>
<div>
<!-- <warning-bar title="注:右上角头像下拉可切换角色" /> -->
<div class="gva-search-box">
<el-form ref="searchForm" :inline="true" :model="searchInfo">
<el-form-item label="用户名">
<el-input v-model="searchInfo.username" placeholder="设备ID" />
</el-form-item>
<el-form-item label="昵称">
<el-input v-model="searchInfo.nickname" placeholder="设备状态" />
</el-form-item>
<el-form-item>
<el-button type="primary" icon="search" @click="onSubmit"> 查询 </el-button>
<el-button icon="refresh" @click="onReset"> 重置 </el-button>
</el-form-item>
</el-form>
</div>
<div class="gva-table-box">
<div class="gva-btn-list">
<el-button type="primary" icon="plus" @click="addUser">新增用户</el-button>
</div>
<el-table :data="tableData">
<el-table-column align="left" label="网关ID" prop="gatewayId" width="200" />
<el-table-column align="left" label="设备号" prop="imei" width="200" />
<el-table-column align="left" label="网关mac" prop="gatewayMac" width="200" />
<el-table-column align="left" label="网关地址" prop="gatewayAddress" />
<el-table-column align="left" label="经纬度" width="250">
<template #default="scope">
<span>{{ scope.row.gatewayLong }}</span>
<el-divider direction="vertical" />
<span>{{ scope.row.gatewayLat }}</span>
</template>
</el-table-column>
</el-table>
<div class="gva-pagination">
<el-pagination
:current-page="page"
:page-size="pageSize"
:page-sizes="[10, 30, 50, 100]"
:total="total"
layout="total, sizes, prev, pager, next, jumper"
@current-change="handleCurrentChange"
@size-change="handleSizeChange"
/>
</div>
</div>
</div>
</template>
<script setup>
import * as serve from '@/api/equipment/alarmRecord'
import { nextTick, ref, watch, onMounted } from 'vue'
import { ElMessage, ElMessageBox } from 'element-plus'
// import { id } from 'element-plus/es/locale'
import { useAppStore } from '@/pinia'
const appStore = useAppStore()
const searchInfo = ref({
username: '',
nickname: '',
phone: '',
email: ''
})
const page = ref(1)
const total = ref(0)
const pageSize = ref(10)
const tableData = ref([])
onMounted(() => {
getTableData()
})
// 分页
const handleSizeChange = (val) => {
pageSize.value = val
getTableData()
}
const handleCurrentChange = (val) => {
page.value = val
getTableData()
}
// 查询
const getTableData = async () => {
const table = await serve.getDeviceWarnList({
page: page.value,
pageSize: pageSize.value,
...searchInfo.value
})
if (table.code === 0) {
tableData.value = table.data.list
total.value = table.data.total
page.value = table.data.page
pageSize.value = table.data.pageSize
}
}
const onSubmit = () => {
page.value = 1
getTableData()
}
const onReset = () => {
searchInfo.value = {
username: '',
nickname: '',
phone: '',
email: ''
}
getTableData()
}
</script>
<style lang="scss">
.header-img-box {
@apply w-52 h-52 border border-solid border-gray-300 rounded-xl flex justify-center items-center cursor-pointer;
}
</style>

View File

@@ -31,11 +31,11 @@
{{ row.cbId || '未设置' }}
</template>
</el-table-column>
<el-table-column align="left" label="项目ID" prop="projectId">
<!-- <el-table-column align="left" label="项目ID" prop="projectId">
<template #default="{ row }">
{{ row.projectId || '未设置' }}
</template>
</el-table-column>
</el-table-column> -->
<el-table-column align="left" label="网关ID" prop="gatewayId">
<template #default="{ row }">
{{ row.gatewayId || '未设置' }}
@@ -48,6 +48,13 @@
}}</el-tag>
</template>
</el-table-column>
<el-table-column align="left" label="锁定状态">
<template #default="{ row }">
<el-tag :type="['success', 'info', 'danger'][row.lockStatus]">{{
['正常', '远程合闸禁止', '锁定'][row.lockStatus]
}}</el-tag>
</template>
</el-table-column>
<el-table-column align="left" label="网络">
<template #default="{ row }">
<el-tag :type="row.netStatus == 1 ? 'primary' : 'info'">{{ row.netStatus == 1 ? '在线' : '离线' }}</el-tag>
@@ -55,20 +62,44 @@
</el-table-column>
<el-table-column align="left" label="设备类型名称" prop="cbTypeName" />
<el-table-column align="left" label="网关mac" prop="gatewayMac" />
<el-table-column align="left" label="协议" prop="protocol" />
<el-table-column align="left" label="品牌" prop="brand" />
<el-table-column align="left" label="安装时间" prop="createTime">
<template #default="{ row }">
{{ row.createTime || '未设置' }}
</template>
</el-table-column>
<el-table-column label="操作" fixed="right">
<el-table-column label="操作" fixed="right" width="240">
<template #default="{ row }">
<el-link v-if="row.deviceStatus == 1" underline="never" type="primary" @click="changeStatus(row)"
>分闸</el-link
>
<el-link v-else underline="never" type="primary" @click="changeStatus(row)">合闸</el-link>
<!-- <el-button type="primary" link icon="delete" @click="deleteUserFunc(row)">删除</el-button> -->
<!-- <el-button type="primary" link icon="edit" @click="openEdit(row)">编辑</el-button> -->
<span class="action-buttons">
<el-button v-if="row.deviceStatus == 1" type="primary" link icon="SortUp" @click="changeStatus(row)">
分闸
</el-button>
<el-button v-else type="primary" link icon="SortDown" @click="changeStatus(row)">合闸</el-button>
<el-button v-if="[1].includes(row.lockStatus)" type="primary" link icon="Unlock" @click="unlock(row)">
解锁
</el-button>
<el-dropdown>
<span class="el-dropdown-link">
更多
<el-icon class="el-icon--right">
<arrow-down />
</el-icon>
</span>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item>
<el-button type="primary" link icon="Odometer" @click="updateParticulars(row)">
实时数据
</el-button>
</el-dropdown-item>
</el-dropdown-menu>
</template>
</el-dropdown>
</span>
</template>
</el-table-column>
</el-table>
@@ -109,7 +140,35 @@
onMounted(() => {
getTableData()
})
// 解锁
const unlock = async (row) => {
ElMessageBox.confirm('确认解锁吗?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning'
}).then(async () => {
const res = await serve.deviceOperation({
id: row.ID,
gatewayId: row.gatewayId,
para: '0xAD'
})
if (res.code === 0) {
ElMessage.success('操作成功')
getTableData()
}
})
}
// 更新
const updateParticulars = async (row) => {
const res = await serve.getDeviceDetailsInfoByRemote({
deviceId: row.ID
})
if (res.code === 0) {
ElMessage.success('更新成功')
} else {
// ElMessage.error(res.msg || '更新失败')
}
}
// 合分闸
const changeStatus = (row) => {
ElMessageBox.confirm(row.deviceStatus == 1 ? '确认分闸吗?' : '确认合闸吗?', '提示', {
@@ -166,8 +225,20 @@
}
</script>
<style lang="scss">
<style lang="scss" scoped>
.header-img-box {
@apply w-52 h-52 border border-solid border-gray-300 rounded-xl flex justify-center items-center cursor-pointer;
}
.action-buttons {
display: flex;
align-items: center;
flex-wrap: wrap;
gap: 8px;
}
.el-dropdown-link {
cursor: pointer;
color: var(--el-color-primary);
// display: flex;
// align-items: center;
}
</style>

View File

@@ -21,9 +21,10 @@
<!-- <el-button type="primary" icon="plus" @click="addUser">新增用户</el-button> -->
</div>
<el-table :data="tableData" row-key="ID">
<el-table-column align="left" label="设备ID" prop="deviceId"> </el-table-column>
<el-table-column align="left" label="运行时长" prop="runtime">
<template #default="{ row }">
{{ row.runtime || '' }}
<span>{{ row.runtime || '' }}</span>
</template>
</el-table-column>
<el-table-column align="left" label="信号质量" prop="signalQuality">
@@ -31,7 +32,12 @@
{{ row.signalQuality || '' }}
</template>
</el-table-column>
<el-table-column align="left" label="漏电流值" prop="leakageCurrent">
<el-table-column align="left" label="电压V" prop="leakageCurrent">
<template #default="{ row }">
{{ row.leakageCurrent || '' }}
</template>
</el-table-column>
<el-table-column align="left" label="漏电流值mA" prop="leakageCurrent">
<template #default="{ row }">
{{ row.leakageCurrent || '' }}
</template>
@@ -41,36 +47,31 @@
{{ row.cumulativeElectricity || '' }}
</template>
</el-table-column>
<el-table-column align="left" label="电流值" prop="current">
<el-table-column align="left" label="电流值A" prop="current">
<template #default="{ row }">
{{ row.current || '' }}
</template>
</el-table-column>
<el-table-column align="left" label="功率因数" prop="powerFactor">
<template #default="{ row }">
{{ row.powerFactor || '' }}
</template>
</el-table-column>
<el-table-column align="left" label="内部温度" prop="internalTemperature">
<el-table-column align="left" label="内部温度(℃)" prop="internalTemperature">
<template #default="{ row }">
{{ row.internalTemperature || '' }}
</template>
</el-table-column>
<el-table-column align="left" label="N相下端温度" prop="nLowerTemperature">
<el-table-column align="left" label="N相下端温度(℃)" prop="nLowerTemperature">
<template #default="{ row }">
{{ row.nLowerTemperature || '' }}
</template>
</el-table-column>
<el-table-column align="left" label="功率因数" prop="powerFactor">
<el-table-column align="left" label="功率因数%" prop="powerFactor">
<template #default="{ row }">
{{ row.powerFactor || '' }}
</template>
</el-table-column>
<el-table-column label="操作" fixed="right">
<template #default="scope">
<template #default="{ row }">
<!-- <el-button type="primary" link icon="delete" @click="deleteUserFunc(scope.row)">删除</el-button> -->
<!-- <el-button type="primary" link icon="edit" @click="openEdit(scope.row)">编辑</el-button> -->
<!-- <el-button type="primary" link icon="Tickets" @click="openDetails(row)">查看</el-button> -->
</template>
</el-table-column>
</el-table>

View File

@@ -1,5 +1,5 @@
<template>
<div id="userLayout" class="w-full h-full relative">
<div id="userLayout" class="w-full h-full relative login-light-mode">
<div
class="rounded-lg flex items-center justify-evenly w-full h-full md:w-screen md:h-screen md:bg-[#194bfb] bg-white"
>