Skip to content

Instantly share code, notes, and snippets.

@enijar
Created October 31, 2018 08:46
Show Gist options
  • Star 5 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save enijar/c2ed734c4913de7a6eec54721b978d29 to your computer and use it in GitHub Desktop.
Save enijar/c2ed734c4913de7a6eec54721b978d29 to your computer and use it in GitHub Desktop.
IndexedDB Cache Images
class Cache {
constructor(props = {}) {
this.version = props.version || 1;
this.assets = {};
this.db = null;
}
init() {
return new Promise(resolve => {
const request = indexedDB.open('tactics.cache', this.version);
request.onupgradeneeded = event => {
event.target.result.createObjectStore('cache');
};
request.onsuccess = () => {
this.db = request.result;
this.db.onerror = () => {
console.error('Error creating/accessing db');
};
if (this.db.setVersion && this.db.version !== this.version) {
const version = this.db.setVersion(this.version);
version.onsuccess = () => {
this.db.createObjectStore('cache');
resolve();
};
} else {
resolve();
}
};
});
}
putImage(key, url) {
return new Promise((resolve, reject) => {
if (!this.db) {
return reject('DB not initialized. Call the init method');
}
const xhr = new XMLHttpRequest();
xhr.open('GET', url);
xhr.responseType = 'blob';
xhr.onload = response;
xhr.onerror = e => console.error(e);
xhr.send();
const db = this.db;
function response(event) {
const blob = this.response;
const transaction = db.transaction(['cache'], 'readwrite');
const put = transaction.objectStore('cache').put(blob, key);
resolve();
}
});
}
getImage(key) {
return new Promise(resolve => {
const transaction = this.db.transaction(['cache'], 'readwrite');
transaction.objectStore('cache').get(key).onsuccess = event => {
resolve(URL.createObjectURL(event.target.result));
};
});
}
}
(async () => {
try {
const cache = new Cache({version: 1});
await cache.init();
await cache.putImage('trophy', '');
const url = await cache.getImage('trophy');
console.log(`cached url -> ${url}`);
} catch (err) {
console.error(err);
}
})();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment