Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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.
- Host: GitHub
- URL: https://github.com/chinedufn/percy
- Owner: chinedufn
- License: apache-2.0
- Created: 2018-07-16T11:14:12.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-09-29T13:42:49.000Z (3 months ago)
- Last Synced: 2024-10-29T14:59:23.697Z (2 months ago)
- Topics: browser, frontend, virtual-dom, wasm, web, webassembly
- Language: Rust
- Homepage: https://chinedufn.github.io/percy/
- Size: 9.49 MB
- Stars: 2,266
- Watchers: 44
- Forks: 84
- Open Issues: 42
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE
Awesome Lists containing this project
- awesome - chinedufn/percy - Build frontend browser apps with Rust + WebAssembly. Supports server side rendering. (Rust)
- awesome-list - percy
- awesome-yew - Percy - A modular toolkit for building isomorphic web apps with Rust + WebAssembly. (Alternatives / Frameworks)
- awesome-rust-zh - Percy - Rust + WebAssembly前端框架
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.rsuse 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 httpschmod +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