Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/prncss-xyz/zustand-optics
https://github.com/prncss-xyz/zustand-optics
Last synced: about 1 month ago
JSON representation
- Host: GitHub
- URL: https://github.com/prncss-xyz/zustand-optics
- Owner: prncss-xyz
- License: mit
- Created: 2024-05-10T21:23:44.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-05-20T18:08:31.000Z (6 months ago)
- Last Synced: 2024-09-30T07:21:58.825Z (about 2 months ago)
- Language: TypeScript
- Size: 124 KB
- Stars: 2
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Zustand Optics
[![Codecov](https://img.shields.io/codecov/c/github/prncss-xyz/zustand-optics)](https://codecov.io/github/prncss-xyz/zustand-optics)
[![Version](https://img.shields.io/npm/v/@prncss-xyz/zustand-optics)](https://www.npmjs.com/package/@prncss-xyz/zustand-optics)[Zustand](https://docs.pmnd.rs/zustand) integration for [optics-ts](https://akheron.github.io/optics-ts/). Based on [jotai-optics](https://github.com/jotaijs/jotai-optics).
## Install
`npm i optics-ts @prncss-xyz/zustand-optics`
## Usage
### First create a store
```typescript
import { create } from "zustand";
import { withOptics } from "@prncss-xyz/zustand-optics";
import { optic } from "optics-ts";const init = { bears: { grizzly: 0 } };
const useBearStore = withOptics(create(() => init));
const bearStoreO = optic();
```### Then
```javascript
import { useCallback } from "react";function GrizzlyCounter({ grizzly }: { grizzly: number }) {
return{grizzly} around here...
;
}
const grizzlyO = bearStoreO.prop("bears").prop("grizzly");function App() {
const [grizzly, setGrizzly] = useBearStore.rw(grizzlyO);
const increasePopulation = useCallback(() => setGrizzly((x) => x + 1), [setGrizzly]);
return (
<>
one up
>
);
}```
## API
### withOptics
`const useStore = withOptics(useBoundStore: UseBoundStore>, defaultIsEqual = Object.is)`
Create a hook with methods as described below. For the meaning of `defaultIsEqual`, see `activate`.
### Basic hooks
#### get
```javascript
const value = useStore.get(focus);
```Returns the value of the focus. (Will return an array if focus is a traversable).
#### set
```javascript
const setValue = useStore.set(focus);
setValue(value);
```Returns a callback which accepts a value and sets the focus to it. If `value` is a value (!), sets the focus to that value. If `value` is a callback, applies the callback to focus. If `value` is `undefined`, removes the focus for a removable optics (prism and traversable) and do nothing otherwise.
The callback is stable.
### Utility hooks
These are wrappers around the basic hooks which can help with code readability.
### rw
Returns a pair made of the focus value and a `set` callback.
```javascript
const [value, setValue] = useStore.rw(focus);
```### activate
```javascript
const [active, activate] = useStore.activate(focus, target, isEqual?);
activate()
```Returns a pair. The first value is a boolean representing whether the focus is equal to target. The second value is a callback setting focus to target value.
```typescript
isEqual(a: A, b: A): boolean
```The second argument is an optional equality function. If not provided, it defaults to the second argument of `createStoreWithOptics`. If neither is provided, defaults to `Object.is`.
### setWith
```javascript
const setter = useStore.setWith([focus1, value1], [focus2, value2] /*, ...*/);
setter();
```Creates a callback which calls multiple `set` operations from left to right.
Note on typing: if you have more than 7 arguments (please don't), TypeScript will assume they all have the same type.