Last active
November 28, 2024 03:57
-
-
Save EvanBacon/4a1fd9515a25ff5b718746323236d81d to your computer and use it in GitHub Desktop.
Polyfill localStorage in Expo SDK 52
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import { Storage } from "expo-sqlite/kv-store"; | |
// localStorage polyfill. Life's too short to not have some storage API. | |
if (typeof localStorage === "undefined") { | |
class StoragePolyfill { | |
/** | |
* Returns the number of key/value pairs. | |
* | |
* [MDN Reference](https://developer.mozilla.org/docs/Web/API/Storage/length) | |
*/ | |
get length(): number { | |
return Storage.getAllKeysSync().length; | |
} | |
/** | |
* Removes all key/value pairs, if there are any. | |
* | |
* Dispatches a storage event on Window objects holding an equivalent Storage object. | |
* | |
* [MDN Reference](https://developer.mozilla.org/docs/Web/API/Storage/clear) | |
*/ | |
clear(): void { | |
Storage.clearSync(); | |
} | |
/** | |
* Returns the current value associated with the given key, or null if the given key does not exist. | |
* | |
* [MDN Reference](https://developer.mozilla.org/docs/Web/API/Storage/getItem) | |
*/ | |
getItem(key: string): string | null { | |
return Storage.getItemSync(key) ?? null; | |
} | |
/** | |
* Returns the name of the nth key, or null if n is greater than or equal to the number of key/value pairs. | |
* | |
* [MDN Reference](https://developer.mozilla.org/docs/Web/API/Storage/key) | |
*/ | |
key(index: number): string | null { | |
return Storage.getAllKeysSync()[index] ?? null; | |
} | |
/** | |
* Removes the key/value pair with the given key, if a key/value pair with the given key exists. | |
* | |
* Dispatches a storage event on Window objects holding an equivalent Storage object. | |
* | |
* [MDN Reference](https://developer.mozilla.org/docs/Web/API/Storage/removeItem) | |
*/ | |
removeItem(key: string): void { | |
Storage.removeItemSync(key); | |
} | |
/** | |
* Sets the value of the pair identified by key to value, creating a new key/value pair if none existed for key previously. | |
* | |
* Throws a "QuotaExceededError" DOMException exception if the new value couldn't be set. (Setting could fail if, e.g., the user has disabled storage for the site, or if the quota has been exceeded.) | |
* | |
* Dispatches a storage event on Window objects holding an equivalent Storage object. | |
* | |
* [MDN Reference](https://developer.mozilla.org/docs/Web/API/Storage/setItem) | |
*/ | |
setItem(key: string, value: string): void { | |
Storage.setItemSync(key, value); | |
} | |
// [name: string]: any; | |
} | |
const localStoragePolyfill = new StoragePolyfill(); | |
Object.defineProperty(global, "localStorage", { | |
value: localStoragePolyfill, | |
}); | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment