修复分页异常问题

This commit is contained in:
ChenYi 2025-07-17 14:36:24 +08:00
parent 8b24e4219e
commit d699782bc9
2 changed files with 62 additions and 47 deletions

View File

@ -8,7 +8,7 @@ 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 { postMetersPage, postCTWingLogInfoPage } from '#/api-client'; import { postCTWingLogInfoPage, postMetersPage } 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';
@ -52,7 +52,7 @@ const getDeviceInfoById = (deviceId: string) => {
if (!deviceId || !deviceOptions.value || deviceOptions.value.length === 0) { if (!deviceId || !deviceOptions.value || deviceOptions.value.length === 0) {
return null; return null;
} }
const device = deviceOptions.value.find((device) => device.id === deviceId); const device = deviceOptions.value.find((device) => device.id === deviceId);
return device; return device;
}; };
@ -86,38 +86,43 @@ const formOptions: VbenFormProps = {
// DeviceId selectedDeviceInfo // DeviceId selectedDeviceInfo
if (changedFields.includes('DeviceId')) { if (changedFields.includes('DeviceId')) {
const deviceId = values.DeviceId; const deviceId = values.DeviceId;
if (deviceId) { if (deviceId) {
// deviceOptions // deviceOptions
let device = deviceOptions.value.length > 0 ? deviceOptions.value.find(d => d.id === deviceId) : null; let device =
deviceOptions.value.length > 0
? deviceOptions.value.find((d) => d.id === deviceId)
: null;
// DeviceSelect // DeviceSelect
if (!device && gridApi?.formApi) { if (!device && gridApi?.formApi) {
try { try {
// DeviceSelect // DeviceSelect
const deviceSelectRef = gridApi.formApi.getFieldComponentRef('DeviceId'); const deviceSelectRef =
gridApi.formApi.getFieldComponentRef('DeviceId');
if (deviceSelectRef && deviceSelectRef.getSelectedDevice) { if (deviceSelectRef && deviceSelectRef.getSelectedDevice) {
device = deviceSelectRef.getSelectedDevice(); device = deviceSelectRef.getSelectedDevice();
} }
} catch (error) { } catch {
// //
} }
} }
if (device) { if (device) {
selectedDeviceInfo.value = device; selectedDeviceInfo.value = device;
} else { } else {
// //
setTimeout(() => { setTimeout(() => {
try { try {
const deviceSelectRef = gridApi.formApi.getFieldComponentRef('DeviceId'); const deviceSelectRef =
gridApi.formApi.getFieldComponentRef('DeviceId');
if (deviceSelectRef && deviceSelectRef.getSelectedDevice) { if (deviceSelectRef && deviceSelectRef.getSelectedDevice) {
const delayedDevice = deviceSelectRef.getSelectedDevice(); const delayedDevice = deviceSelectRef.getSelectedDevice();
if (delayedDevice) { if (delayedDevice) {
selectedDeviceInfo.value = delayedDevice; selectedDeviceInfo.value = delayedDevice;
} }
} }
} catch (error) { } catch {
// //
} }
}, 100); }, 100);
@ -126,15 +131,15 @@ const formOptions: VbenFormProps = {
selectedDeviceInfo.value = null; selectedDeviceInfo.value = null;
} }
} }
// //
const relevantFields = new Set([ const relevantFields = new Set([
'DeviceId', 'DeviceId',
'DeviceType', 'DeviceType',
'IoTDataType',
'SystemName',
'StartCreationTime',
'EndCreationTime', 'EndCreationTime',
'IoTDataType',
'StartCreationTime',
'SystemName',
]); ]);
const hasRelevantChange = changedFields.some((field) => const hasRelevantChange = changedFields.some((field) =>
relevantFields.has(field), relevantFields.has(field),
@ -173,19 +178,23 @@ const gridOptions: VxeGridProps<any> = {
proxyConfig: { proxyConfig: {
ajax: { ajax: {
query: async ({ page }, formValues) => { query: async ({ page }, formValues) => {
// formValuesAPI // API
const currentFormValues = formValues || (gridApi?.formApi ? await gridApi.formApi.getValues() : {}) || {}; const currentFormValues = gridApi?.formApi ? await gridApi.formApi.getValues() : {};
// //
let deviceId = currentFormValues.DeviceId || ''; let deviceId = currentFormValues.DeviceId || '';
let systemName = ''; let systemName = '';
const deviceType = currentFormValues.DeviceType || ''; const deviceType = currentFormValues.DeviceType || '';
// 使 // 使
const deviceInfo = selectedDeviceInfo.value || (currentFormValues.DeviceId && deviceOptions.value.length > 0 ? getDeviceInfoById(currentFormValues.DeviceId) : null); const deviceInfo =
selectedDeviceInfo.value ||
(currentFormValues.DeviceId && deviceOptions.value.length > 0
? getDeviceInfoById(currentFormValues.DeviceId)
: null);
if (deviceInfo) { if (deviceInfo) {
systemName = deviceInfo.systemName || ''; systemName = deviceInfo.businessSystemName || '';
// id // id
if (Number(deviceType) === 10) { if (Number(deviceType) === 10) {
// 使 focusId // 使 focusId
@ -195,7 +204,6 @@ const gridOptions: VxeGridProps<any> = {
deviceId = deviceInfo.meterId || deviceId; deviceId = deviceInfo.meterId || deviceId;
} }
} }
// //
const queryParams = { const queryParams = {
pageIndex: page.currentPage, pageIndex: page.currentPage,
@ -209,7 +217,7 @@ const gridOptions: VxeGridProps<any> = {
EndCreationTime: formatDate(currentFormValues.EndCreationTime), EndCreationTime: formatDate(currentFormValues.EndCreationTime),
FocusAddress: currentFormValues.FocusAddress || '', FocusAddress: currentFormValues.FocusAddress || '',
}; };
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({

View File

@ -52,7 +52,7 @@ const getDeviceInfoById = (deviceId: string) => {
if (!deviceId || !deviceOptions.value || deviceOptions.value.length === 0) { if (!deviceId || !deviceOptions.value || deviceOptions.value.length === 0) {
return null; return null;
} }
const device = deviceOptions.value.find((device) => device.id === deviceId); const device = deviceOptions.value.find((device) => device.id === deviceId);
return device; return device;
}; };
@ -85,38 +85,43 @@ const formOptions: VbenFormProps = {
// DeviceId selectedDeviceInfo // DeviceId selectedDeviceInfo
if (changedFields.includes('DeviceId')) { if (changedFields.includes('DeviceId')) {
const deviceId = values.DeviceId; const deviceId = values.DeviceId;
if (deviceId) { if (deviceId) {
// deviceOptions // deviceOptions
let device = deviceOptions.value.length > 0 ? deviceOptions.value.find(d => d.id === deviceId) : null; let device =
deviceOptions.value.length > 0
? deviceOptions.value.find((d) => d.id === deviceId)
: null;
// DeviceSelect // DeviceSelect
if (!device && gridApi?.formApi) { if (!device && gridApi?.formApi) {
try { try {
// DeviceSelect // DeviceSelect
const deviceSelectRef = gridApi.formApi.getFieldComponentRef('DeviceId'); const deviceSelectRef =
gridApi.formApi.getFieldComponentRef('DeviceId');
if (deviceSelectRef && deviceSelectRef.getSelectedDevice) { if (deviceSelectRef && deviceSelectRef.getSelectedDevice) {
device = deviceSelectRef.getSelectedDevice(); device = deviceSelectRef.getSelectedDevice();
} }
} catch (error) { } catch {
// //
} }
} }
if (device) { if (device) {
selectedDeviceInfo.value = device; selectedDeviceInfo.value = device;
} else { } else {
// //
setTimeout(() => { setTimeout(() => {
try { try {
const deviceSelectRef = gridApi.formApi.getFieldComponentRef('DeviceId'); const deviceSelectRef =
gridApi.formApi.getFieldComponentRef('DeviceId');
if (deviceSelectRef && deviceSelectRef.getSelectedDevice) { if (deviceSelectRef && deviceSelectRef.getSelectedDevice) {
const delayedDevice = deviceSelectRef.getSelectedDevice(); const delayedDevice = deviceSelectRef.getSelectedDevice();
if (delayedDevice) { if (delayedDevice) {
selectedDeviceInfo.value = delayedDevice; selectedDeviceInfo.value = delayedDevice;
} }
} }
} catch (error) { } catch {
// //
} }
}, 100); }, 100);
@ -125,15 +130,15 @@ const formOptions: VbenFormProps = {
selectedDeviceInfo.value = null; selectedDeviceInfo.value = null;
} }
} }
// //
const relevantFields = new Set([ const relevantFields = new Set([
'DeviceId', 'DeviceId',
'DeviceType', 'DeviceType',
'IoTDataType',
'SystemName',
'StartCreationTime',
'EndCreationTime', 'EndCreationTime',
'IoTDataType',
'StartCreationTime',
'SystemName',
]); ]);
const hasRelevantChange = changedFields.some((field) => const hasRelevantChange = changedFields.some((field) =>
relevantFields.has(field), relevantFields.has(field),
@ -157,7 +162,6 @@ const gridOptions: VxeGridProps<any> = {
columns: tableSchema.value, columns: tableSchema.value,
height: 'auto', height: 'auto',
keepSource: true, keepSource: true,
//
pager: true, pager: true,
pagerConfig: { pagerConfig: {
currentPage: 1, currentPage: 1,
@ -172,19 +176,23 @@ const gridOptions: VxeGridProps<any> = {
proxyConfig: { proxyConfig: {
ajax: { ajax: {
query: async ({ page }, formValues) => { query: async ({ page }, formValues) => {
// formValuesAPI // API
const currentFormValues = formValues || (gridApi?.formApi ? await gridApi.formApi.getValues() : {}) || {}; const currentFormValues = gridApi?.formApi ? await gridApi.formApi.getValues() : {};
// //
let deviceId = currentFormValues.DeviceId || ''; let deviceId = currentFormValues.DeviceId || '';
let systemName = ''; let systemName = '';
const deviceType = currentFormValues.DeviceType || ''; const deviceType = currentFormValues.DeviceType || '';
// 使 // 使
const deviceInfo = selectedDeviceInfo.value || (currentFormValues.DeviceId && deviceOptions.value.length > 0 ? getDeviceInfoById(currentFormValues.DeviceId) : null); const deviceInfo =
selectedDeviceInfo.value ||
(currentFormValues.DeviceId && deviceOptions.value.length > 0
? getDeviceInfoById(currentFormValues.DeviceId)
: null);
if (deviceInfo) { if (deviceInfo) {
systemName = deviceInfo.systemName || ''; systemName = deviceInfo.businessSystemName || '';
// id // id
if (Number(deviceType) === 10) { if (Number(deviceType) === 10) {
// 使 focusId // 使 focusId
@ -194,7 +202,7 @@ const gridOptions: VxeGridProps<any> = {
deviceId = deviceInfo.meterId || deviceId; deviceId = deviceInfo.meterId || deviceId;
} }
} }
// //
const queryParams = { const queryParams = {
pageIndex: page.currentPage, pageIndex: page.currentPage,
@ -207,7 +215,7 @@ const gridOptions: VxeGridProps<any> = {
StartCreationTime: formatDate(currentFormValues.StartCreationTime), StartCreationTime: formatDate(currentFormValues.StartCreationTime),
EndCreationTime: formatDate(currentFormValues.EndCreationTime), EndCreationTime: formatDate(currentFormValues.EndCreationTime),
}; };
if (DeviceType) queryParams.DeviceType = DeviceType; if (DeviceType) queryParams.DeviceType = DeviceType;
if (DeviceId) queryParams.DeviceId = DeviceId; if (DeviceId) queryParams.DeviceId = DeviceId;
const { data } = await postOneNETLogInfoPage({ const { data } = await postOneNETLogInfoPage({
@ -251,7 +259,6 @@ watch(
}, },
); );
// //
onMounted(async () => { onMounted(async () => {
await fetchDeviceOptions(); await fetchDeviceOptions();