Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/chinedufn/percy

Build frontend browser apps with Rust + WebAssembly. Supports server side rendering.
https://github.com/chinedufn/percy

browser frontend virtual-dom wasm web webassembly

Last synced: 5 days ago
JSON representation

Build frontend browser apps with Rust + WebAssembly. Supports server side rendering.

Awesome Lists containing this project

README

        

Percy
=====

[![Actions Status](https://github.com/chinedufn/percy/workflows/tests/badge.svg)](https://github.com/chinedufn/percy/actions)
[![Actions Status](https://github.com/chinedufn/percy/workflows/github-pages/badge.svg)](https://github.com/chinedufn/percy/actions)

> Build frontend browser apps with Rust + WebAssembly. Supports server side rendering.

## The Percy Book

This README gives a light introduction to Percy. Check out [The Percy Book] for a full walk through.

[The Percy Book]: https://chinedufn.github.io/percy/

## Stable Rust

Percy compiles on stable Rust with one caveat:

On nightly Rust you can create text nodes without quotes.

```rust
// Nightly Rust does not require quotes around text nodes.
html! {

My text nodes here
};
```

On stable Rust, quotation marks are required.

```rust
// Stable Rust requires quotes around text nodes.
html! {

{ "My text nodes here " }
};
```

This difference will go away once span locations are stabilized in the Rust compiler - [Rust tracking issue](https://github.com/rust-lang/rust/issues/54725).

## Getting Started

The best way to get up to speed is by checking out [The Percy Book](https://chinedufn.github.io/percy/), but here is a
very basic example to get your feet wet with.

### Quickstart - Getting your feet wet

Percy allows you to create applications that only have server side rendering, only client side rendering,
or both server and client side rendering.

Here's a quick-and-easy working example of client side rendering that you can try right now:

---

First, Create a new project using

```sh
cargo new client-side-web-app --lib
cd client-side-web-app
```

---

Add the following files to your project.

```sh
touch build.sh
touch index.html
touch app.css
```

---

Here's the directory structure:

```sh
.
├── Cargo.toml
├── build.sh
├── index.html
├── app.css
└── src
└── lib.rs
```

---

Now edit each file with the following contents:

```sh
# contents of build.sh

#!/bin/bash

cd "$(dirname "$0")"

mkdir -p public

cargo build --target wasm32-unknown-unknown
wasm-bindgen target/wasm32-unknown-unknown/debug/client_side_web_app.wasm --no-typescript --target web --out-dir ./public --debug
cp index.html public/
cp app.css public/
```

---

```rust
// contents of src/lib.rs

use wasm_bindgen::prelude::*;
use web_sys;

use percy_dom::prelude::*;

#[wasm_bindgen]
struct App {
pdom: PercyDom
}

#[wasm_bindgen]
impl App {
#[wasm_bindgen(constructor)]
pub fn new () -> App {
let start_view = html! {

Hello
};

let window = web_sys::window().unwrap();
let document = window.document().unwrap();
let body = document.body().unwrap();

let mut pdom = PercyDom::new_append_to_mount(start_view, &body);

let greetings = "Hello, World!";

let end_view = html! {
// Use regular Rust comments within your html


/* Interpolate values using braces */
{ greetings }


// No need to wrap text in quotation marks (:
Click me and check your console


};

pdom.update(end_view);

App { pdom }
}
}
```

---

```toml
# contents of Cargo.toml

[package]
name = "client-side-web-app"
version = "0.1.0"
authors = ["Friends of Percy"]
edition = "2018"

[lib]
crate-type = ["cdylib"] # Don't forget this!

[dependencies]
wasm-bindgen = "0.2"
js-sys = "0.3"
percy-dom = "0.9"

[dependencies.web-sys]
version = "0.3"
features = [
"Document",
"MouseEvent",
"Window",
"console"
]
```

---

```html





Client Side Demo



import init, {App} from '/client_side_web_app.js'

async function run () {
await init('/client_side_web_app_bg.wasm')
new App()
}

run()

```

---

```css
/* contents of app.css */
.big {
font-size: 30px;
}
.blue {
color: blue;
}
.giant-button {
font-size: 24px;
font-weight: bold;
}
```

---

Now run

```sh
# Used to compile your Rust code to WebAssembly
cargo install wasm-bindgen-cli

# Or any other static file server that supports the application/wasm mime type
cargo install https

chmod +x ./build.sh
./build.sh

# Visit localhost:8080 in your browser
http ./public --port 8080
```

And you should see the following:

![Client side example](./example.png)

Nice work!

## More Examples

- [Isomorphic web app](examples/isomorphic)

- [Unit Testing View Components](examples/unit-testing-components)

- [Open an Issue or PR if you have an idea for a useful example!](https://github.com/chinedufn/percy/issues)

## API Documentation

- [percy-dom API docs](https://chinedufn.github.io/percy/api/percy_dom/macro.html.html)

- [html-macro API docs](https://chinedufn.github.io/percy/api/html_macro)

- [percy-router API docs](https://chinedufn.github.io/percy/api/percy_router)

## Contributing

Always feel very free to open issues and PRs with any questions / thoughts that you have!

Even if it feels basic or simple - if there's a question on your mind that you can't quickly answer yourself then that's a failure
in the documentation.

Much more information on how to contribute to the codebase can be found in the [contributing section](https://chinedufn.github.io/percy/contributing/getting-started.html) of The Percy Book!

## To Test

To run all of the unit, integration and browser tests, [grab the dependencies then](https://chinedufn.github.io/percy/contributing/getting-started.html) :

```sh
./test.sh
```

## License

MIT