summaryrefslogtreecommitdiff
path: root/src/view/address.rs
diff options
context:
space:
mode:
authorjelemux <jeremias.weber@protonmail.com>2021-02-11 12:07:22 +0100
committerjelemux <jeremias.weber@protonmail.com>2021-02-11 12:07:22 +0100
commit0660151a8b641fa0a23dde2598132029970f7ae4 (patch)
tree0bdeb1108419add4570f278795f0bfd0f5366856 /src/view/address.rs
parent036a567bae8346eb38f9237f59645dbcc4f1cd8c (diff)
downloadwasm-card-0660151a8b641fa0a23dde2598132029970f7ae4.tar.gz
wasm-card-0660151a8b641fa0a23dde2598132029970f7ae4.tar.bz2
refactoring - reduced code size by about a third
Diffstat (limited to 'src/view/address.rs')
-rw-r--r--src/view/address.rs103
1 files changed, 0 insertions, 103 deletions
diff --git a/src/view/address.rs b/src/view/address.rs
deleted file mode 100644
index 57ea7e4..0000000
--- a/src/view/address.rs
+++ /dev/null
@@ -1,103 +0,0 @@
-use super::VCardPropertyInputComponent;
-use crate::view::InputProps;
-use crate::viewmodel::address::*;
-use crate::viewmodel::Error;
-use crate::viewmodel::VCardPropertyInputObject;
-use yew::prelude::*;
-use yewtil::NeqAssign;
-
-type Props = InputProps<Address, AddressView>;
-
-/// View Component for a `address` field
-///
-/// # Examples
-///
-/// ```compile_fail
-/// let html = html!{
-/// <AddressView weak_link=some_weak_component_link
-/// generated=self.link.callback(
-/// |n: Irc<Address>|
-/// Msg::GeneratedAddress(some_address)
-/// )
-/// />
-/// };
-/// ```
-#[derive(Clone, PartialEq)]
-pub struct AddressView {
- props: Props,
- value: Address,
- error: Option<Error>,
-}
-
-pub enum Msg {
- UpdatePostOfficeBox(String),
- UpdateExtension(String),
- UpdateStreet(String),
- UpdateLocality(String),
- UpdateRegion(String),
- UpdateCode(String),
- UpdateCountry(String),
- ToggleWork,
- ToggleHome,
-
- Generate,
-}
-
-impl VCardPropertyInputComponent<Address> for AddressView {
- fn get_input_object(&self) -> Address {
- self.value.clone()
- }
- fn get_title(&self) -> String {
- "Address".to_string()
- }
- fn get_error(&self) -> Option<Error> {
- self.error.clone()
- }
-}
-
-impl Component for AddressView {
- 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 {
- props,
- value: Address::new(),
- error: None,
- }
- }
- fn update(&mut self, msg: <Self as yew::Component>::Message) -> bool {
- match msg {
- Msg::UpdatePostOfficeBox(b) => self.value.post_office_box = b,
- Msg::UpdateExtension(e) => self.value.extension = e,
- Msg::UpdateStreet(s) => self.value.street = s,
- Msg::UpdateLocality(l) => self.value.locality = l,
- Msg::UpdateRegion(r) => self.value.region = r,
- Msg::UpdateCode(p) => self.value.code = p,
- Msg::UpdateCountry(c) => self.value.country = c,
- Msg::ToggleWork => self.value.work = !self.value.work,
- Msg::ToggleHome => self.value.home = !self.value.home,
- Msg::Generate => {
- self.props.generated.emit(self.value.clone());
- }
- };
- true
- }
- fn change(&mut self, props: <Self as yew::Component>::Properties) -> bool {
- self.props.neq_assign(props)
- }
- fn view(&self) -> yew::virtual_dom::VNode {
- let link = self.props.weak_link.borrow().clone().unwrap();
-
- html! {
- <div class="box">
- { self.render_error() }
-
- <h3 class="subtitle">{ self.get_title() }</h3>
-
- { self.get_input_object().render(&link) }
-
- </div>
- }
- }
-}