报警列表,持续时间动态计算

This commit is contained in:
fengerli
2025-09-20 14:25:32 +08:00
parent 517998a0db
commit eb4bb8c208
4 changed files with 161 additions and 8 deletions

View File

@ -89,16 +89,16 @@
<div class="label">报警事项</div>
<div class="alearm">
<template v-if="item.deviceAction === 0">强制报警
<span v-if="item.treatmentState === 1">({{ item.startTime.split(' ')[1] || '' }})</span>
<span v-if="item.treatmentState === 1">({{ item.timeDiff}})</span>
</template>
<template v-else-if="item.deviceAction === 1">撞击闯入
<span v-if="item.treatmentState === 1">({{ item.startTime.split(' ')[1] || '' }})</span>
<span v-if="item.treatmentState === 1">({{ item.timeDiff}})</span>
</template>
<template v-else-if="item.deviceAction === 2">自动报警
<span v-if="item.treatmentState === 1">({{ item.startTime.split(' ')[1] || '' }})</span>
<span v-if="item.treatmentState === 1">({{ item.timeDiff}})</span>
</template>
<template v-else-if="item.deviceAction === 3">电子围栏告警
<span v-if="item.treatmentState === 1">({{ item.startTime.split(' ')[1] || '' }})</span>
<span v-if="item.treatmentState === 1">({{ item.timeDiff}})</span>
</template>
</div>
<div class="label">报警地点</div>
@ -134,13 +134,14 @@
</el-table-column>
<el-table-column label="报警持续时间" align="center" prop="durationTime" width="180">
<template #default="scope">
<el-tag type="danger">{{ scope.row.durationTime }}</el-tag>
<el-tag type="danger">{{ scope.row.durationTime || '/' }}</el-tag>
</template>
</el-table-column>
<el-table-column label="处理状态" align="center" prop="treatmentState">
<template #default="scope">
<div class="ysStatus" v-if="scope.row.treatmentState == 0">已处理</div>
<el-tag type="danger" v-if="scope.row.treatmentState == 1">未处理</el-tag>
</template>
</el-table-column>
<el-table-column label="报警时间" align="center" prop="startTime" />
@ -156,8 +157,10 @@
import { listAlarm } from '@/api/equipmentAlarmRecord/index';
import { AlarmVO, AlarmQuery, AlarmForm } from '@/api/equipmentAlarmRecord/types';
import apiTypeAll from '@/api/equipmentManagement/device/index';
import { TimeConverter } from '@/utils/timeConverter';
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
const alarmList = ref<AlarmVO[]>([]);
const timers = ref<Record<string, number>>({});
const isListView = ref(true);
const dateRange = ref(['', '']);
const loading = ref(true);
@ -220,12 +223,47 @@ const getList = async () => {
};
const res = await listAlarm(queryParams.value);
if (res.rows) {
alarmList.value = res.rows;
// 先清除已有定时器
clearAllTimers();
//alarmList.value = res.rows;
// 为每个项添加timeDiff属性并初始化
alarmList.value = res.rows.map(item => ({
...item,
timeDiff: '' // 用于存储计算出的时间差
}));
total.value = res.total;
// 为每个需要计时的项创建定时器
initTimers();
}
loading.value = false;
}
// 初始化所有定时器
const initTimers = () => {
alarmList.value.forEach(item => {
// 只对需要计时的项创建定时器(根据你的业务逻辑判断)
if (item.treatmentState === 1 && item.startTime) {
// 使用项的唯一标识作为定时器键名假设id是唯一标识
timers.value[item.id] = TimeConverter.createTimeDiffTimer(
item.startTime,
(diff) => {
// 找到对应的项并更新时间差
const index = alarmList.value.findIndex(i => i.id === item.id);
if (index !== -1) {
alarmList.value[index].timeDiff = diff;
}
}
);
}
});
};
// 清除所有定时器
const clearAllTimers = () => {
Object.values(timers.value).forEach(timerId => {
TimeConverter.clearTimeDiffTimer(timerId);
});
timers.value = {};
};
// 设备类型
const getDeviceType = () => {
apiTypeAll.deviceTypeAll().then(res => {

View File

@ -288,6 +288,7 @@
import { addMenu, cascadeDelMenu, delMenu, getMenu, listMenu, updateMenu } from '@/api/system/menu';
import { MenuForm, MenuQuery, MenuVO } from '@/api/system/menu/types';
import { MenuTypeEnum } from '@/enums/MenuTypeEnum';
import { log } from 'console';
interface MenuOptionsType {
menuId: number;
@ -324,6 +325,7 @@ const initFormData = {
visible: '0',
status: '0'
};
const data = reactive<PageData<MenuForm, MenuQuery>>({
form: { ...initFormData },
queryParams: {