2021-09-24 06:37:51 +00:00
|
|
|
use dioxus::{events::MouseEvent, prelude::*};
|
|
|
|
use fxhash::FxBuildHasher;
|
2021-07-12 17:03:24 +00:00
|
|
|
use std::rc::Rc;
|
2021-06-22 21:20:54 +00:00
|
|
|
|
|
|
|
fn main() {
|
2021-10-16 21:04:28 +00:00
|
|
|
dioxus::desktop::launch(App, |c| c);
|
2021-06-22 21:20:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// We use a special immutable hashmap to make hashmap operations efficient
|
2021-07-07 17:51:55 +00:00
|
|
|
type RowList = im_rc::HashMap<usize, Rc<str>, FxBuildHasher>;
|
2021-06-22 21:20:54 +00:00
|
|
|
|
2021-10-16 21:37:28 +00:00
|
|
|
static App: FC<()> = |(cx, _props)| {
|
2021-07-12 17:03:24 +00:00
|
|
|
let items = use_state(cx, || RowList::default());
|
2021-06-22 21:20:54 +00:00
|
|
|
|
2021-07-12 17:03:24 +00:00
|
|
|
let create_rendered_rows = move |from, num| move |_| items.set(create_row_list(from, num));
|
2021-06-22 21:20:54 +00:00
|
|
|
|
|
|
|
let append_1_000_rows =
|
2021-07-12 17:03:24 +00:00
|
|
|
move |_| items.set(create_row_list(items.len(), 1000).union((*items).clone()));
|
2021-06-22 21:20:54 +00:00
|
|
|
|
|
|
|
let update_every_10th_row = move |_| {
|
2021-07-12 17:03:24 +00:00
|
|
|
let mut new_items = (*items).clone();
|
2021-06-22 21:20:54 +00:00
|
|
|
let mut small_rng = SmallRng::from_entropy();
|
2021-07-12 17:03:24 +00:00
|
|
|
new_items.iter_mut().step_by(10).for_each(|(_, val)| {
|
|
|
|
*val = create_new_row_label(&mut String::with_capacity(30), &mut small_rng)
|
|
|
|
});
|
|
|
|
items.set(new_items);
|
2021-06-22 21:20:54 +00:00
|
|
|
};
|
2021-07-12 17:03:24 +00:00
|
|
|
let clear_rows = move |_| items.set(RowList::default());
|
2021-06-22 21:20:54 +00:00
|
|
|
|
|
|
|
let swap_rows = move |_| {
|
|
|
|
// this looks a bit ugly because we're using a hashmap instead of a vec
|
|
|
|
if items.len() > 998 {
|
2021-07-12 17:03:24 +00:00
|
|
|
let mut new_items = (*items).clone();
|
2021-06-22 21:20:54 +00:00
|
|
|
let a = new_items.get(&0).unwrap().clone();
|
|
|
|
*new_items.get_mut(&0).unwrap() = new_items.get(&998).unwrap().clone();
|
|
|
|
*new_items.get_mut(&998).unwrap() = a;
|
2021-07-12 17:03:24 +00:00
|
|
|
items.set(new_items);
|
2021-06-22 21:20:54 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
let rows = items.iter().map(|(key, value)| {
|
|
|
|
rsx!(Row {
|
|
|
|
key: "{key}",
|
|
|
|
row_id: *key as usize,
|
|
|
|
label: value.clone(),
|
|
|
|
})
|
|
|
|
});
|
|
|
|
|
|
|
|
cx.render(rsx! {
|
|
|
|
div { class: "container"
|
|
|
|
div { class: "jumbotron"
|
|
|
|
div { class: "row"
|
|
|
|
div { class: "col-md-6", h1 { "Dioxus" } }
|
|
|
|
div { class: "col-md-6"
|
|
|
|
div { class: "row"
|
2021-09-24 06:37:51 +00:00
|
|
|
ActionButton { name: "Create 1,000 rows", id: "run", onclick: {create_rendered_rows(0, 1_000)} }
|
|
|
|
ActionButton { name: "Create 10,000 rows", id: "runlots", onclick: {create_rendered_rows(0, 10_000)} }
|
|
|
|
ActionButton { name: "Append 1,000 rows", id: "add", onclick: {append_1_000_rows} }
|
|
|
|
ActionButton { name: "Update every 10th row", id: "update", onclick: {update_every_10th_row} }
|
|
|
|
ActionButton { name: "Clear", id: "clear", onclick: {clear_rows} }
|
|
|
|
ActionButton { name: "Swap rows", id: "swaprows", onclick: {swap_rows} }
|
2021-06-22 21:20:54 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2021-07-12 17:03:24 +00:00
|
|
|
table {
|
2021-06-22 21:20:54 +00:00
|
|
|
tbody {
|
|
|
|
{rows}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
span {}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
};
|
|
|
|
|
|
|
|
#[derive(Props)]
|
2021-09-24 06:37:51 +00:00
|
|
|
struct ActionButtonProps<'a> {
|
2021-06-22 21:20:54 +00:00
|
|
|
name: &'static str,
|
|
|
|
id: &'static str,
|
2021-09-24 06:37:51 +00:00
|
|
|
onclick: &'a dyn Fn(MouseEvent),
|
2021-06-22 21:20:54 +00:00
|
|
|
}
|
2021-09-24 06:37:51 +00:00
|
|
|
|
2021-10-30 01:43:21 +00:00
|
|
|
fn ActionButton<'a>((cx, props): Scope<'a, ActionButtonProps>) -> Element<'a> {
|
2021-09-24 06:37:51 +00:00
|
|
|
rsx!(cx, div { class: "col-sm-6 smallpad"
|
|
|
|
button { class:"btn btn-primary btn-block", r#type: "button", id: "{props.id}", onclick: {props.onclick},
|
|
|
|
"{props.name}"
|
2021-06-22 21:20:54 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(PartialEq, Props)]
|
|
|
|
struct RowProps {
|
|
|
|
row_id: usize,
|
|
|
|
label: Rc<str>,
|
|
|
|
}
|
2021-10-30 01:43:21 +00:00
|
|
|
fn Row((cx, props): Scope<RowProps>) -> Element {
|
2021-09-24 06:37:51 +00:00
|
|
|
rsx!(cx, tr {
|
|
|
|
td { class:"col-md-1", "{props.row_id}" }
|
|
|
|
td { class:"col-md-1", onclick: move |_| { /* run onselect */ }
|
|
|
|
a { class: "lbl", "{props.label}" }
|
|
|
|
}
|
|
|
|
td { class: "col-md-1"
|
|
|
|
a { class: "remove", onclick: move |_| {/* remove */}
|
|
|
|
span { class: "glyphicon glyphicon-remove remove" aria_hidden: "true" }
|
2021-06-22 21:20:54 +00:00
|
|
|
}
|
|
|
|
}
|
2021-09-24 06:37:51 +00:00
|
|
|
td { class: "col-md-6" }
|
2021-06-22 21:20:54 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
use rand::prelude::*;
|
2021-07-12 17:03:24 +00:00
|
|
|
fn create_new_row_label(label: &mut String, rng: &mut SmallRng) -> Rc<str> {
|
2021-06-22 21:20:54 +00:00
|
|
|
label.push_str(ADJECTIVES.choose(rng).unwrap());
|
|
|
|
label.push(' ');
|
|
|
|
label.push_str(COLOURS.choose(rng).unwrap());
|
|
|
|
label.push(' ');
|
|
|
|
label.push_str(NOUNS.choose(rng).unwrap());
|
2021-07-12 17:03:24 +00:00
|
|
|
Rc::from(label.as_ref())
|
2021-06-22 21:20:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
fn create_row_list(from: usize, num: usize) -> RowList {
|
|
|
|
let mut small_rng = SmallRng::from_entropy();
|
2021-07-12 17:03:24 +00:00
|
|
|
let mut buf = String::with_capacity(35);
|
2021-06-22 21:20:54 +00:00
|
|
|
(from..num + from)
|
2021-07-12 17:03:24 +00:00
|
|
|
.map(|f| {
|
|
|
|
let o = (f, create_new_row_label(&mut buf, &mut small_rng));
|
|
|
|
buf.clear();
|
|
|
|
o
|
|
|
|
})
|
2021-06-22 21:20:54 +00:00
|
|
|
.collect::<RowList>()
|
|
|
|
}
|
|
|
|
|
|
|
|
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",
|
|
|
|
];
|