summaryrefslogtreecommitdiff
path: root/src/view/telephone.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/view/telephone.rs')
-rw-r--r--src/view/telephone.rs54
1 files changed, 35 insertions, 19 deletions
diff --git a/src/view/telephone.rs b/src/view/telephone.rs
index 808ebfa..a47c610 100644
--- a/src/view/telephone.rs
+++ b/src/view/telephone.rs
@@ -1,3 +1,5 @@
+use crate::view::WeakComponentLink;
+use crate::viewmodel::Error;
use yew::prelude::*;
use vcard::properties;
use crate::viewmodel::telephone::*;
@@ -5,10 +7,9 @@ use crate::viewmodel::VCardPropertyInputObject;
use super::VCardPropertyInputComponent;
pub struct TelephoneView {
- link: ComponentLink<Self>,
+ props: Props,
value: Telephone,
- oninput: Callback<Telephone>,
- errors: Vec<String>,
+ error: Option<Error>,
}
pub enum Msg {
@@ -23,12 +24,14 @@ pub enum Msg {
ToggleVideo,
TogglePager,
ToggleTextPhone,
+
+ Generate,
}
#[derive(Clone, PartialEq, Properties)]
pub struct Props {
- pub oninput: Callback<Telephone>,
- //pub errors: Vec<String>,
+ pub generated: Callback<Result<properties::Telephone,()>>,
+ pub weak_link: WeakComponentLink<TelephoneView>,
}
impl VCardPropertyInputComponent<properties::Telephone, Telephone> for TelephoneView {
@@ -38,8 +41,8 @@ impl VCardPropertyInputComponent<properties::Telephone, Telephone> for Telephone
fn get_title(&self) -> String {
"Telephone".to_string()
}
- fn get_errors(&self) -> Vec<String> {
- self.errors.clone()
+ fn get_error(&self) -> Option<Error> {
+ self.error.clone()
}
}
@@ -47,11 +50,11 @@ impl Component for TelephoneView {
type Message = Msg;
type Properties = Props;
fn create(props: <Self as yew::Component>::Properties, link: yew::html::Scope<Self>) -> Self {
+ props.weak_link.borrow_mut().replace(link);
Self {
- link,
+ props,
value: Telephone::new(),
- oninput: props.oninput,
- errors: vec![],
+ error: None,
}
}
fn update(&mut self, msg: <Self as yew::Component>::Message) -> bool {
@@ -67,26 +70,39 @@ impl Component for TelephoneView {
Msg::ToggleVideo => self.value.video = !self.value.video,
Msg::TogglePager => self.value.pager = !self.value.pager,
Msg::ToggleTextPhone => self.value.text_phone = !self.value.text_phone,
+ Msg::Generate => {
+ match self.value.to_vcard_property() {
+ Ok(telephone) => {
+ self.props.generated.emit(Ok(telephone));
+ return false;
+ },
+ Err(error) => {
+ self.props.generated.emit(Err(()));
+ self.error = Some(error);
+ },
+ };
+ }
};
- self.oninput.emit(self.value.clone());
true
}
fn change(&mut self, props: <Self as yew::Component>::Properties) -> bool {
- self.oninput = props.oninput;
- true
+ if self.props != props {
+ self.props = props;
+ true
+ } else {
+ false
+ }
}
fn view(&self) -> yew::virtual_dom::VNode {
+ let link = self.props.weak_link.borrow().clone().unwrap();
+
html!{
<div class="box">
- {
- self.render_errors()
- }
+ { self.render_error() }
<h3 class="subtitle">{ self.get_title() }</h3>
- {
- self.get_input_object().render(&self.link)
- }
+ { self.get_input_object().render(&link) }
</div>
}