| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 | import { UnidentifiedQueueStoreEntry, QueueStoreEntry } from './QueueDb.js';import '../_version.js';/** * A class to manage storing requests from a Queue in IndexedDB, * indexed by their queue name for easier access. * * Most developers will not need to access this class directly; * it is exposed for advanced use cases. */export declare class QueueStore {    private readonly _queueName;    private readonly _queueDb;    /**     * Associates this instance with a Queue instance, so entries added can be     * identified by their queue name.     *     * @param {string} queueName     */    constructor(queueName: string);    /**     * Append an entry last in the queue.     *     * @param {Object} entry     * @param {Object} entry.requestData     * @param {number} [entry.timestamp]     * @param {Object} [entry.metadata]     */    pushEntry(entry: UnidentifiedQueueStoreEntry): Promise<void>;    /**     * Prepend an entry first in the queue.     *     * @param {Object} entry     * @param {Object} entry.requestData     * @param {number} [entry.timestamp]     * @param {Object} [entry.metadata]     */    unshiftEntry(entry: UnidentifiedQueueStoreEntry): Promise<void>;    /**     * Removes and returns the last entry in the queue matching the `queueName`.     *     * @return {Promise<QueueStoreEntry|undefined>}     */    popEntry(): Promise<QueueStoreEntry | undefined>;    /**     * Removes and returns the first entry in the queue matching the `queueName`.     *     * @return {Promise<QueueStoreEntry|undefined>}     */    shiftEntry(): Promise<QueueStoreEntry | undefined>;    /**     * Returns all entries in the store matching the `queueName`.     *     * @param {Object} options See {@link workbox-background-sync.Queue~getAll}     * @return {Promise<Array<Object>>}     */    getAll(): Promise<QueueStoreEntry[]>;    /**     * Returns the number of entries in the store matching the `queueName`.     *     * @param {Object} options See {@link workbox-background-sync.Queue~size}     * @return {Promise<number>}     */    size(): Promise<number>;    /**     * Deletes the entry for the given ID.     *     * WARNING: this method does not ensure the deleted entry belongs to this     * queue (i.e. matches the `queueName`). But this limitation is acceptable     * as this class is not publicly exposed. An additional check would make     * this method slower than it needs to be.     *     * @param {number} id     */    deleteEntry(id: number): Promise<void>;    /**     * Removes and returns the first or last entry in the queue (based on the     * `direction` argument) matching the `queueName`.     *     * @return {Promise<QueueStoreEntry|undefined>}     * @private     */    _removeEntry(entry?: QueueStoreEntry): Promise<QueueStoreEntry | undefined>;}
 |