hirola-core

Crates.iohirola-core
lib.rshirola-core
version0.4.0
sourcesrc
created_at2020-12-30 20:36:15.13896
updated_at2023-12-28 22:06:45.181226
descriptionAn html library for building client side webapps
homepage
repositoryhttps://github.com/geofmureithi/hirola
max_upload_size
id329389
size66,454
Geoffrey Mureithi (geofmureithi)

documentation

https://docs.rs/hirola

README

Hirola

Latest Version Browser Tests Unit Tests MIT licensed

Hirola is a declarative frontend framework that is focused on simplicity and reactivity.

Goals

  1. KISS: A simple and declarative way to build frontend UIs in rust.
  2. Make it easy to read, extend and share code.
  3. Frp signals allowing fine-grained reactivity.
  4. Familiarity: Uses rsx which is very similar to jsx.

Example

We are going to create a simple counter program.

cargo new counter

With a new project, we need to create an index file which is the entry point and required by trunk

cd counter

Create an index.html in the root of counter. Add the contents below

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title>Hirola Counter</title>
  </head>
  <body></body>
</html>

Lets add some code to src/main.rs

use hirola::prelude::*;
use hirola::dom::*;

fn counter() -> Dom {
    let count = Mutable::new(0i32);
    let decrement = count.callback(|s| *s.lock_mut() -= 1);
    let increment = count.callback(|s| *s.lock_mut() += 1);
    html! {
        <>
            <button on:click=decrement>"-"</button>
            <span>{count}</span>
            <button on:click=increment>"+"</button>
        </>
    }
}
fn main() {
    hirola::dom::mount(counter()).unwrap();
}

Now lets run our project

trunk serve

Ecosystem

Check out Hirola Docs written with Hirola itself!

Here are some extensions for hirola:

  1. Form
  2. Router
  3. State
  4. Markdown

Milestones

Status Goal Labels
Basic templating with rust and rsx ready
Extend functionality with mixins ready
Components ready
SSR ready
Signals ready
🚧 Form management started
Markdown templating pending
🚧 Styling started
SSG pending
Commit count: 163

cargo fmt