Freya 🦀


Website | Docs | Book | Discord
Freya is a native GUI library for Rust powered by 🧬 Dioxus and 🎨 Skia.
âš ï¸ It's currently work in progress and not usable for production, but you can already play with it! You can join the Discord server if you have any question or issue.
```rust, no_run
fn app(cx: Scope) -> Element {
let mut count = use_state(cx, || 0);
render!(
rect {
height: "20%",
width: "100%",
background: "rgb(233, 196, 106)",
padding: "12",
color: "rgb(20, 33, 61)",
label {
font_size: "20",
"Number is: {count}"
}
}
rect {
height: "80%",
width: "100%",
background: "rgb(168, 218, 220)",
color: "black",
padding: "12",
onclick: move |_| count += 1,
label { "Click to increase!" }
}
)
}
```
|

|
Want to try it? 🤔
âš ï¸ First, see Environment setup.
Clone this repo and run:
shell
cargo run --example counter
You can also try freya-template
Usage 📜
Add Freya and Dioxus as dependencies:
toml
freya = "0.1"
dioxus = { version = "0.4", features = ["macro", "hooks"] }
Features ✨
- â›ï¸ Built-in components (button, scroll views, switch and more)
- 🚇 Built-in hooks library (animations, text editing and more)
- 🔠Built-in devtools panel (experimental âš ï¸) (experimental âš ï¸)
- 🧰 Built-in headless testing runner for components
- 🎨 Theming support (not extensible yet âš ï¸)
- ðŸ›©ï¸ Cross-platform (Windows, Linux, MacOS)
- ðŸ–¼ï¸ SKSL Shaders support
- ðŸ”„ï¸ Dioxus Hot-reload support
- 📒 Multi-line text editing (experimental âš ï¸)
- 🦾 Basic Accessibility Support (experimental âš ï¸)
- 🧩Compatible with dioxus-std and other Dioxus renderer-agnostic libraries
Goals ðŸ˜
- Performant and low memory usage
- Good developer experience
- Cross-platform support
- Decent Accessibility support
- Useful testing APIs
- Useful and extensible components and hooks
Status ⌚
You can see the tracking issue to know what features are implemented and which ones are not, yet.
MIT License