mirror of
https://github.com/yewprint/yewprint
synced 2024-11-22 11:33:04 +00:00
Fix NumericInput's onchange
prop (#129)
This commit is contained in:
parent
2e541af11c
commit
89e6c93b86
4 changed files with 23 additions and 5 deletions
|
@ -44,6 +44,7 @@ impl Component for CheckboxDoc {
|
|||
html! {
|
||||
<div>
|
||||
<H1 class=classes!("docs-title")>{"Checkbox"}</H1>
|
||||
<SourceCodeUrl />
|
||||
<ExampleContainer
|
||||
source=source
|
||||
props=Some(html! {
|
||||
|
@ -94,3 +95,5 @@ crate::build_example_prop_component! {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
crate::build_source_code_component!();
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
use yew::prelude::*;
|
||||
use yewprint::{Button, IconName, NumericInput};
|
||||
use yewprint::{Button, IconName, NumericInput, Text};
|
||||
|
||||
pub struct Example {
|
||||
props: ExampleProps,
|
||||
|
@ -17,6 +17,8 @@ pub struct ExampleProps {
|
|||
|
||||
pub enum Msg {
|
||||
Reset,
|
||||
UpdateValue(i32),
|
||||
UpdateValueTwo(i32),
|
||||
}
|
||||
|
||||
impl Component for Example {
|
||||
|
@ -38,6 +40,12 @@ impl Component for Example {
|
|||
self.value = 4;
|
||||
self.value_two = 4;
|
||||
}
|
||||
Msg::UpdateValue(value) => {
|
||||
self.value = value;
|
||||
}
|
||||
Msg::UpdateValueTwo(value) => {
|
||||
self.value_two = value;
|
||||
}
|
||||
}
|
||||
true
|
||||
}
|
||||
|
@ -61,6 +69,7 @@ impl Component for Example {
|
|||
bounds=i32::MIN..=i32::MAX
|
||||
increment=10
|
||||
placeholder=String::from("Enter an integer...")
|
||||
onchange=self.link.callback(|x| Msg::UpdateValueTwo(x))
|
||||
/>
|
||||
<NumericInput<i32>
|
||||
disabled=self.props.disabled
|
||||
|
@ -70,6 +79,7 @@ impl Component for Example {
|
|||
bounds=-10..=10
|
||||
increment=1
|
||||
placeholder=String::from("Integer between -10 and 10")
|
||||
onchange=self.link.callback(|x| Msg::UpdateValue(x))
|
||||
/>
|
||||
<Button
|
||||
icon=IconName::Refresh
|
||||
|
@ -77,6 +87,7 @@ impl Component for Example {
|
|||
>
|
||||
{"Reset at 4"}
|
||||
</Button>
|
||||
<Text>{format!("actual values are {} and {}", self.value, self.value_two)}</Text>
|
||||
</>
|
||||
}
|
||||
}
|
||||
|
|
|
@ -44,6 +44,7 @@ impl Component for NumericInputDoc {
|
|||
html! {
|
||||
<div>
|
||||
<H1 class=classes!("docs-title")>{"NumericInput"}</H1>
|
||||
<SourceCodeUrl />
|
||||
<div>
|
||||
<ExampleContainer
|
||||
source=source
|
||||
|
@ -96,3 +97,5 @@ crate::build_example_prop_component! {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
crate::build_source_code_component!();
|
||||
|
|
|
@ -104,6 +104,7 @@ where
|
|||
self.props.value = Some(num);
|
||||
self.input = value;
|
||||
}
|
||||
self.props.onchange.emit(self.props.value.clone().unwrap());
|
||||
true
|
||||
} else {
|
||||
false
|
||||
|
@ -114,12 +115,12 @@ where
|
|||
if num >= *self.props.bounds.end() {
|
||||
self.props.value = Some(self.props.bounds.end().clone());
|
||||
self.input = self.props.bounds.end().to_string();
|
||||
true
|
||||
} else {
|
||||
self.props.value = Some(num.clone() + self.props.increment.clone());
|
||||
self.input = (num + self.props.increment.clone()).to_string();
|
||||
true
|
||||
}
|
||||
self.props.onchange.emit(self.props.value.clone().unwrap());
|
||||
true
|
||||
} else {
|
||||
false
|
||||
}
|
||||
|
@ -129,12 +130,12 @@ where
|
|||
if num <= *self.props.bounds.start() {
|
||||
self.props.value = Some(self.props.bounds.start().clone());
|
||||
self.input = self.props.bounds.start().to_string();
|
||||
true
|
||||
} else {
|
||||
self.props.value = Some(num.clone() - self.props.increment.clone());
|
||||
self.input = (num - self.props.increment.clone()).to_string();
|
||||
true
|
||||
}
|
||||
self.props.onchange.emit(self.props.value.clone().unwrap());
|
||||
true
|
||||
} else {
|
||||
false
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue