Skip to content

Setup

Reatom is a framework-agnostic state manager, and you can use it with various adapters for different frameworks. This guide provides a common usage with React.js, as it is the most commonly used view library currently.

Create new project from template

#

The base template project includes Vite, TypeScript, React and Reatom ecosystem: https://github.com/artalar/reatom-react-ts

You could try it online: codesandbox, stackblitz, gitpod

To setup it in your machine you can use degit package.

Terminal window
npx degit github:artalar/reatom-react-ts PROJECT-NAME
cd PROJECT-NAME
npm install
npm run dev

Add to existing project

#
Terminal window
npm i @reatom/core

With React

#

Installation

#
Terminal window
npm i @reatom/npm-react

You need to set up the main context and put it into the provider at the top of your application.

import { createCtx } from '@reatom/core'
import { reatomContext } from '@reatom/npm-react'
import { Main } from './path/to/an/Main'
const ctx = createCtx()
export const App = () => (
<reatomContext.Provider value={ctx}>
<Main />
</reatomContext.Provider>
)

Usage

#

The useAtom function allows you to have an experience similar to useState, but with shared atom state.

const nameAtom = atom('Joe')
const greetingAtom = atom((ctx) => `Hello, ${ctx.spy(nameAtom)}!`)
const Greeting = () => {
const [name, setName] = useAtom(nameAtom)
const [greeting] = useAtom(greetingAtom)
return (
<>
<label>
What is your name?:
<input value={name} onChange={(e) => setName(e.currentTarget.value)} />
</label>
<h1>Hello {greeting}!</h1>
</>
)
}

Also, you can create computed atoms (kind of selectors) right inside useAtom.

const nameAtom = atom('Joe')
const Greeting = () => {
const t = useTranslation()
const [name, setName] = useAtom(nameAtom)
const [greeting] = useAtom(
(ctx) => `${t('common:GREETING')} ${ctx.spy(nameAtom)}!`,
[t],
)
return (
<>
<label>
What is your name?:
<input value={name} onChange={(e) => setName(e.currentTarget.value)} />
</label>
<h1>{greeting}!</h1>
</>
)
}

This is very basic functionality of reatom-react bindings, see more in @reatom/npm-react package documentation