You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
257 lines
7.8 KiB
Vue
257 lines
7.8 KiB
Vue
<template>
|
|
<ContentWrap>
|
|
<el-form
|
|
class="-mb-15px real-time-monitoring-form"
|
|
:model="queryParams"
|
|
ref="queryFormRef"
|
|
:inline="true"
|
|
label-width="auto"
|
|
>
|
|
<el-form-item :label="t('DataCollection.RealTimeMonitoring.searchLineCodeLabel')" prop="lineNode">
|
|
<el-input
|
|
v-model="queryParams.lineNode"
|
|
:placeholder="t('DataCollection.RealTimeMonitoring.searchLineCodePlaceholder')"
|
|
clearable
|
|
@keyup.enter="handleQuery"
|
|
class="!w-240px"
|
|
/>
|
|
</el-form-item>
|
|
<el-form-item :label="t('DataCollection.RealTimeMonitoring.searchLineNameLabel')" prop="lineName">
|
|
<el-input
|
|
v-model="queryParams.lineName"
|
|
:placeholder="t('DataCollection.RealTimeMonitoring.searchLineNamePlaceholder')"
|
|
clearable
|
|
@keyup.enter="handleQuery"
|
|
class="!w-240px"
|
|
/>
|
|
</el-form-item>
|
|
<el-form-item :label="t('DataCollection.RealTimeMonitoring.searchDeviceCodeLabel')" prop="deviceCode">
|
|
<el-input
|
|
v-model="queryParams.deviceCode"
|
|
:placeholder="t('DataCollection.RealTimeMonitoring.searchDeviceCodePlaceholder')"
|
|
clearable
|
|
@keyup.enter="handleQuery"
|
|
class="!w-240px"
|
|
/>
|
|
</el-form-item>
|
|
<el-form-item :label="t('DataCollection.RealTimeMonitoring.searchDeviceNameLabel')" prop="deviceName">
|
|
<el-input
|
|
v-model="queryParams.deviceName"
|
|
:placeholder="t('DataCollection.RealTimeMonitoring.searchDeviceNamePlaceholder')"
|
|
clearable
|
|
@keyup.enter="handleQuery"
|
|
class="!w-240px"
|
|
/>
|
|
</el-form-item>
|
|
<el-form-item>
|
|
<el-button @click="handleQuery">
|
|
<Icon icon="ep:search" class="mr-5px" />
|
|
{{ t('DataCollection.RealTimeMonitoring.searchButtonText') }}
|
|
</el-button>
|
|
<el-button @click="resetQuery">
|
|
<Icon icon="ep:refresh" class="mr-5px" />
|
|
{{ t('DataCollection.RealTimeMonitoring.resetButtonText') }}
|
|
</el-button>
|
|
<el-button type="success" plain @click="handleExport" :loading="exportLoading">
|
|
<Icon icon="ep:download" class="mr-5px" />
|
|
{{ t('DataCollection.RealTimeMonitoring.exportButtonText') }}
|
|
</el-button>
|
|
</el-form-item>
|
|
</el-form>
|
|
</ContentWrap>
|
|
|
|
<ContentWrap>
|
|
<el-table
|
|
v-loading="loading"
|
|
:data="list"
|
|
:stripe="true"
|
|
:show-overflow-tooltip="true"
|
|
row-key="id"
|
|
@selection-change="handleSelectionChange"
|
|
>
|
|
<el-table-column type="selection" width="55" reserve-selection />
|
|
<el-table-column
|
|
:label="t('DataCollection.RealTimeMonitoring.tableDeviceCodeColumn')"
|
|
align="left"
|
|
prop="deviceCode"
|
|
min-width="140px"
|
|
/>
|
|
<el-table-column
|
|
:label="t('DataCollection.RealTimeMonitoring.tableDeviceNameColumn')"
|
|
align="left"
|
|
prop="deviceName"
|
|
min-width="160px"
|
|
/>
|
|
<el-table-column
|
|
:label="t('DataCollection.RealTimeMonitoring.tableLineCodeColumn')"
|
|
align="left"
|
|
prop="lineNode"
|
|
min-width="140px"
|
|
/>
|
|
<el-table-column
|
|
:label="t('DataCollection.RealTimeMonitoring.tableLineNameColumn')"
|
|
align="left"
|
|
prop="lineName"
|
|
min-width="160px"
|
|
/>
|
|
<!-- <el-table-column
|
|
:label="t('DataCollection.RealTimeMonitoring.tableStatusColumn')"
|
|
align="center"
|
|
prop="status"
|
|
width="120px"
|
|
>
|
|
<template #default="scope">
|
|
<dict-tag :type="DICT_TYPE.IOT_GATEWAY_STATUS" :value="scope.row.status" />
|
|
</template>
|
|
</el-table-column> -->
|
|
<el-table-column
|
|
:label="t('DataCollection.RealTimeMonitoring.tableCollectionTimeColumn')"
|
|
align="center"
|
|
prop="collectionTime"
|
|
:formatter="dateFormatter"
|
|
width="180px"
|
|
/>
|
|
<el-table-column
|
|
:label="t('DataCollection.RealTimeMonitoring.tableOperateColumn')"
|
|
align="center"
|
|
fixed="right"
|
|
width="150px"
|
|
>
|
|
<template #default="scope">
|
|
<el-button link type="primary" @click="handleSingleMonitor(scope.row)">
|
|
{{ t('DataCollection.RealTimeMonitoring.tableActionSingleMonitorLabel') }}
|
|
</el-button>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
<Pagination
|
|
:total="total" v-model:page="queryParams.pageNo" v-model:limit="queryParams.pageSize"
|
|
@pagination="getList" />
|
|
</ContentWrap>
|
|
|
|
<SingleDeviceMonitorDialog
|
|
v-model="monitorDialogVisible"
|
|
:device-id="monitorDeviceId"
|
|
:device-name="monitorDeviceName"
|
|
:collection-time="monitorCollectionTime"
|
|
/>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { DICT_TYPE } from '@/utils/dict'
|
|
import { dateFormatter } from '@/utils/formatTime'
|
|
import download from '@/utils/download'
|
|
import { DeviceApi, LineDeviceVO } from '@/api/iot/device'
|
|
import SingleDeviceMonitorDialog from './SingleDeviceMonitorDialog.vue'
|
|
|
|
defineOptions({ name: 'RealTimeMonitoring' })
|
|
|
|
const message = useMessage()
|
|
const { t } = useI18n()
|
|
|
|
const loading = ref(true)
|
|
const list = ref<LineDeviceVO[]>([])
|
|
const total = ref(0)
|
|
const exportLoading = ref(false)
|
|
const queryParams = reactive({
|
|
pageNo: 1,
|
|
pageSize: 10,
|
|
id: undefined,
|
|
lineNode: undefined,
|
|
lineName: undefined,
|
|
deviceCode: undefined,
|
|
deviceName: undefined,
|
|
status: undefined,
|
|
collectionTime: undefined
|
|
})
|
|
const queryFormRef = ref()
|
|
|
|
const selectedIds = ref<(string | number)[]>([])
|
|
const handleSelectionChange = (rows: LineDeviceVO[]) => {
|
|
selectedIds.value =
|
|
rows?.map((row) => ((row as any)?.id ?? (row as any)?.deviceId) as string | number).filter(
|
|
(id) => id !== undefined && id !== null && id !== ''
|
|
) ?? []
|
|
}
|
|
|
|
const monitorDialogVisible = ref(false)
|
|
const monitorDeviceId = ref<string | number>()
|
|
const monitorDeviceName = ref<string>()
|
|
const monitorCollectionTime = ref<string | number>()
|
|
|
|
const buildQueryParams = (): Parameters<typeof DeviceApi.getLineDevicePage>[0] => {
|
|
const params: Parameters<typeof DeviceApi.getLineDevicePage>[0] = {
|
|
pageNo: queryParams.pageNo,
|
|
pageSize: queryParams.pageSize
|
|
}
|
|
const keys = ['id', 'lineNode', 'lineName', 'deviceCode', 'deviceName', 'status', 'collectionTime'] as const
|
|
for (const key of keys) {
|
|
const value = queryParams[key]
|
|
if (value === undefined || value === null || value === '') {
|
|
continue
|
|
}
|
|
(params as any)[key] = value
|
|
}
|
|
return params
|
|
}
|
|
|
|
const getList = async () => {
|
|
loading.value = true
|
|
try {
|
|
const data = await DeviceApi.getLineDevicePage(buildQueryParams())
|
|
list.value = data.list
|
|
total.value = data.total
|
|
} finally {
|
|
loading.value = false
|
|
}
|
|
}
|
|
|
|
const handleQuery = () => {
|
|
queryParams.pageNo = 1
|
|
getList()
|
|
}
|
|
|
|
const resetQuery = () => {
|
|
queryFormRef.value.resetFields()
|
|
handleQuery()
|
|
}
|
|
|
|
const handleSingleMonitor = (row: LineDeviceVO) => {
|
|
const deviceId = (row as any)?.deviceId ?? row?.id
|
|
if (deviceId === undefined || deviceId === null || deviceId === '') {
|
|
message.error(t('DataCollection.RealTimeMonitoring.messageDeviceInfoIncomplete'))
|
|
return
|
|
}
|
|
monitorDeviceId.value = deviceId
|
|
monitorDeviceName.value = row?.deviceName ?? ''
|
|
monitorCollectionTime.value = row?.collectionTime
|
|
monitorDialogVisible.value = true
|
|
}
|
|
|
|
const handleExport = async () => {
|
|
try {
|
|
await message.exportConfirm()
|
|
exportLoading.value = true
|
|
const params: any = {
|
|
...buildQueryParams(),
|
|
ids: selectedIds.value.length ? selectedIds.value.join(',') : undefined
|
|
}
|
|
const data = await DeviceApi.exportLineDevice(params)
|
|
download.excel(data, t('DataCollection.RealTimeMonitoring.exportFilename'))
|
|
} catch {
|
|
} finally {
|
|
exportLoading.value = false
|
|
}
|
|
}
|
|
|
|
onMounted(() => {
|
|
getList()
|
|
})
|
|
</script>
|
|
|
|
<style scoped lang="scss">
|
|
.real-time-monitoring-form :deep(.el-form-item__label) {
|
|
min-width: 100px;
|
|
}
|
|
</style>
|