1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
use wasm_bindgen::JsCast;
use web_sys::*;
use yew::prelude::*;
#[derive(Properties, PartialEq)]
pub struct ColorProps {
pub color: String,
pub on_color: Callback<String>,
}
#[function_component(ColorSelector)]
pub fn color_component(props: &ColorProps) -> Html {
let oninput = props.on_color.reform(|event: InputEvent| {
event
.target()
.unwrap()
.unchecked_into::<HtmlInputElement>()
.value()
});
html! {
<input
class="parameter"
type="color"
value={ props.color.to_owned() }
oninput={ oninput }/>
}
}