mirror of
https://github.com/adoyle0/thaw.git
synced 2025-01-22 22:09:22 -05:00
✨ feat: add button type
This commit is contained in:
parent
12dc04d2e4
commit
c51f220ed0
3 changed files with 29 additions and 22 deletions
|
@ -14,6 +14,9 @@ pub fn DemoButton(cx: Scope) -> impl IntoView {
|
|||
<Button type_=ButtonType::TEXT>
|
||||
"TEXT"
|
||||
</Button>
|
||||
<Button type_=ButtonType::LINK>
|
||||
"LINK"
|
||||
</Button>
|
||||
<Button color=ButtonColor::PRIMARY>
|
||||
"PRIMARY Color"
|
||||
</Button>
|
||||
|
|
|
@ -13,10 +13,16 @@
|
|||
border-color: var(--border-color-hover);
|
||||
}
|
||||
|
||||
.melt-button--text {
|
||||
.melt-button--text,
|
||||
.melt-button--link {
|
||||
border: none;
|
||||
}
|
||||
|
||||
.melt-button--text:hover {
|
||||
color: var(--font-color-hover);
|
||||
background-color: #f2f2f2;
|
||||
}
|
||||
|
||||
.melt-button--link:hover {
|
||||
color: var(--font-color-hover);
|
||||
}
|
|
@ -4,12 +4,13 @@ use leptos::*;
|
|||
use stylers::style_sheet_str;
|
||||
pub use theme::ButtonTheme;
|
||||
|
||||
#[derive(Default, PartialEq, Clone)]
|
||||
#[derive(Default, PartialEq, Clone, Copy)]
|
||||
pub enum ButtonType {
|
||||
#[default]
|
||||
PRIMARY,
|
||||
SOLID,
|
||||
TEXT,
|
||||
LINK,
|
||||
}
|
||||
|
||||
#[derive(Default, Clone)]
|
||||
|
@ -40,14 +41,11 @@ pub fn Button(
|
|||
children: Children,
|
||||
) -> impl IntoView {
|
||||
let theme = use_theme(cx, Theme::light);
|
||||
let css_vars;
|
||||
{
|
||||
let type_ = type_.clone().get();
|
||||
css_vars = create_memo(cx, move |_| {
|
||||
let css_vars = create_memo(cx, move |_| {
|
||||
let mut css_vars = String::new();
|
||||
let theme = theme.get();
|
||||
let bg_color = color.get().theme_color(&theme);
|
||||
if type_ == ButtonType::PRIMARY {
|
||||
if type_.get() == ButtonType::PRIMARY {
|
||||
css_vars.push_str(&format!("--background-color: {bg_color};"));
|
||||
css_vars.push_str(&format!("--font-color: #fff;"));
|
||||
css_vars.push_str(&format!("--border-color: {bg_color};"));
|
||||
|
@ -60,13 +58,13 @@ pub fn Button(
|
|||
|
||||
css_vars
|
||||
});
|
||||
}
|
||||
let class_name = mount_style("button", || style_sheet_str!("./src/button/button.css"));
|
||||
|
||||
view! {cx, class=class_name,
|
||||
<button
|
||||
class:melt-button=true
|
||||
class=("melt-button--text", move || type_.get() == ButtonType::TEXT)
|
||||
class=("melt-button--link", move || type_.get() == ButtonType::LINK)
|
||||
style=move || css_vars.get()
|
||||
>
|
||||
{children(cx)}
|
||||
|
|
Loading…
Add table
Reference in a new issue