dioxus/packages/core/examples/jsframework.rs

115 lines
2.5 KiB
Rust
Raw Normal View History

2021-10-04 05:28:04 +00:00
use dioxus::events::on::MouseEvent;
2021-08-23 17:15:57 +00:00
use dioxus_core as dioxus;
use dioxus_core::prelude::*;
2021-09-25 01:46:23 +00:00
use dioxus_core_macro::*;
2021-08-23 17:15:57 +00:00
use dioxus_html as dioxus_elements;
use rand::prelude::*;
use std::fmt::Display;
fn main() {
let mut dom = VirtualDom::new(App);
2021-08-24 19:12:20 +00:00
let g = dom.rebuild();
2021-08-23 17:15:57 +00:00
assert!(g.edits.len() > 1);
}
2021-09-21 17:42:52 +00:00
static App: FC<()> = |cx, props| {
2021-08-23 17:15:57 +00:00
let mut rng = SmallRng::from_entropy();
2021-10-16 21:04:28 +00:00
let rows = (0..10_000_usize).map(|f| {
2021-08-23 17:15:57 +00:00
let label = Label::new(&mut rng);
rsx! {
Row {
row_id: f,
label: label
}
}
});
cx.render(rsx! {
table {
tbody {
{rows}
}
}
})
};
#[derive(PartialEq, Props)]
struct RowProps {
row_id: usize,
label: Label,
}
2021-09-21 17:42:52 +00:00
fn Row<'a>(cx: Context<'a>, props: &'a RowProps) -> DomTree<'a> {
2021-10-04 05:28:04 +00:00
let handler = move |evt: MouseEvent| {
let g = evt.button;
};
2021-08-23 17:15:57 +00:00
cx.render(rsx! {
tr {
2021-09-21 17:42:52 +00:00
td { class:"col-md-1", "{props.row_id}" }
2021-08-23 17:15:57 +00:00
td { class:"col-md-1", onclick: move |_| { /* run onselect */ }
2021-09-21 17:42:52 +00:00
a { class: "lbl", "{props.label}" }
2021-08-23 17:15:57 +00:00
}
td { class: "col-md-1"
2021-10-04 05:28:04 +00:00
a { class: "remove", onclick: {handler}
2021-08-23 17:15:57 +00:00
span { class: "glyphicon glyphicon-remove remove" aria_hidden: "true" }
}
}
td { class: "col-md-6" }
}
})
}
#[derive(PartialEq)]
struct Label([&'static str; 3]);
impl Label {
fn new(rng: &mut SmallRng) -> Self {
Label([
ADJECTIVES.choose(rng).unwrap(),
COLOURS.choose(rng).unwrap(),
NOUNS.choose(rng).unwrap(),
])
}
}
impl Display for Label {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(f, "{} {} {}", self.0[0], self.0[1], self.0[2])
}
}
static ADJECTIVES: &[&str] = &[
"pretty",
"large",
"big",
"small",
"tall",
"short",
"long",
"handsome",
"plain",
"quaint",
"clean",
"elegant",
"easy",
"angry",
"crazy",
"helpful",
"mushy",
"odd",
"unsightly",
"adorable",
"important",
"inexpensive",
"cheap",
"expensive",
"fancy",
];
static COLOURS: &[&str] = &[
"red", "yellow", "blue", "green", "pink", "brown", "purple", "brown", "white", "black",
"orange",
];
static NOUNS: &[&str] = &[
"table", "chair", "house", "bbq", "desk", "car", "pony", "cookie", "sandwich", "burger",
"pizza", "mouse", "keyboard",
];