Files
cinny/src/app/components/SpecVersionsLoader.tsx
T

44 lines
1.1 KiB
TypeScript
Raw Normal View History

import { ReactNode, useCallback, useEffect, useState } from 'react';
2024-01-21 23:50:56 +11:00
import { AsyncStatus, useAsyncCallback } from '../hooks/useAsyncCallback';
import { SpecVersions, specVersions } from '../cs-api';
type SpecVersionsLoaderProps = {
baseUrl: string;
2024-01-21 23:50:56 +11:00
fallback?: () => ReactNode;
error?: (err: unknown, retry: () => void, ignore: () => void) => ReactNode;
2024-01-21 23:50:56 +11:00
children: (versions: SpecVersions) => ReactNode;
};
export function SpecVersionsLoader({
baseUrl,
fallback,
error,
children,
}: SpecVersionsLoaderProps) {
2024-01-21 23:50:56 +11:00
const [state, load] = useAsyncCallback(
useCallback(() => specVersions(fetch, baseUrl), [baseUrl])
);
const [ignoreError, setIgnoreError] = useState(false);
const ignoreCallback = useCallback(() => setIgnoreError(true), []);
2024-01-21 23:50:56 +11:00
useEffect(() => {
load();
}, [load]);
if (state.status === AsyncStatus.Idle || state.status === AsyncStatus.Loading) {
return fallback?.();
}
if (!ignoreError && state.status === AsyncStatus.Error) {
return error?.(state.error, load, ignoreCallback);
2024-01-21 23:50:56 +11:00
}
return children(
state.status === AsyncStatus.Success
? state.data
: {
versions: [],
}
);
2024-01-21 23:50:56 +11:00
}