2021-10-25 19:05:17 +00:00
|
|
|
#![allow(non_snake_case)]
|
|
|
|
|
2021-10-30 01:43:21 +00:00
|
|
|
use dioxus::component::Scope;
|
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-10-30 01:43:21 +00:00
|
|
|
fn App((cx, props): Scope<()>) -> Element {
|
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
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2021-10-30 01:43:21 +00:00
|
|
|
cx.render(rsx! {
|
2021-08-23 17:15:57 +00:00
|
|
|
table {
|
|
|
|
tbody {
|
|
|
|
{rows}
|
|
|
|
}
|
|
|
|
}
|
2021-10-30 01:43:21 +00:00
|
|
|
})
|
2021-10-25 19:05:17 +00:00
|
|
|
}
|
2021-08-23 17:15:57 +00:00
|
|
|
|
|
|
|
#[derive(PartialEq, Props)]
|
|
|
|
struct RowProps {
|
|
|
|
row_id: usize,
|
|
|
|
label: Label,
|
|
|
|
}
|
2021-10-25 19:05:17 +00:00
|
|
|
|
2021-10-30 01:43:21 +00:00
|
|
|
fn Row((cx, props): Scope<RowProps>) -> Element {
|
2021-10-04 05:28:04 +00:00
|
|
|
let handler = move |evt: MouseEvent| {
|
|
|
|
let g = evt.button;
|
|
|
|
};
|
2021-10-30 01:43:21 +00:00
|
|
|
cx.render(rsx! {
|
2021-08-23 17:15:57 +00:00
|
|
|
tr {
|
2021-09-21 17:42:52 +00:00
|
|
|
td { class:"col-md-1", "{props.row_id}" }
|
2021-10-27 20:58:20 +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-27 20:58:20 +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" }
|
|
|
|
}
|
2021-10-30 01:43:21 +00:00
|
|
|
})
|
2021-08-23 17:15:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[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",
|
|
|
|
];
|