From e0c21b5f285651313cf80bcb6812dc9a80d90928 Mon Sep 17 00:00:00 2001 From: luoxiao Date: Tue, 16 May 2023 12:54:47 +0800 Subject: [PATCH] =?UTF-8?q?=F0=9F=A6=84=20refactor:=20option=5Fcomp?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/button/mod.rs | 2 +- src/card/mod.rs | 64 ++++++++++++----------------------- src/components/option_comp.rs | 9 +++-- 3 files changed, 27 insertions(+), 48 deletions(-) diff --git a/src/button/mod.rs b/src/button/mod.rs index ef0d0d5..2e846b7 100644 --- a/src/button/mod.rs +++ b/src/button/mod.rs @@ -82,7 +82,7 @@ pub fn Button( } }/> - diff --git a/src/card/mod.rs b/src/card/mod.rs index c02636a..1d35fc5 100644 --- a/src/card/mod.rs +++ b/src/card/mod.rs @@ -1,11 +1,11 @@ -use crate::utils::mount_style::mount_style; +use crate::{components::*, utils::mount_style::mount_style}; use leptos::*; use stylers::style_sheet_str; #[component] pub fn Card( cx: Scope, - #[prop(default = None)] title: Option, + #[prop(optional)] title: MaybeSignal, #[prop(default = None)] header: Option, #[prop(default = None)] header_extra: Option, children: Children, @@ -16,41 +16,25 @@ pub fn Card( cx, class=class_name,
{ - if header.is_some() || title.is_some() { + if header.is_some() || title.get().is_empty() { view! { cx, class=class_name,
- { - if let Some(header) = header { - view! { - cx, - <> - { header(cx) } - - } - } else { - view! { - cx, - <> - { title } - - } - } - } + + { title.get() } +
- { - if let Some(header_extra) = header_extra { - view! { - cx, class=class_name, -
- { header_extra(cx)} -
- }.into() - } else { - None + + { header_extra(cx)} +
} - } + }/>
}.into() } else { @@ -60,18 +44,14 @@ pub fn Card(
{ children(cx) }
- { - if let Some(footer) = footer { - view! { - cx, class=class_name, - - }.into() - } else { - None + + { footer(cx) } + } - } + }/> } } diff --git a/src/components/option_comp.rs b/src/components/option_comp.rs index 1cb261a..9938533 100644 --- a/src/components/option_comp.rs +++ b/src/components/option_comp.rs @@ -1,4 +1,3 @@ -use super::Fallback; use leptos::*; #[component] @@ -6,16 +5,16 @@ pub fn OptionComp( cx: Scope, value: Option, view: VF, - #[prop(optional)] fallback: Option, + #[prop(optional)] children: Option, ) -> impl IntoView where - VF: Fn(Scope, T) -> IV + 'static, + VF: FnOnce(Scope, T) -> IV + 'static, IV: IntoView, { if let Some(value) = value { view(cx, value).into_view(cx) - } else if let Some(fallback) = &fallback { - (fallback.children)(cx).into_view(cx) + } else if let Some(children) = children { + children(cx).into_view(cx) } else { ().into_view(cx) }