dioxus/packages/desktop/src
2022-02-21 23:45:01 -05:00
..
assets feat: move default_icon to assets 2022-02-14 16:53:35 +08:00
cfg.rs feat: tweak debug tools to be customizable 2022-02-21 23:45:01 -05:00
controller.rs fix: ping window after virtualdom is ready 2022-02-19 17:34:44 -05:00
desktop_context.rs Support maximize toggle and devtool 2022-02-13 20:34:27 +01:00
escape.rs fix: really big bug around hooks 2021-11-29 11:10:40 -05:00
events.rs fix: compile for rust 1.57 2022-02-18 23:30:09 -05:00
index.html wip: disable reload in production 2022-02-19 22:36:55 -05:00
lib.rs feat: tweak debug tools to be customizable 2022-02-21 23:45:01 -05:00
protocol.rs Extract protocol hander into module 2022-02-13 20:34:26 +01:00
readme.md Add default desktop icon 2022-02-13 00:35:02 +08:00
user_window_events.rs fix: ping window after virtualdom is ready 2022-02-19 17:34:44 -05:00

Dioxus Desktop Renderer

Render the Dioxus VirtualDom using the platform's native WebView implementation.

Desktop

One of Dioxus' killer features is the ability to quickly build a native desktop app that looks and feels the same across platforms. Apps built with Dioxus are typically <5mb in size and use existing system resources, so they won't hog extreme amounts of RAM or memory.

Dioxus Desktop is built off Tauri. Right now there aren't any Dioxus abstractions over keyboard shortcuts, menubar, handling, etc, so you'll want to leverage Tauri - mostly Wry and Tao) directly. The next major release of Dioxus-Desktop will include components and hooks for notifications, global shortcuts, menubar, etc.

Getting Set up

Getting Set up with Dioxus-Desktop is quite easy. Make sure you have Rust and Cargo installed, and then create a new project:

$ cargo new --bin demo
$ cd app

Add Dioxus with the desktop feature:

$ cargo add dioxus --features desktop

Edit your main.rs:

// main.rs
use dioxus::prelude::*;

fn main() {
    dioxus::desktop::launch(app);
}

fn app(cx: Scope) -> Element {
    cx.render(rsx!{
        div {
            "hello world!"
        }
    })
}

To configure the webview, menubar, and other important desktop-specific features, checkout out some of the launch configuration in the API reference.

Future Steps

Make sure to read the Dioxus Guide if you already haven't!