UNPKG

@tanstack/db

Version:

A reactive client store for building super fast apps on sync

46 lines (45 loc) 1.36 kB
import { ThrottleStrategy, ThrottleStrategyOptions } from './types.cjs'; /** * Creates a throttle strategy that ensures transactions are evenly spaced * over time. * * Provides smooth, controlled execution patterns ideal for UI updates like * sliders, progress bars, or scroll handlers where you want consistent * execution timing. * * @param options - Configuration for throttle behavior * @returns A throttle strategy instance * * @example * ```ts * // Throttle slider updates to every 200ms * const mutate = usePacedMutations({ * onMutate: (volume) => { * settingsCollection.update('volume', draft => { draft.value = volume }) * }, * mutationFn: async ({ transaction }) => { * await api.updateVolume(transaction.mutations) * }, * strategy: throttleStrategy({ wait: 200 }) * }) * ``` * * @example * ```ts * // Throttle with leading and trailing execution * const mutate = usePacedMutations({ * onMutate: (data) => { * collection.update(id, draft => { Object.assign(draft, data) }) * }, * mutationFn: async ({ transaction }) => { * await api.save(transaction.mutations) * }, * strategy: throttleStrategy({ * wait: 500, * leading: true, * trailing: true * }) * }) * ``` */ export declare function throttleStrategy(options: ThrottleStrategyOptions): ThrottleStrategy;