Skip to content

Commit

Permalink
docs: create-storage-state
Browse files Browse the repository at this point in the history
  • Loading branch information
SukkaW committed Oct 26, 2024
1 parent a879645 commit d249786
Show file tree
Hide file tree
Showing 3 changed files with 137 additions and 0 deletions.
2 changes: 2 additions & 0 deletions docs/src/pages/_meta.json
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,8 @@
"title": "Utilities"
},
"context-state": {},
"context-local-storage-state": {},
"context-session-storage-state": {},
"create-fixed-array": {},
"invariant-nullthrow": {},
"noop": {},
Expand Down
69 changes: 69 additions & 0 deletions docs/src/pages/create-local-storage-state.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
---
title: Create localStorage State
---

# Create localStorage State

import ExportMetaInfo from '../components/export-meta-info';

<ExportMetaInfo />

Store your shared state that lives in localStorage and synchronize the state of a component with the data stored in the `localStorage`. Lift your state up and passing them deeply into your React app without worrying about performance.

## Usage

First, create a shared hooks with `createLocalStorageState`. It is recommended to place them in a separate file:

```tsx filename="src/context/sidebar-active.tsx" copy
import { createLocalStorageState } from 'foxact/create-local-storage-state';

const [useSidebarActive, useSidebarActiveValue] = createLocalStorageState(
'sidebar-active', // The localStorage key
/**
* The initial value to use if there is no item in the local storage with the provided key,
* the undefined value will be used if no initial value is provided.
*
* Also, the initial value will also be used during the server-side rendering, see below.
*/
false,
/**
* Optional configuration object enables the customization of value serialization before it's stored in local storage.
*/
{
// Optional, default to false. When set to "true", the value will be passed to the localStorage API as is.
raw: false,
// Optional, default to "JSON.stringify". Can only be specified when the "raw" is set to false (which is the default).
serializer: JSON.stringify,
// Optional, default to "JSON.parse". Can only be specified when the "raw" is set to false (which is the default).
deserializer: JSON.parse,
}
);

export { useSidebarActive, useSidebarActiveValue };
```

And now you can use the getter and setter hooks anywhere in your app:

```tsx filename="src/components/sidebar.tsx" copy
import { memo } from 'react';
import { useSidebarActive, useSidebarActiveValue } from '../context/sidebar-active';

function Sidebar() {
const [sidebarActive, setSidebarActive] = useSidebarActive();
// If you only need the value, you can use `useSidebarActiveValue` instead:
const sidebarActive = useSidebarActiveValue();

return (
<div className={`sidebar ${sidebarActive ? 'active' : ''}`}>
<button onClick={() => setSidebarActive(false)}>Close Sidebar</button>
</div>
);
}

export default memo(Sidebar);
```

## Sever-side Rendering

If the second argument (the initial value) is provided, React will use the initial value to render the UI and generate HTML on the server, otherwise React will find the closest `<Suspense>` boundary and render its `fallback` UI into the generated server HTML on the server. See
[`useLocalStorage`](/use-local-storage#sever-side-rendering) for more information.
66 changes: 66 additions & 0 deletions docs/src/pages/create-session-storage-state.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
---
title: Create sessionStorage State
---

# Create sessionStorage State

import ExportMetaInfo from '../components/export-meta-info';

<ExportMetaInfo />

Store your shared state that lives in sessionStorage and synchronize the state of a component with the data stored in the `localStorage`. Lift your state up and passing them deeply into your React app without worrying about performance.

## Usage

```tsx filename="src/context/sidebar-active.tsx" copy
import { createSessionStorageState } from 'foxact/create-session-storage-state';

const [useSidebarActive, useSidebarActiveValue] = createSessionStorageState(
'sidebar-active', // The localStorage key
/**
* The initial value to use if there is no item in the local storage with the provided key,
* the undefined value will be used if no initial value is provided.
*
* Also, the initial value will also be used during the server-side rendering, see below.
*/
false,
/**
* Optional configuration object enables the customization of value serialization before it's stored in local storage.
*/
{
// Optional, default to false. When set to "true", the value will be passed to the localStorage API as is.
raw: false,
// Optional, default to "JSON.stringify". Can only be specified when the "raw" is set to false (which is the default).
serializer: JSON.stringify,
// Optional, default to "JSON.parse". Can only be specified when the "raw" is set to false (which is the default).
deserializer: JSON.parse,
}
);

export { useSidebarActive, useSidebarActiveValue };
```

And now you can use the getter and setter hooks anywhere in your app:

```tsx filename="src/components/sidebar.tsx" copy
import { memo } from 'react';
import { useSidebarActive, useSidebarActiveValue } from '../context/sidebar-active';

function Sidebar() {
const [sidebarActive, setSidebarActive] = useSidebarActive();
// If you only need the value, you can use `useSidebarActiveValue` instead:
const sidebarActive = useSidebarActiveValue();

return (
<div className={`sidebar ${sidebarActive ? 'active' : ''}`}>
<button onClick={() => setSidebarActive(false)}>Close Sidebar</button>
</div>
);
}

export default memo(Sidebar);
```

## Sever-side Rendering

See [createLocalStorageState](/create-local-storage-state#sever-side-rendering) for more details.

0 comments on commit d249786

Please sign in to comment.