forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			48 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { UIEventSource } from "../UIEventSource"
 | |
| import * as idb from "idb-keyval"
 | |
| import { Utils } from "../../Utils"
 | |
| 
 | |
| /**
 | |
|  * UIEventsource-wrapper around indexedDB key-value
 | |
|  */
 | |
| export class IdbLocalStorage {
 | |
|     private static readonly _sourceCache: Record<string, UIEventSource<any>> = {}
 | |
| 
 | |
|     public static Get<T>(
 | |
|         key: string,
 | |
|         options?: { defaultValue?: T; whenLoaded?: (t: T | null) => void }
 | |
|     ): UIEventSource<T> {
 | |
|         if (IdbLocalStorage._sourceCache[key] !== undefined) {
 | |
|             return IdbLocalStorage._sourceCache[key]
 | |
|         }
 | |
|         const src = new UIEventSource<T>(options?.defaultValue, "idb-local-storage:" + key)
 | |
|         if (Utils.runningFromConsole) {
 | |
|             return src
 | |
|         }
 | |
|         src.addCallback((v) => idb.set(key, v))
 | |
| 
 | |
|         idb.get(key)
 | |
|             .then((v) => {
 | |
|                 src.setData(v ?? options?.defaultValue)
 | |
|                 if (options?.whenLoaded !== undefined) {
 | |
|                     options?.whenLoaded(v)
 | |
|                 }
 | |
|             })
 | |
|             .catch((err) => {
 | |
|                 console.warn("Loading from local storage failed due to", err)
 | |
|                 if (options?.whenLoaded !== undefined) {
 | |
|                     options?.whenLoaded(null)
 | |
|                 }
 | |
|             })
 | |
|         IdbLocalStorage._sourceCache[key] = src
 | |
|         return src
 | |
|     }
 | |
| 
 | |
|     public static SetDirectly(key: string, value) {
 | |
|         idb.set(key, value)
 | |
|     }
 | |
| 
 | |
|     static GetDirectly(key: string) {
 | |
|         return idb.get(key)
 | |
|     }
 | |
| }
 |