mapcomplete/Logic/Web/LocalStorageSource.ts

44 lines
1.3 KiB
TypeScript
Raw Normal View History

2022-09-08 21:40:48 +02:00
import { UIEventSource } from "../UIEventSource"
2021-03-29 14:10:20 +02:00
/**
* UIEventsource-wrapper around localStorage
*/
export class LocalStorageSource {
static GetParsed<T>(key: string, defaultValue: T): UIEventSource<T> {
return LocalStorageSource.Get(key).sync(
2022-09-08 21:40:48 +02:00
(str) => {
if (str === undefined) {
return defaultValue
}
try {
return JSON.parse(str)
} catch {
return defaultValue
}
2022-09-08 21:40:48 +02:00
},
[],
(value) => JSON.stringify(value)
)
}
static Get(key: string, defaultValue: string = undefined): UIEventSource<string> {
2020-07-31 17:11:44 +02:00
try {
2022-09-08 21:40:48 +02:00
const saved = localStorage.getItem(key)
const source = new UIEventSource<string>(saved ?? defaultValue, "localstorage:" + key)
2020-07-31 17:11:44 +02:00
source.addCallback((data) => {
try {
2022-09-08 21:40:48 +02:00
localStorage.setItem(key, data)
} catch (e) {
2021-03-29 14:10:20 +02:00
// Probably exceeded the quota with this item!
// Lets nuke everything
localStorage.clear()
}
2022-09-08 21:40:48 +02:00
})
return source
2020-07-31 17:11:44 +02:00
} catch (e) {
2022-09-08 21:40:48 +02:00
return new UIEventSource<string>(defaultValue)
2020-07-31 17:11:44 +02:00
}
}
2020-07-31 17:11:44 +02:00
}