完善onenet和ctwing日志查询

This commit is contained in:
ChenYi 2025-07-17 14:01:07 +08:00
parent 113f24cc9d
commit 0ce33054d8
2 changed files with 209 additions and 70 deletions

View File

@ -2,13 +2,13 @@
import type { VbenFormProps } from '#/adapter/form'; import type { VbenFormProps } from '#/adapter/form';
import type { VxeGridProps } from '#/adapter/vxe-table'; import type { VxeGridProps } from '#/adapter/vxe-table';
import { ref, watch } from 'vue'; import { onMounted, ref, watch } from 'vue';
import { useRoute } from 'vue-router'; import { useRoute } from 'vue-router';
import { Page } from '@vben/common-ui'; import { Page } from '@vben/common-ui';
import { useVbenVxeGrid } from '#/adapter/vxe-table'; import { useVbenVxeGrid } from '#/adapter/vxe-table';
import { postCTWingLogInfoPage } from '#/api-client'; import { postMetersPage, postCTWingLogInfoPage } from '#/api-client';
import DeviceSelect from '../deviceData/DeviceSelect.vue'; import DeviceSelect from '../deviceData/DeviceSelect.vue';
import { querySchema, tableSchema } from './schema'; import { querySchema, tableSchema } from './schema';
@ -26,6 +26,53 @@ const deviceSelectRef = ref();
// //
const selectedDeviceInfo = ref<any>(null); const selectedDeviceInfo = ref<any>(null);
//
const deviceOptions = ref<any[]>();
//
const fetchDeviceOptions = async () => {
try {
const { data } = await postMetersPage({
body: {
pageIndex: 1,
pageSize: 1000,
},
});
if (data?.items) {
deviceOptions.value = data.items;
}
} catch (error) {
console.error('获取设备信息失败:', error);
}
};
// ID
const getDeviceInfoById = (deviceId: string) => {
console.log('getDeviceInfoById 调用:', { deviceId, deviceOptionsLength: deviceOptions.value?.length });
if (!deviceId || !deviceOptions.value || deviceOptions.value.length === 0) {
console.log('getDeviceInfoById 返回 null - 条件不满足');
return null;
}
//
console.log('前3构:', deviceOptions.value.slice(0, 3).map(device => ({
id: device.id,
meterName: device.meterName,
meterId: device.meterId,
focusId: device.focusId,
systemName: device.systemName,
keys: Object.keys(device),
fullDevice: JSON.parse(JSON.stringify(device)) //
})));
const device = deviceOptions.value.find((device) => device.id === deviceId);
console.log('查找结果:', device);
return device;
};
// //
const formatDate = (date: any) => { const formatDate = (date: any) => {
if (!date) return ''; if (!date) return '';
@ -33,8 +80,99 @@ const formatDate = (date: any) => {
if (date.toISOString) return date.format('YYYY-MM-DD HH:mm:ss'); if (date.toISOString) return date.format('YYYY-MM-DD HH:mm:ss');
return ''; return '';
}; };
// DeviceSelect
const getDeviceInfoFromRef = async () => {
if (
deviceSelectRef.value &&
typeof deviceSelectRef.value.getSelectedDevice === 'function'
) {
const deviceInfo = deviceSelectRef.value.getSelectedDevice();
console.log('从 ref 获取设备信息:', deviceInfo);
return deviceInfo;
}
return null;
};
const formOptions: VbenFormProps = { const formOptions: VbenFormProps = {
schema: querySchema.value, schema: querySchema.value,
// 使
submitOnChange: false,
//
handleValuesChange: async (values, changedFields) => {
console.log('handleValuesChange 被触发:', { values, changedFields });
console.log('当前所有表单值:', values);
console.log('DeviceType:', values.DeviceType);
console.log('IoTDataType:', values.IoTDataType);
// DeviceId selectedDeviceInfo
if (changedFields.includes('DeviceId')) {
const deviceId = values.DeviceId;
console.log('DeviceId 变化:', deviceId);
if (deviceId) {
// deviceOptions
let device = deviceOptions.value.length > 0 ? deviceOptions.value.find(d => d.id === deviceId) : null;
// DeviceSelect
if (!device && gridApi?.formApi) {
try {
// DeviceSelect
const deviceSelectRef = gridApi.formApi.getFieldComponentRef('DeviceId');
if (deviceSelectRef && deviceSelectRef.getSelectedDevice) {
device = deviceSelectRef.getSelectedDevice();
}
} catch (error) {
console.log('获取组件实例失败:', error);
}
}
if (device) {
selectedDeviceInfo.value = device;
console.log('handleValuesChange 更新设备信息:', device);
} else {
//
setTimeout(() => {
try {
const deviceSelectRef = gridApi.formApi.getFieldComponentRef('DeviceId');
if (deviceSelectRef && deviceSelectRef.getSelectedDevice) {
const delayedDevice = deviceSelectRef.getSelectedDevice();
if (delayedDevice) {
selectedDeviceInfo.value = delayedDevice;
console.log('延迟获取设备信息成功:', delayedDevice);
}
}
} catch (error) {
console.log('延迟获取组件实例失败:', error);
}
}, 100);
}
} else {
selectedDeviceInfo.value = null;
}
}
//
const relevantFields = new Set([
'DeviceId',
'DeviceType',
'IoTDataType',
'SystemName',
'StartCreationTime',
'EndCreationTime',
]);
const hasRelevantChange = changedFields.some((field) =>
relevantFields.has(field),
);
if (hasRelevantChange) {
// 使 setTimeout
setTimeout(async () => {
const latestValues = await gridApi.formApi.getValues();
gridApi.reload(latestValues);
}, 0);
}
},
}; };
const gridOptions: VxeGridProps<any> = { const gridOptions: VxeGridProps<any> = {
@ -45,18 +183,11 @@ const gridOptions: VxeGridProps<any> = {
columns: tableSchema.value, columns: tableSchema.value,
height: 'auto', height: 'auto',
keepSource: true, keepSource: true,
//
pager: true,
pagerConfig: { pagerConfig: {
currentPage: 1, currentPage: 1,
pageSize: 10, pageSize: 20,
pageSizes: [10, 20, 100],
layouts: [
'PrevPage',
'JumpNumber',
'NextPage',
'FullJump',
'Sizes',
'Total',
],
}, },
toolbarConfig: { toolbarConfig: {
custom: true, custom: true,
@ -67,36 +198,56 @@ const gridOptions: VxeGridProps<any> = {
proxyConfig: { proxyConfig: {
ajax: { ajax: {
query: async ({ page }, formValues) => { query: async ({ page }, formValues) => {
// formValuesAPI
const currentFormValues = formValues || (gridApi?.formApi ? await gridApi.formApi.getValues() : {}) || {};
console.log('查询时的 formValues:', formValues);
console.log('查询时的 currentFormValues:', currentFormValues);
// //
let deviceId = ''; let deviceId = currentFormValues.DeviceId || '';
let systemName = ''; let systemName = '';
const deviceType = formValues?.DeviceType || ''; const deviceType = currentFormValues.DeviceType || '';
const finalFocusAddress = formValues.FocusAddress || '';
if (deviceSelectRef.value) { console.log('查询参数:', { deviceId, deviceType, currentFormValues });
const deviceInfo = deviceSelectRef.value.getSelectedDeviceInfo(); console.log('currentFormValues.DeviceId:', currentFormValues.DeviceId);
console.log('currentFormValues.DeviceType:', currentFormValues.DeviceType);
console.log('currentFormValues.IoTDataType:', currentFormValues.IoTDataType);
// 使
const deviceInfo = selectedDeviceInfo.value || (currentFormValues.DeviceId && deviceOptions.value.length > 0 ? getDeviceInfoById(currentFormValues.DeviceId) : null);
if (deviceInfo) { if (deviceInfo) {
finalFocusAddress = deviceInfo.focusAddress || ''; console.log('使用设备信息:', deviceInfo);
systemName = deviceInfo.systemName || ''; systemName = deviceInfo.systemName || '';
// 10focusIdmeterId // id
deviceId = if (Number(deviceType) === 10) {
Number(deviceType) === 10 // 使 focusId
? deviceInfo.focusId || '' deviceId = deviceInfo.focusId || deviceId;
: deviceInfo.meterId || ''; } else {
// 使 meterId
deviceId = deviceInfo.meterId || deviceId;
} }
} else {
console.log('没有找到设备信息,使用原始 deviceId:', deviceId);
} }
// //
const queryParams: any = { const queryParams = {
pageIndex: page.currentPage, pageIndex: page.currentPage,
pageSize: page.pageSize, pageSize: page.pageSize,
SearchKeyword: formValues?.SearchKeyword || '', SearchKeyword: currentFormValues.SearchKeyword || '',
DeviceType: deviceType, DeviceType: deviceType,
IoTDataType: formValues?.IoTDataType || '', IoTDataType: currentFormValues.IoTDataType || '',
DeviceId: deviceId, DeviceId: deviceId,
SystemName: systemName || formValues?.SystemName || '', SystemName: systemName || currentFormValues.SystemName || '',
StartCreationTime: formatDate(formValues?.StartCreationTime), StartCreationTime: formatDate(currentFormValues.StartCreationTime),
EndCreationTime: formatDate(formValues?.EndCreationTime), EndCreationTime: formatDate(currentFormValues.EndCreationTime),
FocusAddress: finalFocusAddress, FocusAddress: currentFormValues.FocusAddress || '',
}; };
console.log('最终查询参数:', queryParams);
if (DeviceType) queryParams.DeviceType = DeviceType; if (DeviceType) queryParams.DeviceType = DeviceType;
if (DeviceId) queryParams.DeviceId = DeviceId; if (DeviceId) queryParams.DeviceId = DeviceId;
const { data } = await postCTWingLogInfoPage({ const { data } = await postCTWingLogInfoPage({
@ -117,12 +268,13 @@ const [Grid, gridApi] = useVbenVxeGrid({ formOptions, gridOptions });
// //
watch( watch(
() => gridApi?.pagerApi?.pageSize, () => gridApi?.pagerApi?.pageSize,
(newSize, oldSize) => { async (newSize, oldSize) => {
if (newSize !== oldSize && oldSize) { if (newSize !== oldSize && oldSize) {
// //
gridApi.pagerApi.currentPage = 1; gridApi.pagerApi.currentPage = 1;
// //
gridApi.reload(); const latestValues = await gridApi.formApi.getValues();
gridApi.reload(latestValues);
} }
}, },
); );
@ -130,23 +282,19 @@ watch(
// //
watch( watch(
() => gridApi?.pagerApi?.currentPage, () => gridApi?.pagerApi?.currentPage,
(newPage, oldPage) => { async (newPage, oldPage) => {
if (newPage !== oldPage && oldPage) { if (newPage !== oldPage && oldPage) {
// //
gridApi.reload(); const latestValues = await gridApi.formApi.getValues();
gridApi.reload(latestValues);
} }
}, },
); );
// DeviceId //
watch( onMounted(async () => {
() => gridApi?.getFormModel?.()?.DeviceId, await fetchDeviceOptions();
(newVal, oldVal) => { });
if (newVal !== oldVal) {
gridApi.reload();
}
},
);
</script> </script>
<template> <template>

View File

@ -182,18 +182,11 @@ const gridOptions: VxeGridProps<any> = {
columns: tableSchema.value, columns: tableSchema.value,
height: 'auto', height: 'auto',
keepSource: true, keepSource: true,
//
pager: true,
pagerConfig: { pagerConfig: {
currentPage: 1, currentPage: 1,
pageSize: 10, pageSize: 20,
pageSizes: [10, 20, 100],
layouts: [
'PrevPage',
'JumpNumber',
'NextPage',
'FullJump',
'Sizes',
'Total',
],
}, },
toolbarConfig: { toolbarConfig: {
custom: true, custom: true,
@ -273,32 +266,30 @@ const [Grid, gridApi] = useVbenVxeGrid({ formOptions, gridOptions });
// //
watch( watch(
() => gridApi?.pagerApi?.pageSize, () => gridApi?.pagerApi?.pageSize,
(newSize, oldSize) => { async (newSize, oldSize) => {
if (newSize !== oldSize && oldSize) { if (newSize !== oldSize && oldSize) {
//
gridApi.pagerApi.currentPage = 1; gridApi.pagerApi.currentPage = 1;
gridApi.reload(); //
const latestValues = await gridApi.formApi.getValues();
gridApi.reload(latestValues);
} }
}, },
); );
// //
watch( watch(
() => gridApi?.pagerApi?.currentPage, () => gridApi?.pagerApi?.currentPage,
(newPage, oldPage) => { async (newPage, oldPage) => {
if (newPage !== oldPage && oldPage) { if (newPage !== oldPage && oldPage) {
gridApi.reload(); //
} const latestValues = await gridApi.formApi.getValues();
}, gridApi.reload(latestValues);
);
// DeviceId
watch(
() => gridApi?.getFormModel?.()?.DeviceId,
(newVal, oldVal) => {
if (newVal !== oldVal) {
gridApi.reload();
} }
}, },
); );
// //
onMounted(async () => { onMounted(async () => {
await fetchDeviceOptions(); await fetchDeviceOptions();