mirror of
https://github.com/stackblitz-labs/bolt.diy
synced 2025-01-26 04:37:04 +00:00
30 lines
783 B
TypeScript
30 lines
783 B
TypeScript
export function bufferWatchEvents<T extends unknown[]>(timeInMs: number, cb: (events: T[]) => unknown) {
|
|
let timeoutId: number | undefined;
|
|
let events: T[] = [];
|
|
|
|
// keep track of the processing of the previous batch so we can wait for it
|
|
let processing: Promise<unknown> = Promise.resolve();
|
|
|
|
const scheduleBufferTick = () => {
|
|
timeoutId = self.setTimeout(async () => {
|
|
// we wait until the previous batch is entirely processed so events are processed in order
|
|
await processing;
|
|
|
|
if (events.length > 0) {
|
|
processing = Promise.resolve(cb(events));
|
|
}
|
|
|
|
timeoutId = undefined;
|
|
events = [];
|
|
}, timeInMs);
|
|
};
|
|
|
|
return (...args: T) => {
|
|
events.push(args);
|
|
|
|
if (!timeoutId) {
|
|
scheduleBufferTick();
|
|
}
|
|
};
|
|
}
|