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