chore: fix generic data provider isUpdate (#1560)
This commit is contained in:
parent
96811b45e3
commit
1d87eab47c
@ -5,8 +5,15 @@ import type {
|
||||
Subscribe,
|
||||
Load,
|
||||
UpdateCallback,
|
||||
UpdateDelta,
|
||||
} from '../lib/generic-data-provider';
|
||||
|
||||
function hasDelta<T>(
|
||||
updateData: UpdateDelta<T>
|
||||
): updateData is Required<UpdateDelta<T>> {
|
||||
return !!updateData.isUpdate;
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
* @param dataProvider subscribe function created by makeDataProvider
|
||||
@ -63,16 +70,16 @@ export function useDataProvider<Data, Delta>({
|
||||
return Promise.reject();
|
||||
}, []);
|
||||
const callback = useCallback<UpdateCallback<Data, Delta>>(
|
||||
({
|
||||
data,
|
||||
error,
|
||||
loading,
|
||||
delta,
|
||||
insertionData,
|
||||
totalCount,
|
||||
isInsert,
|
||||
isUpdate,
|
||||
}) => {
|
||||
(arg) => {
|
||||
const {
|
||||
data,
|
||||
error,
|
||||
loading,
|
||||
insertionData,
|
||||
totalCount,
|
||||
isInsert,
|
||||
isUpdate,
|
||||
} = arg;
|
||||
setError(error);
|
||||
setLoading(loading);
|
||||
if (!error && !loading) {
|
||||
@ -83,7 +90,8 @@ export function useDataProvider<Data, Delta>({
|
||||
isUpdate &&
|
||||
!noUpdate &&
|
||||
update &&
|
||||
(!delta || update({ delta, data }))
|
||||
hasDelta<Delta>(arg) &&
|
||||
update({ delta: arg.delta, data })
|
||||
) {
|
||||
return;
|
||||
}
|
||||
|
@ -9,10 +9,13 @@ import type { Subscription } from 'zen-observable-ts';
|
||||
import isEqual from 'lodash/isEqual';
|
||||
import type { Pagination as PaginationWithoutSkip } from '@vegaprotocol/types';
|
||||
|
||||
interface UpdateData<Data, Delta> {
|
||||
export interface UpdateDelta<Delta> {
|
||||
delta?: Delta;
|
||||
insertionData?: Data | null;
|
||||
isUpdate?: boolean;
|
||||
}
|
||||
|
||||
interface UpdateData<Data, Delta> extends UpdateDelta<Delta> {
|
||||
insertionData?: Data | null;
|
||||
isInsert?: boolean;
|
||||
}
|
||||
export interface UpdateCallback<Data, Delta> {
|
||||
@ -557,13 +560,13 @@ function makeDerivedDataProviderInternal<Data, Delta>(
|
||||
: data;
|
||||
if (newLoaded) {
|
||||
const updatedPart = parts[updatedPartIndex];
|
||||
if (updatedPart.isUpdate && updatedPart.delta && combineDelta) {
|
||||
delta = combineDelta(parts, variables);
|
||||
if (updatedPart.isUpdate) {
|
||||
isUpdate = true;
|
||||
if (updatedPart.delta && combineDelta) {
|
||||
delta = combineDelta(parts, variables);
|
||||
}
|
||||
delete updatedPart.isUpdate;
|
||||
delete updatedPart.delta;
|
||||
if (delta) {
|
||||
isUpdate = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
if (
|
||||
|
Loading…
Reference in New Issue
Block a user