2021-08-20 03:38:16 -07:00
|
|
|
// FirefoxのプライベートモードなどではindexedDBが使用不可能なので、
|
|
|
|
// indexedDBが使えない環境ではlocalStorageを使う
|
|
|
|
import {
|
|
|
|
get as iget,
|
|
|
|
set as iset,
|
|
|
|
del as idel,
|
2021-10-06 22:28:22 -07:00
|
|
|
createStore,
|
2021-08-20 03:38:16 -07:00
|
|
|
} from 'idb-keyval';
|
|
|
|
|
|
|
|
const fallbackName = (key: string) => `idbfallback::${key}`;
|
|
|
|
|
|
|
|
let idbAvailable = typeof window !== 'undefined' ? !!window.indexedDB : true;
|
|
|
|
|
|
|
|
if (idbAvailable) {
|
|
|
|
try {
|
2021-10-06 22:28:22 -07:00
|
|
|
await createStore('keyval-store', 'keyval');
|
2021-08-20 03:38:16 -07:00
|
|
|
} catch (e) {
|
2021-10-06 22:28:22 -07:00
|
|
|
console.error('idb open error', e);
|
2021-08-20 03:38:16 -07:00
|
|
|
idbAvailable = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!idbAvailable) console.error('indexedDB is unavailable. It will use localStorage.');
|
|
|
|
|
|
|
|
export async function get(key: string) {
|
|
|
|
if (idbAvailable) return iget(key);
|
|
|
|
return JSON.parse(localStorage.getItem(fallbackName(key)));
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function set(key: string, val: any) {
|
|
|
|
if (idbAvailable) return iset(key, val);
|
|
|
|
return localStorage.setItem(fallbackName(key), JSON.stringify(val));
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function del(key: string) {
|
|
|
|
if (idbAvailable) return idel(key);
|
|
|
|
return localStorage.removeItem(fallbackName(key));
|
|
|
|
}
|