title | description | nav |
---|---|---|
Babel |
This doc describes the `jotai/babel` bundle. |
2.04 |
Jotai is based on object references and not keys (like Recoil). This means there's no identifier for atoms. To identify atoms, it's possible to add a debugLabel
to an atom, which can be found in React devtools.
However, this can quickly become cumbersome to add a debugLabel
to every atom.
This babel
plugin adds a debugLabel
to every atom, based on its identifier.
The plugin transforms this code:
export const countAtom = atom(0)
Into:
export const countAtom = atom(0)
countAtom.debugLabel = 'countAtom'
Default exports are also handled, based on the file naming:
// countAtom.ts
export default atom(0)
Which transform into:
// countAtom.ts
const countAtom = atom(0)
countAtom.debugLabel = 'countAtom'
export default countAtom
With a babel
configuration file:
{
"plugins": ["jotai/babel/plugin-debug-label"]
}
You can also supply your atom names to the plugin:
{
"plugins": [
["jotai/babel/plugin-debug-label", { "customAtomNames": ["customAtom"] }]
]
}
Examples can be found below.
This plugin adds support for React Refresh for Jotai atoms. This makes sure that state isn't reset, when developing using React Refresh.
With a babel
configuration file:
{
"plugins": ["jotai/babel/plugin-react-refresh"]
}
You can also supply your atom names to the plugin:
{
"plugins": [
["jotai/babel/plugin-react-refresh", { "customAtomNames": ["customAtom"] }]
]
}
Examples can be found below.
Jotai ships with a babel
containing the plugins created for Jotai.
With a babel
configuration file:
{
"presets": ["jotai/babel/preset"]
}
You can also supply your atom names to the preset:
{
"presets": [["jotai/babel/preset", { "customAtomNames": ["customAtom"] }]]
}