Я делаю запрос GraphQL для загрузки данных в мою таблицу пользовательского интерфейса материалов. Я хочу, чтобы он загружал больше данных при прокрутке.
Данные заносятся в таблицу корректно, нумерация страниц работает некорректно.
return (
<Query
query = {MESSAGE_QUERY}
variables = {{
where: getQueryVariables({
date,
}),
limit: 50,
offset: 0,
sortingOrder,
}}
fetchPolicy = "cache-and-network"
>
{({ data, fetchMore }: QueryResult) => {
fetchMore({
variables: {
offset: data.message
? data.message.length
: 0,
},
updateQuery: (
prevResult: { DataRowProps: any },
{ fetchMoreResult }: any,
) => {
if (!fetchMoreResult) return prevResult;
return Object.assign({}, prevResult, {
...fetchMoreResult.DataRowProps,
});
},
});
return data.message
? data.message.map(
(rowData: DataRowProps, index: number) => {
return containmentDOMRect ? (
<VisibilitySensor
containment = {containmentDOMRect.current || undefined}
onChange = {isVisible =>
isVisible && index % LOAD_SIZE === 0 && index >= LOAD_SIZE
? loadMoreData(index)
: undefined
}
>
<DataRowComponent
{...rowData}
index = {index}
selectedRow = {selectedRow}
callBack = {callBack}
/>
</VisibilitySensor>
) : null;
},
)
: null;
}}
</Query>
);
};
Я не вижу никаких ошибок при запуске кода, но он не загружает больше данных при прокрутке. Я удалил некоторый неважный код из-за ограничений на переполнение стека, дайте мне знать, если это необходимо. Любая помощь высоко ценится.
Правильный способ использования функций запроса fecthMore и обновления находится внутри тега VisibilitySensor:
{({ data, fetchMore }: QueryResult) => {
return data.vitm_truck_message
? data.vitm_truck_message.map(
(rowData: DataRowProps, index: number) => {
const visibilitySensorKey = rowData.message_type.name
.concat(rowData.message_sub_type.name)
.concat(rowData.created_time);
return containmentDOMRect ? (
<VisibilitySensor
key = {visibilitySensorKey}
containment = {containmentDOMRect.current || undefined}
scrollCheck
onChange = {isVisible =>
isVisible && index % LOAD_SIZE === 0 && index >= LOAD_SIZE
? fetchMore({
variables: {
offset: data.vitm_truck_message
? data.vitm_truck_message.length
: 0,
},
updateQuery: (
prev: any,
{ fetchMoreResult }: any,
) => {
if (
fetchMoreResult.vitm_truck_message.length !== 0
) {
offsetValue = data.vitm_truck_message.length;
prev.vitm_truck_message.forEach(
(element: object) => {
if (
data.vitm_truck_message.indexOf(element) <
0
) {
data.vitm_truck_message.push(element);
}
},
);
fetchMoreResult.vitm_truck_message.forEach(
(element: object) => {
if (
data.vitm_truck_message.indexOf(element) <
0
) {
data.vitm_truck_message.push(element);
}
},
);
}
return prev;
},
})
: undefined
}
>
<DataRowComponent
{...rowData}
index = {index}
selectedRow = {selectedRow}
callBack = {callBack}
/>
</VisibilitySensor>
) : null;
},
)
: null;
}}