summaryrefslogtreecommitdiff
path: root/src/view/name.rs
diff options
context:
space:
mode:
authorjelemux <jeremias.weber@protonmail.com>2021-01-28 17:41:49 +0100
committerjelemux <jeremias.weber@protonmail.com>2021-01-28 17:41:49 +0100
commit3f0892368bcf475fdae39f24ef51b82b3013535f (patch)
tree087a0869e618cc37b48e6d462c99bc1b289ddabf /src/view/name.rs
parent4a0c73eebb8dfd6a5543945049175f64b9817c96 (diff)
downloadwasm-card-3f0892368bcf475fdae39f24ef51b82b3013535f.tar.gz
wasm-card-3f0892368bcf475fdae39f24ef51b82b3013535f.tar.bz2
try to fix problem with vcard mutable references
Diffstat (limited to 'src/view/name.rs')
-rw-r--r--src/view/name.rs61
1 files changed, 43 insertions, 18 deletions
diff --git a/src/view/name.rs b/src/view/name.rs
index f76fd2e..df3fb15 100644
--- a/src/view/name.rs
+++ b/src/view/name.rs
@@ -1,3 +1,5 @@
+use crate::viewmodel::Error;
+use crate::view::WeakComponentLink;
use yew::prelude::*;
use vcard::properties;
use crate::viewmodel::name::*;
@@ -5,10 +7,9 @@ use crate::viewmodel::VCardPropertyInputObject;
use super::VCardPropertyInputComponent;
pub struct NameView {
- link: ComponentLink<Self>,
+ props: Props,
value: Name,
- oninput: Callback<Name>,
- errors: Vec<String>,
+ error: Option<Error>,
}
pub enum Msg {
@@ -17,11 +18,15 @@ pub enum Msg {
UpdateMiddleName(String),
UpdateLastName(String),
UpdateSuffix(String),
+
+ Generate,
}
#[derive(Clone, PartialEq, Properties)]
pub struct Props {
- pub oninput: Callback<Name>,
+ pub generated_name: Callback<Result<properties::Name,()>>,
+ pub generated_fn: Callback<Result<properties::FormattedName,()>>,
+ pub weak_link: WeakComponentLink<NameView>,
}
impl VCardPropertyInputComponent<properties::Name, Name> for NameView {
@@ -31,8 +36,8 @@ impl VCardPropertyInputComponent<properties::Name, Name> for NameView {
fn get_title(&self) -> String {
"Name".to_string()
}
- fn get_errors(&self) -> Vec<String> {
- self.errors.clone()
+ fn get_error(&self) -> Option<Error> {
+ self.error.clone()
}
}
@@ -40,11 +45,11 @@ impl Component for NameView {
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: Name::new(),
- oninput: props.oninput,
- errors: vec![],
+ error: None,
}
}
fn update(&mut self, msg: <Self as yew::Component>::Message) -> bool {
@@ -54,26 +59,46 @@ impl Component for NameView {
Msg::UpdateMiddleName(m) => self.value.middle_name = m,
Msg::UpdateLastName(l) => self.value.last_name = l,
Msg::UpdateSuffix(s) => self.value.suffix = s,
+ Generate => {
+ match self.value.formatted_name() {
+ Ok(formatted_name) => self.props.generated_fn.emit(Ok(formatted_name)),
+ Err(error) => {
+ self.props.generated_fn.emit(Err(()));
+ self.error = Some(error);
+ },
+ };
+ match self.value.to_vcard_property() {
+ Ok(name) => {
+ self.props.generated_name.emit(Ok(name));
+ return false;
+ },
+ Err(error) => {
+ self.props.generated_name.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>
}