npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@retorquere/indexeddb-promise

v1.0.11

Published

Use IndexedDB with promises + typescript typings

Downloads

38

Readme

IndexedDB Promise

Important: This is an ESM only package. It uses the browser’s IndexedDB API.

You can find tests and example code on the GitHub repository that will help you understand how to use this package. github.com/StephenHassall/indexeddb-promise

Important: Most of the functions return a Promise object and need to be used with the await keyword. Not doing this will create errors. If you do have problems using the package then the first thing you need to do is double check any missing await statements.

Installation

npm install @retorquere/indexeddb-promise

Contents

Introduction

The IndexedDB API is a database in the browser, however it is not the same as a large SQL like database, but more like a simple object store with indexes. It is different compared to other databases you may have used before, but once you understand how to use it, you will find it very useful for storing data on the client end.

All the API tasks are performed on a different thread and any request to do something is performed on that thread. Once the task is performed it sends an event to signal that it has finished (or failed). When doing a number of tasks together, adding and removing records, dealing with the events can become a pain. This package was created to add promises to the tasks, allowing you to use async/await to perform the steps one after the other.

// Create instance of my database
const myDatabase = new MyDatabase();

// Open the database
await myDatabase.open();

// Create transaction
const transaction = myDatabase.transaction('my-object-store', 'readwrite');

// Open my object store (table)
const myObjectStore = transaction.objectStore('my-object-store');

// Add record (object/document)
await myObjectStore.add({ id: 1, text: 'hello' });
await myObjectStore.add({ id: 2, text: 'world' });

// Commit changes
await transaction.commit();

// Close my database
myDatabase.close();

All the classes are wrappers to the IDB interfaces but with promises and one or two extra helpful functions. The goal of this package is to make using the IndexedDB API easier, more understandable, but without replacing the core functions with something totally new.

You will find information on how most of the functions work by looking at the related interface functions associated with them. Their functions and parameters are basically the same.

Database

This class is a wrapper to the IDBDatabase interface, but you cannot use it directly, it needs to be derived from. You create your own class that extends from the Database class and then override the _upgrade function. This is used to create the internal object stores and indexes.

class MyDatabase extends Database {
  constructor() {
    // Call base constructor to set database name and version
    super('my-database', 1);
  }

  _upgrade(transaction, oldVersion, newVersion) {
    // New version (or first time)
    this.createObjectStore('objectStore1');
    this.createObjectStore('objectStore2');
  }
}

|Name|Information| |---|---| |constructor(name, version)|When you have derived your own class from Database, make sure you call the super function with the name of the database and its current version.| |iDbDatabase|Get the IDBDatabase interface object associated with the database.| |version|Get the version of the database.| |name|Get the name of the database.| |objectStoreNames|Get a list of object store names contained within the database.| |openasync/await|Opens the database and calls the _upgrade override function if required.| |close|Closes the database.| |createObjectStore(name, [options])|While upgrading you can create new object stores.| |deleteObjectStore(name)|While upgrading you can delete existing object stores.| |transaction(storeNames, [mode], [options])|When the database is open you can create a transaction.| |_upgrade(transaction, oldVersion, newVersion)|When the open function is called, if there is a different version number, then the _upgrade function will be called. You need to override this function within your own class and perform any upgrading steps required. You can use async with this function if required.| |_close|Override this function to handle when the database is closed unexpectedly. This is not called when the close function is used. | |_versionChange|Override this function to handle when the database has changed from elsewhere, in another tab for example.|

Transaction

This class is a wrapper to the IDBTransaction interface.

|Name|Information| |---|---| |iDbTransaction|Get the IDBTransaction interface object associated with the transaction.| |db|Get the IDBDatabase interface object that created the transaction object.| |durability|Get the durability setting used when the transaction was created.| |mode|Get the mode setting used when the transaction was created.| |objectStoreNames|Get the list of object store names used when the transaction was created.| |error|Get the error why the transaction failed.| |commitasync/await|Commits any changes made with the transaction to the database.| |abortasync/await|Aborts all the changes made with the transaction.| |objectStore(name)|Get the object store object. It can only return an object store that was selected when the transaction was created.|

ObjectStore

This class is a wrapper to the IDBObjectStore interface.

|Name|Information| |---|---| |iDbObjectStore|Get the IDBObjectStore interface object associated with the object store.| |transaction|Get the IDBTransaction interface object that created the object store object.| |autoIncrement|Get the autoIncrement setting used when the objectStore was created (in the _upgrade override function).| |keyPath|Get the keyPath setting used when the objectStore was created (in the _upgrade override function).| |name|Get the name of the object store.| |indexNames|Get a list of all the index names within the object store.| |clear()async/await|Deletes all the objects (records) within the object store.| |count([query])async/await|Counts the number of objects (records) that match the query.| |add(value, [key])async/await|Insert a new object (record) into the object store.| |put(value, [key])async/await|Updates an existing object (record) within the object store.| |delete(key)async/await|Delete one or more objects (records) from the object store.| |get(key)async/await|Get the first found object (record) using the key or key range.| |getAll([query], [count])async/await|Get all the found objects (records) using the key or key range. It will only return up to the given count.| |getKey([key])async/await|Get the first found key using the key or key range.| |getAllKeys([query], [count])async/await|Get all the found keys using the query. It will only return up to the given count.| |createIndex(indexName, keyPath, [options])|Create a new index for the object store to use (in the _upgrade override function).| |deleteIndex(indexName)|Delete an existing index from the object store (in the _upgrade override function).| |index(name)|Get the index object used by the object store.| |openCursor([query], [direction])async/await|Opens a cursor that is used to move through the matching objects (records).| |openKeyCursor([query], [direction])async/await|Opens a cursor that is used to move through the matching objects (records) and return only the key parts (not the whole object).|

Index

This class is a wrapper to the IDBIndex interface.

|Name|Information| |---|---| |iDbIndex|Get the IDBIndex interface object associated with the index.| |objectStore|Get the IDBObjectStore interface object that created the index object.| |keyPath|Get the keyPath setting used when the index was created (in the _upgrade override function).| |multiEntry|Get the multiEntry setting used when the index was created (in the _upgrade override function).| |unique|Get the unique setting used when the index was created (in the _upgrade override function).| |name|Get the name of the index.| |count([key])async/await|Counts the number of objects (records) that match the query.| |get(key)async/await|Get the first found object (record) using the key or key range.| |getAll([query], [count])async/await|Get all the found objects (records) using the key or key range. It will only return up to the given count.| |getKey([key])async/await|Get the first found key using the key or key range.| |getAllKeys([query], [count])async/await|Get all the found keys using the query. It will only return up to the given count.| |openCursor([range], [direction])async/await|Opens a cursor that is used to move through the matching objects (records).| |openKeyCursor([range], [direction])async/await|Opens a cursor that is used to move through the matching objects (records) and return only the key parts (not the whole object).|

Cursor

This class is a wrapper to the IDBCursor interface.

|Name|Information| |---|---| |iDbCursor|Get the IDBCursor interface object associated with the cursor.| |source|Get either the IDBObjectStore or IDBIndex interface object that created the cursor object.| |request|Get the IDBRequest interface object linked to the cursor.| |direction|Get the direction setting used when creating the cursor object.| |key|Get the current key value of the object the cursor is looking at.| |primaryKey|Get the current primary key value for the object the cursor is looking at.| |advance(count)async/await|Make the cursor jump forward by the given number of steps. The promise resolves with true, record found, or false (passed end of list).| |continue([key])async/await|More on to the next object (record). The promise resolves with true, record found, or false (passed end of list).| |continuePrimaryKey(key, primaryKey)async/await|More on to the next object (record). The promise resolves with true, record found, or false (passed end of list).|

CursorWithValue

This class is a wrapper to the IDBCursorWithValue interface. This is derived from the Cursor class therefore it also contains all the properties and functions from that class.

|Name|Information| |---|---| |iDbCursorWithValue|Get the IDBCursorWithValue interface object associated with the cursor.| |value|Get the current value, the object (record) itself, where the cursor is positioned at.| |delete()async/await|Deletes the object (record) the cursor is currently positioned at.| |update(value)async/await|Updates the object (record) the cursor is currently positioned at. This replaces the whole object with the existing one. Any indexes will automatically be updated.|

Factory

This is not a wrapper like the other classes. It is used to add promises to one of the IDBFactor functions.

|Name|Information| |---|---| |databases|Get a list of all the databases. This information includes the name and version.| |deleteDatabase(name, [options])async/await|Deletes a database.|