dioxus/packages/fermi/README.md

113 lines
2.6 KiB
Markdown
Raw Normal View History

2022-02-17 15:38:51 +00:00
<div align="center">
<h1>Fermi ⚛</h1>
<p>
<strong>Atom-based global state management solution for Dioxus</strong>
</p>
</div>
<div align="center">
<!-- Crates version -->
2023-06-27 00:29:49 +00:00
<a href="https://crates.io/crates/fermi">
<img src="https://img.shields.io/crates/v/fermi.svg?style=flat-square"
2022-02-17 15:38:51 +00:00
alt="Crates.io version" />
</a>
<!-- Downloads -->
2023-06-27 00:29:49 +00:00
<a href="https://crates.io/crates/fermi">
<img src="https://img.shields.io/crates/d/fermi.svg?style=flat-square"
2022-02-17 15:38:51 +00:00
alt="Download" />
</a>
<!-- docs -->
2023-06-27 00:29:49 +00:00
<a href="https://docs.rs/fermi">
2022-02-17 15:38:51 +00:00
<img src="https://img.shields.io/badge/docs-latest-blue.svg?style=flat-square"
alt="docs.rs docs" />
</a>
<!-- CI -->
2023-06-27 00:29:49 +00:00
<a href="https://github.com/DioxusLabs/dioxus/actions">
2022-02-17 15:38:51 +00:00
<img src="https://github.com/dioxuslabs/dioxus/actions/workflows/main.yml/badge.svg"
alt="CI status" />
</a>
</div>
-----
Fermi is a global state management solution for Dioxus that's as easy as `use_state`.
Inspired by atom-based state management solutions, all state in Fermi starts as an `atom`:
```rust, ignore
2022-02-17 15:38:51 +00:00
static NAME: Atom<&str> = |_| "Dioxus";
```
From anywhere in our app, we can read the value of our atom:
2022-02-17 15:38:51 +00:00
```rust, ignores
fn NameCard(cx: Scope) -> Element {
let name = use_read(cx, NAME);
2022-02-17 15:38:51 +00:00
cx.render(rsx!{ h1 { "Hello, {name}"} })
}
```
We can also set the value of our atom, also from anywhere in our app:
```rust, ignore
fn NameCard(cx: Scope) -> Element {
let set_name = use_set(cx, NAME);
2022-02-17 15:38:51 +00:00
cx.render(rsx!{
button {
onclick: move |_| set_name("Fermi"),
"Set name to fermi"
}
})
}
```
If needed, we can update the atom's value, based on itself:
```rust, ignore
static COUNT: Atom<i32> = |_| 0;
fn Counter(cx: Scope) -> Element {
let mut count = use_atom_state(cx, COUNT);
cx.render(rsx!{
p {
"{count}"
}
button {
onclick: move |_| count += 1,
"Increment counter"
}
})
}
```
2022-02-17 15:38:51 +00:00
It's that simple!
## Installation
Fermi is currently under construction, so you have to use the `master` branch to get started.
```toml
2022-06-28 02:58:27 +00:00
[dependencies]
2022-09-06 18:42:45 +00:00
fermi = { git = "https://github.com/dioxuslabs/dioxus" }
2022-02-17 15:38:51 +00:00
```
## Running examples
The examples here use Dioxus Desktop to showcase their functionality. To run an example, use
```sh
2022-09-06 18:42:45 +00:00
$ cargo run --example fermi
2022-02-17 15:38:51 +00:00
```
## Features
Broadly our feature set required to be released includes:
2022-02-17 15:38:51 +00:00
- [x] Support for Atoms
- [x] Support for AtomRef (for values that aren't `Clone`)
2022-02-17 15:38:51 +00:00
- [ ] Support for Atom Families
- [ ] Support for memoized Selectors
- [ ] Support for memoized SelectorFamilies
- [ ] Support for UseFermiCallback for access to fermi from async