Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/huytd/kanban-app
Kanban board built with Rust and Elm
https://github.com/huytd/kanban-app
elm gui kanban rust webview
Last synced: about 22 hours ago
JSON representation
Kanban board built with Rust and Elm
- Host: GitHub
- URL: https://github.com/huytd/kanban-app
- Owner: huytd
- License: other
- Created: 2018-04-28T21:30:52.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-05-09T20:28:12.000Z (over 6 years ago)
- Last Synced: 2025-01-05T16:03:48.099Z (8 days ago)
- Topics: elm, gui, kanban, rust, webview
- Language: Rust
- Homepage:
- Size: 187 KB
- Stars: 1,794
- Watchers: 33
- Forks: 71
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-list - kanban-app
- starred-awesome - kanban-app - Kanban board built with Rust and Elm (Rust)
- awesome-starred - huytd/kanban-app - Kanban board built with Rust and Elm (rust)
README
# Desktop Kanban Board
Look ma, no Electron!
![](light-theme.png)
![](dark-theme.png)
## What is this?
This is a web-based Kanban board application, built with Elm and Rust.
The only different from this application and hundred thousands of web-based application out there is: **We don't need [Electron](https://electronjs.org/)!**.
Instead, it use native WebView (WebKit for Linux/macOS, and MSHTML on Windows), more details [see here](https://github.com/zserge/webview).
The whole source code in this repository is just a desktop client, which you can actually use for **any** web-based application.
_Note: I maintain my own version of [zserge/webview](https://github.com/zserge/webview) and [Boscop/web-view](https://github.com/Boscop/web-view), because I want to add some customized titlebar on macOS, and my code is ugly enough to create a PR on these repos._
## Instruction
### Step 1: Build the web application
**Skip this if you're using an online hosted application from an URL, or building your own app**.
Clone the [Kanelm](https://github.com/huytd/kanelm) application source code from here https://github.com/huytd/kanelm
Follow the instruction in that repo to config your jsonbin.io config, then install the dependencies and build it:
```
yarn install
elm-package install
yarn build
```What you will get is a `dist` folder, and you only need the `dist.js` file, copy it to `www` folder of this repo.
```
└── www
└── dist.js
```### Step 2: Build the desktop application
You gonna need [cargo bundle](https://github.com/burtonageo/cargo-bundle).
Install it, then run:
```
cargo bundle --release
```Now you got it.
## Wait, what happened?
Well, the Elm application will be compiled into a single `dist.js` file, the content of this JavaScript file will be inlined into our Rust source code:
**src/main.rs**
```rust
let html = format!(r#"
{css}
{js}
"#,
css = r#"body { background: #1d1f21; }"#,
js = include_str!("../www/dist.js"));
```The Rust application will then create a new window, contains a webview, load this HTML content into that webview, and that's it.
## But Electron did the same thing?
Yeh, but sometimes, all you need is just a webview to display your web application on a desktop. You don't need file system access or automatic update, blah blah, it would be a huge waste to ship your app with >100MB of Chromium and V8 in it.
In fact, this application only uses 0-3% CPU and the bundle size is >800KB on macOS.
![](monitor.png)