function queueStrategy(options?): QueueStrategy;
function queueStrategy(options?): QueueStrategy;
Defined in: packages/db/src/strategies/queueStrategy.ts:46
Creates a queue strategy that processes all mutations in order with proper serialization.
Unlike other strategies that may drop executions, queue ensures every mutation is processed sequentially. Each transaction commit completes before the next one starts. Useful when data consistency is critical and every operation must complete in order.
Configuration for queue behavior (FIFO/LIFO, timing, size limits)
A queue strategy instance
// FIFO queue - process in order received
const mutate = usePacedMutations({
mutationFn: async ({ transaction }) => {
await api.save(transaction.mutations)
},
strategy: queueStrategy({
wait: 200,
addItemsTo: 'back',
getItemsFrom: 'front'
})
})
// FIFO queue - process in order received
const mutate = usePacedMutations({
mutationFn: async ({ transaction }) => {
await api.save(transaction.mutations)
},
strategy: queueStrategy({
wait: 200,
addItemsTo: 'back',
getItemsFrom: 'front'
})
})
// LIFO queue - process most recent first
const mutate = usePacedMutations({
mutationFn: async ({ transaction }) => {
await api.save(transaction.mutations)
},
strategy: queueStrategy({
wait: 200,
addItemsTo: 'back',
getItemsFrom: 'back'
})
})
// LIFO queue - process most recent first
const mutate = usePacedMutations({
mutationFn: async ({ transaction }) => {
await api.save(transaction.mutations)
},
strategy: queueStrategy({
wait: 200,
addItemsTo: 'back',
getItemsFrom: 'back'
})
})
Your weekly dose of JavaScript news. Delivered every Monday to over 100,000 devs, for free.
Your weekly dose of JavaScript news. Delivered every Monday to over 100,000 devs, for free.
