mirror of
https://github.com/DioxusLabs/dioxus
synced 2024-11-27 14:40:44 +00:00
107 lines
5.9 KiB
Rust
107 lines
5.9 KiB
Rust
use dioxus::prelude::*;
|
|
|
|
fn main() {
|
|
dioxus_desktop::launch(app);
|
|
}
|
|
|
|
fn app(cx: Scope) -> Element {
|
|
let mut count = use_state(cx, || 0);
|
|
|
|
cx.render(
|
|
// rsx expands to LazyNodes::new
|
|
::dioxus::core::LazyNodes::new(
|
|
move |__cx: &::dioxus::core::ScopeState| -> ::dioxus::core::VNode {
|
|
// The template is every static part of the rsx
|
|
static TEMPLATE: ::dioxus::core::Template = ::dioxus::core::Template {
|
|
// This is the source location of the rsx that generated this template. This is used to make hot rsx reloading work. Hot rsx reloading just replaces the template with a new one generated from the rsx by the CLI.
|
|
name: "examples\\readme.rs:14:15:250",
|
|
// The root nodes are the top level nodes of the rsx
|
|
roots: &[
|
|
// The h1 node
|
|
::dioxus::core::TemplateNode::Element {
|
|
// Find the built in h1 tag in the dioxus_elements crate exported by the dioxus html crate
|
|
tag: dioxus_elements::h1::TAG_NAME,
|
|
namespace: dioxus_elements::h1::NAME_SPACE,
|
|
attrs: &[],
|
|
// The children of the h1 node
|
|
children: &[
|
|
// The dynamic count text node
|
|
// Any nodes that are dynamic have a dynamic placeholder with a unique index
|
|
::dioxus::core::TemplateNode::DynamicText {
|
|
// This index is used to find what element in `dynamic_nodes` to use instead of the placeholder
|
|
id: 0usize,
|
|
},
|
|
],
|
|
},
|
|
// The up high button node
|
|
::dioxus::core::TemplateNode::Element {
|
|
tag: dioxus_elements::button::TAG_NAME,
|
|
namespace: dioxus_elements::button::NAME_SPACE,
|
|
attrs: &[
|
|
// The dynamic onclick listener attribute
|
|
// Any attributes that are dynamic have a dynamic placeholder with a unique index.
|
|
::dioxus::core::TemplateAttribute::Dynamic {
|
|
// Similar to dynamic nodes, dynamic attributes have a unique index used to find the attribute in `dynamic_attrs` to use instead of the placeholder
|
|
id: 0usize,
|
|
},
|
|
],
|
|
children: &[::dioxus::core::TemplateNode::Text { text: "Up high!" }],
|
|
},
|
|
// The down low button node
|
|
::dioxus::core::TemplateNode::Element {
|
|
tag: dioxus_elements::button::TAG_NAME,
|
|
namespace: dioxus_elements::button::NAME_SPACE,
|
|
attrs: &[
|
|
// The dynamic onclick listener attribute
|
|
::dioxus::core::TemplateAttribute::Dynamic { id: 1usize },
|
|
],
|
|
children: &[::dioxus::core::TemplateNode::Text { text: "Down low!" }],
|
|
},
|
|
],
|
|
// Node paths is a list of paths to every dynamic node in the rsx
|
|
node_paths: &[
|
|
// The first node path is the path to the dynamic node with an id of 0 (the count text node)
|
|
&[
|
|
// Go to the index 0 root node
|
|
0u8,
|
|
//
|
|
// Go to the first child of the root node
|
|
0u8,
|
|
],
|
|
],
|
|
// Attr paths is a list of paths to every dynamic attribute in the rsx
|
|
attr_paths: &[
|
|
// The first attr path is the path to the dynamic attribute with an id of 0 (the up high button onclick listener)
|
|
&[
|
|
// Go to the index 1 root node
|
|
1u8,
|
|
],
|
|
// The second attr path is the path to the dynamic attribute with an id of 1 (the down low button onclick listener)
|
|
&[
|
|
// Go to the index 2 root node
|
|
2u8,
|
|
],
|
|
],
|
|
};
|
|
// The VNode is a reference to the template with the dynamic parts of the rsx
|
|
::dioxus::core::VNode {
|
|
parent: None,
|
|
key: None,
|
|
// The static template this node will use. The template is stored in a Cell so it can be replaced with a new template when hot rsx reloading is enabled
|
|
template: std::cell::Cell::new(TEMPLATE),
|
|
root_ids: Default::default(),
|
|
dynamic_nodes: __cx.bump().alloc([
|
|
// The dynamic count text node (dynamic node id 0)
|
|
__cx.text_node(format_args!("High-Five counter: {0}", count)),
|
|
]),
|
|
dynamic_attrs: __cx.bump().alloc([
|
|
// The dynamic up high button onclick listener (dynamic attribute id 0)
|
|
dioxus_elements::events::onclick(__cx, move |_| count += 1),
|
|
// The dynamic down low button onclick listener (dynamic attribute id 1)
|
|
dioxus_elements::events::onclick(__cx, move |_| count -= 1),
|
|
]),
|
|
}
|
|
},
|
|
),
|
|
)
|
|
}
|