mirror of
https://github.com/langgenius/dify.git
synced 2025-11-20 15:01:46 +00:00
23 lines
602 B
TypeScript
23 lines
602 B
TypeScript
|
|
import {
|
||
|
|
useCallback,
|
||
|
|
useRef,
|
||
|
|
} from 'react'
|
||
|
|
|
||
|
|
export const useSerialAsyncCallback = <Args extends any[], Result = void>(
|
||
|
|
fn: (...args: Args) => Promise<Result> | Result,
|
||
|
|
shouldSkip?: () => boolean,
|
||
|
|
) => {
|
||
|
|
const queueRef = useRef<Promise<unknown>>(Promise.resolve())
|
||
|
|
|
||
|
|
return useCallback((...args: Args) => {
|
||
|
|
if (shouldSkip?.())
|
||
|
|
return Promise.resolve(undefined as Result)
|
||
|
|
|
||
|
|
const lastPromise = queueRef.current.catch(() => undefined)
|
||
|
|
const nextPromise = lastPromise.then(() => fn(...args))
|
||
|
|
queueRef.current = nextPromise
|
||
|
|
|
||
|
|
return nextPromise
|
||
|
|
}, [fn, shouldSkip])
|
||
|
|
}
|