Home / LocalStorageProvider
The LocalStorageProvider
is a reactive wrapper for the local storage API. It syncs changes to its state with the browser's local storage. You can use this to save simple strings across different parts of your application.
DO NOT store sensitive data in the local storage as this has absolutely no layer of security
The following guide demonstrates how to use the LocalStorageProvider
The first step to using the LocalStorageProvider
widget is to make it an ancestor of your app export.
import ReactDOM from "react-dom";
import { LocalStorageProvider } from "react-simple-widgets/dist/local-storage-provider";
import { App } from "./app.tsx";
ReactDOM.createRoot(
<LocalStorageProvider>
<App />
</LocalStorageProvider>,
document.getElementById("root")
);
This makes the LocalStorageProvider
context available to the rest of the application.
The code example below illustrates how to utilize each function in the provider
app.tsx
import { useContext } from "react";
import { LocalStorageProviderContext } from "react-simple-widgets/dist/local-storage-provider";
export function App() {
const {
getItem /* Retrieve an item from the local storage */,
setItem /* Store an item in the cache and local storage and rerender */,
removeItem /* Remove one or more items from the cache and local storage and rerender */,
clear /* Clear all items stored with this provider from the cache and local storage rerender */
} = useContext(LocalStorageProviderContext);
// Save a value to the provider store
function saveValueInStore(key: string, value: any): void {
setItem(key, value);
}
// Delete one or more values from the provider store
function deleteValueInStore(...keys: Array<string>): void {
removeItem(...keys);
}
// Delete all values from the provider store
function clearValuesInStore(): void {
clear();
}
return (
<div id="app">
<label htmlFor="input-1">Value 1 (Saved in local storage)</label>
<input
id="input-1"
value={getItem("value-1")}
onChange={e => saveValueInStore("value-1", e.target.value, true)}
/>
<button onClick={() => deleteValueInStore("value-1")}>
Clear Value 1
</button>
<label htmlFor="input-2">Value 2 (Saved in local storage)</label>
<input
id="input-2"
value={getItem("value-2")}
onChange={e => saveValueInStore("value-2", e.target.value, true)}
/>
<button onClick={() => deleteValueInStore("value-2")}>
Clear Value 2
</button>
<label htmlFor="input-3">Value 3</label>
<input
id="input-3"
value={getItem("value-3")}
onChange={e => saveValueInStore("value-3", e.target.value)}
/>
<button onClick={() => deleteValueInStore("value-3")}>
Clear Value 3
</button>
<button onClick={clearValuesInStore}>Clear all values in store</button>
</div>
);
}