Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/utkarshkukreti/draco
Draco is a Rust library for building client side web applications with Web Assembly.
https://github.com/utkarshkukreti/draco
Last synced: 4 days ago
JSON representation
Draco is a Rust library for building client side web applications with Web Assembly.
- Host: GitHub
- URL: https://github.com/utkarshkukreti/draco
- Owner: utkarshkukreti
- License: apache-2.0
- Created: 2018-10-26T08:08:11.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2023-04-03T07:36:23.000Z (almost 2 years ago)
- Last Synced: 2025-01-14T12:13:06.772Z (11 days ago)
- Language: Rust
- Homepage:
- Size: 438 KB
- Stars: 302
- Watchers: 15
- Forks: 18
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
Awesome Lists containing this project
- awesome-ccamel - utkarshkukreti/draco - Draco is a Rust library for building client side web applications with Web Assembly. (Rust)
- awesome-yew - Draco - A Rust library for building client side web applications with WebAssembly. (Alternatives / Frameworks)
README
# Draco
> Draco is a Rust library to build client side web applications with Web
> Assembly.> [Live Examples with Annotated Source](https://draco-examples.netlify.com/) |
> [Starter](https://github.com/utkarshkukreti/draco-starter)> Note: This is the README for upcoming Draco 0.2.
> The README for the latest released version is
> [here](https://github.com/utkarshkukreti/draco/tree/0.1.2).## Overview
The "Hello, World!" of Draco ([with comments here](examples/hello_world/src/lib.rs)):
```rust
use wasm_bindgen::prelude::*;struct HelloWorld;
impl draco::Application for HelloWorld {
type Message = ();fn view(&self) -> draco::VNode {
draco::html::h1().with("Hello, world!").into()
}
}#[wasm_bindgen(start)]
pub fn start() {
draco::start(HelloWorld, draco::select("main").expect("").into());
}
```Draco is modeled after The Elm Architecture and Redux. A Draco application
implements the `draco::Application` trait, which includes one type and two
functions.```rust
pub trait Application {
type Message;fn update(&mut self, message: Self::Message, mailbox: &Mailbox) {}
fn view(&self) -> Node;
}
```The `view` function maps `&self` to an HTML/SVG Node. The Node can emit
`Message`s on certain events.The `update` function takes `&mut self`, a `Message` and a `draco::Mailbox`.
This function may update its fields based on the value of the Message. This
function may also send more messages to itself or spawn a Future which will send
a message when it resolves, through the `Mailbox`.### Counter
This Counter example ([with comments here](examples/counter/src/lib.rs))
demonstrates an application which updates an integer value based on 3 types of
messages emitted from the view.```rust
use wasm_bindgen::prelude::*;#[derive(Default)]
pub struct Counter {
value: i32,
}pub enum Message {
Increment,
Decrement,
Reset,
}impl draco::Application for Counter {
type Message = Message;fn update(&mut self, message: Self::Message, _: &draco::Mailbox) {
match message {
Message::Increment => self.value += 1,
Message::Decrement => self.value -= 1,
Message::Reset => self.value = 0,
}
}fn view(&self) -> draco::VNode {
use draco::html as h;
h::div()
.with((
h::button().on("click", |_| Message::Decrement).with("-"),
" ",
self.value,
" ",
h::button().with("+").on("click", |_| Message::Increment),
" ",
h::button().with("Reset").on("click", |_| Message::Reset),
))
.into()
}
}#[wasm_bindgen(start)]
pub fn start() {
draco::start(
Counter::default(),
draco::select("main").expect("").into(),
);
}
```