Skip to content

Instantly share code, notes, and snippets.

@EvanBacon
Last active November 28, 2024 03:57
Show Gist options
  • Save EvanBacon/4a1fd9515a25ff5b718746323236d81d to your computer and use it in GitHub Desktop.
Save EvanBacon/4a1fd9515a25ff5b718746323236d81d to your computer and use it in GitHub Desktop.
Polyfill localStorage in Expo SDK 52
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