Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pmndrs/jotai
π» Primitive and flexible state management for React
https://github.com/pmndrs/jotai
atomic hacktoberfest management react state
Last synced: 6 days ago
JSON representation
π» Primitive and flexible state management for React
- Host: GitHub
- URL: https://github.com/pmndrs/jotai
- Owner: pmndrs
- License: mit
- Created: 2020-08-11T23:15:36.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-04-14T22:23:33.000Z (7 months ago)
- Last Synced: 2024-04-15T11:06:46.519Z (7 months ago)
- Topics: atomic, hacktoberfest, management, react, state
- Language: TypeScript
- Homepage: https://jotai.org
- Size: 11.9 MB
- Stars: 17,150
- Watchers: 65
- Forks: 544
- Open Issues: 11
-
Metadata Files:
- Readme: readme.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesomeLibrary - jotai - π» Primitive and flexible state management for React (θ―θ¨θ΅ζΊεΊ / typescript)
- awesome-react - jotai - Primitive and flexible state management for React. ![](https://img.shields.io/github/stars/pmndrs/jotai.svg?style=social&label=Star) (Utilities / State Management)
- awesome-learning-resources - jotai - Bottom-up approach to React state management with an atomic model (Uncategorized / Uncategorized)
- awesome-whatthefar - Jotai
- awesome-github-star - jotai
- awesome-list - jotai
- awesome-react-three-fiber - jotai
- awesome-webxr-development - Jotai - badge] - Primitive and flexible state management for React. Scales from a simple useState replacement to an enterprise TypeScript application (State Management / Visual Editor)
- awesome-resources - Jotai
- awesome-react-state-management - jotai - Primitive, flexible state management for React (Recoil-like) (List)
- awesome-f2e-libs - **jotai**
- awesome-react - jotai - Primitive and flexible state management for React (**Awesome React** [![Awesome](https://cdn.rawgit.com/sindresorhus/awesome/d7305f38d29fed78fa85652e3a63e154dd8e8829/media/badge.svg)](https://github.com/sindresorhus/awesome) / React)
- awesome-fe-resources - jotai
- awesome - pmndrs/jotai - π» Primitive and flexible state management for React (TypeScript)
- StarryDivineSky - pmndrs/jotai
- awesome - pmndrs/jotai - π» Primitive and flexible state management for React (TypeScript)
README
![Jotai (light mode)](./img/jotai-header-light.png#gh-light-mode-only)
![Jotai (dark mode)](./img/jotai-header-dark.png#gh-dark-mode-only)
visit [jotai.org](https://jotai.org) or `npm i jotai`
[![Build Status](https://img.shields.io/github/actions/workflow/status/pmndrs/jotai/lint-and-type.yml?branch=main&style=flat&colorA=000000&colorB=000000)](https://github.com/pmndrs/jotai/actions?query=workflow%3ALint)
[![Build Size](https://img.shields.io/bundlephobia/minzip/jotai?label=bundle%20size&style=flat&colorA=000000&colorB=000000)](https://bundlephobia.com/result?p=jotai)
[![Version](https://img.shields.io/npm/v/jotai?style=flat&colorA=000000&colorB=000000)](https://www.npmjs.com/package/jotai)
[![Downloads](https://img.shields.io/npm/dt/jotai.svg?style=flat&colorA=000000&colorB=000000)](https://www.npmjs.com/package/jotai)
[![Discord Shield](https://img.shields.io/discord/740090768164651008?style=flat&colorA=000000&colorB=000000&label=discord&logo=discord&logoColor=ffffff)](https://discord.gg/poimandres)
[![Open Collective](https://img.shields.io/opencollective/all/jotai?style=flat&colorA=000000&colorB=000000)](https://opencollective.com/jotai)Jotai scales from a simple useState replacement to an enterprise TypeScript application.
- Minimal core API (2kb)
- Many utilities and extensions
- No string keys (compared to Recoil)Examples: [Demo 1](https://codesandbox.io/s/jotai-demo-47wvh) |
[Demo 2](https://codesandbox.io/s/jotai-demo-forked-x2g5d)### First, create a primitive atom
An atom represents a piece of state. All you need is to specify an initial
value, which can be primitive values like strings and numbers, objects, and
arrays. You can create as many primitive atoms as you want.```jsx
import { atom } from 'jotai'const countAtom = atom(0)
const countryAtom = atom('Japan')
const citiesAtom = atom(['Tokyo', 'Kyoto', 'Osaka'])
const mangaAtom = atom({ 'Dragon Ball': 1984, 'One Piece': 1997, Naruto: 1999 })
```### Use the atom in your components
It can be used like `React.useState`:
```jsx
import { useAtom } from 'jotai'function Counter() {
const [count, setCount] = useAtom(countAtom)
return (
{count}
setCount((c) => c + 1)}>one up
...
```### Create derived atoms with computed values
A new read-only atom can be created from existing atoms by passing a read
function as the first argument. `get` allows you to fetch the contextual value
of any atom.```jsx
const doubledCountAtom = atom((get) => get(countAtom) * 2)function DoubleCounter() {
const [doubledCount] = useAtom(doubledCountAtom)
return{doubledCount}
}
```### Creating an atom from multiple atoms
You can combine multiple atoms to create a derived atom.
```jsx
const count1 = atom(1)
const count2 = atom(2)
const count3 = atom(3)const sum = atom((get) => get(count1) + get(count2) + get(count3))
```Or if you like fp patterns ...
```jsx
const atoms = [count1, count2, count3, ...otherAtoms]
const sum = atom((get) => atoms.map(get).reduce((acc, count) => acc + count))
```### Derived async atoms [](https://react.dev/reference/react/Suspense)
You can make the read function an async function too.
```jsx
const urlAtom = atom('https://json.host.com')
const fetchUrlAtom = atom(async (get) => {
const response = await fetch(get(urlAtom))
return await response.json()
})function Status() {
// Re-renders the component after urlAtom is changed and the async function above concludes
const [json] = useAtom(fetchUrlAtom)
...
```### You can create a writable derived atom
Specify a write function at the second argument. `get` will return the current
value of an atom. `set` will update the value of an atom.```jsx
const decrementCountAtom = atom(
(get) => get(countAtom),
(get, set, _arg) => set(countAtom, get(countAtom) - 1)
)function Counter() {
const [count, decrement] = useAtom(decrementCountAtom)
return (
{count}
Decrease
...
```### Write only derived atoms
Just do not define a read function.
```jsx
const multiplyCountAtom = atom(null, (get, set, by) =>
set(countAtom, get(countAtom) * by),
)function Controls() {
const [, multiply] = useAtom(multiplyCountAtom)
return multiply(3)}>triple
}
```### Async actions
Just make the write function an async function and call `set` when you're ready.
```jsx
const fetchCountAtom = atom(
(get) => get(countAtom),
async (_get, set, url) => {
const response = await fetch(url)
set(countAtom, (await response.json()).count)
}
)function Controls() {
const [count, compute] = useAtom(fetchCountAtom)
return (
compute('http://count.host.com')}>compute
...
```### Note about functional programming
Jotai's fluid interface is no accident β atoms are monads, just like promises!
Monads are an [established]()
pattern for modular, pure, robust and understandable code which is [optimized for change](https://overreacted.io/optimized-for-change/).
Read more about [Jotai and monads.](https://jotai.org/docs/basics/functional-programming-and-jotai)## Links
- [website](https://jotai.org)
- [documentation](https://jotai.org/docs)
- [course](https://egghead.io/courses/manage-application-state-with-jotai-atoms-2c3a29f0)