All files / use-queue/src types.ts

0% Statements 0/0
0% Branches 0/0
0% Functions 0/0
0% Lines 0/0

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79                                                                                                                                                             
/**
 * Accepted initial value for {@link useQueue}.
 *
 * Mirrors `useState`'s lazy-initializer support: pass an array, any iterable of
 * values, or a function returning one of those (evaluated once on mount). The
 * first element becomes the front of the queue (the next item to be dequeued).
 *
 * @template T - Element type.
 *
 * @example
 * ```ts
 * useQueue<string>();                  // empty
 * useQueue<string>(["a", "b"]);        // "a" is the front
 * useQueue(new Set(["a", "b"]));       // any iterable works
 * useQueue(() => expensiveInit());     // lazy
 * ```
 */
export type QueueInitializer<T> = Iterable<T> | (() => Iterable<T>);
 
/**
 * Stable action handlers returned by {@link useQueue}. Every function keeps a
 * stable identity across renders, so the actions object is safe to use as a
 * `useEffect`/`useMemo` dependency.
 *
 * @template T - Element type.
 */
export interface UseQueueActions<T> {
  /**
   * Enqueue one or more items onto the back of the queue. Calling with no
   * arguments is a no-op and does not trigger a re-render.
   */
  add: (...items: T[]) => void;
 
  /**
   * Dequeue the front item: remove it from the queue and return it. Returns
   * `undefined` when the queue is empty (in which case it is a no-op and does
   * not trigger a re-render).
   *
   * The returned value reflects the front of the queue at call time. When
   * `remove` is called multiple times synchronously within the same event
   * (before React re-renders), each call returns the same front snapshot even
   * though the underlying state correctly advances — read the returned `queue`
   * array after the render for the settled state.
   */
  remove: () => T | undefined;
 
  /**
   * Peek at the front item (the next item that `remove` would return) without
   * mutating the queue. Returns `undefined` when the queue is empty. Stable
   * across renders and always reflects the latest state.
   */
  peek: () => T | undefined;
 
  /**
   * Remove every item. Clearing an already-empty queue is a no-op.
   */
  clear: () => void;
 
  /**
   * Reset the queue back to the initial value provided at mount (a fresh copy,
   * so later mutations never affect the stored initial).
   */
  reset: () => void;
}
 
/**
 * Return type of {@link useQueue}: a tuple of the current (read-only) queue and
 * the stable action handlers.
 *
 * The queue is typed as `readonly T[]` on purpose — mutating it directly (e.g.
 * `queue.push(...)`) would bypass React state and break immutability, so the
 * type steers callers to the actions instead. Read access works as usual:
 * `queue[0]` is the front, `queue[queue.length - 1]` is the back, and
 * `queue.length` is the size.
 *
 * @template T - Element type.
 */
export type UseQueueReturn<T> = [readonly T[], UseQueueActions<T>];