2024-01-03 20:52:56 +08:00
|
|
|
# Button
|
|
|
|
|
|
|
|
```rust demo
|
|
|
|
view! {
|
|
|
|
<Space>
|
|
|
|
<Button variant=ButtonVariant::Primary>"Primary"</Button>
|
2024-01-29 16:18:01 +08:00
|
|
|
<Button variant=ButtonVariant::Outlined>"Outlined"</Button>
|
2024-01-03 20:52:56 +08:00
|
|
|
<Button variant=ButtonVariant::Text>"Text"</Button>
|
|
|
|
<Button variant=ButtonVariant::Link>"Link"</Button>
|
|
|
|
</Space>
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### Color
|
|
|
|
|
|
|
|
```rust demo
|
|
|
|
view! {
|
|
|
|
<Space>
|
|
|
|
<Button color=ButtonColor::Primary>"Primary Color"</Button>
|
|
|
|
<Button color=ButtonColor::Success>"Success Color"</Button>
|
|
|
|
<Button color=ButtonColor::Warning>"Warning Color"</Button>
|
|
|
|
<Button color=ButtonColor::Error>"Error Color"</Button>
|
|
|
|
</Space>
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### Icon
|
|
|
|
|
|
|
|
```rust demo
|
|
|
|
view! {
|
|
|
|
<Space>
|
2024-01-26 23:10:17 +09:00
|
|
|
<Button color=ButtonColor::Error icon=icondata::AiCloseOutlined>
|
2024-01-03 20:52:56 +08:00
|
|
|
"Error Color Icon"
|
|
|
|
</Button>
|
|
|
|
<Button
|
|
|
|
color=ButtonColor::Error
|
2024-01-26 23:10:17 +09:00
|
|
|
icon=icondata::AiCloseOutlined
|
2024-01-03 20:52:56 +08:00
|
|
|
round=true
|
|
|
|
/>
|
|
|
|
<Button
|
|
|
|
color=ButtonColor::Error
|
2024-01-26 23:10:17 +09:00
|
|
|
icon=icondata::AiCloseOutlined
|
2024-01-03 20:52:56 +08:00
|
|
|
circle=true
|
|
|
|
/>
|
|
|
|
</Space>
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### Loading
|
|
|
|
|
|
|
|
```rust demo
|
|
|
|
let loading = create_rw_signal(false);
|
|
|
|
let on_click = move |_| {
|
|
|
|
loading.set(true);
|
|
|
|
set_timeout(
|
|
|
|
move || {
|
|
|
|
loading.set(false);
|
|
|
|
},
|
|
|
|
std::time::Duration::new(2, 0),
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
view! {
|
|
|
|
<Space>
|
2024-01-26 23:10:17 +09:00
|
|
|
<Button loading on_click icon=icondata::AiCloseOutlined>
|
2024-01-03 20:52:56 +08:00
|
|
|
"Click Me"
|
|
|
|
</Button>
|
|
|
|
<Button loading on_click>
|
|
|
|
"Click Me"
|
|
|
|
</Button>
|
|
|
|
</Space>
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### Disabled
|
|
|
|
|
|
|
|
```rust demo
|
|
|
|
view! {
|
|
|
|
<Space>
|
|
|
|
<Button variant=ButtonVariant::Primary disabled=true>
|
|
|
|
"Primary"
|
|
|
|
</Button>
|
2024-01-29 16:18:01 +08:00
|
|
|
<Button variant=ButtonVariant::Outlined disabled=true>
|
|
|
|
"Outlined"
|
2024-01-03 20:52:56 +08:00
|
|
|
</Button>
|
|
|
|
<Button variant=ButtonVariant::Text disabled=true>
|
|
|
|
"Text"
|
|
|
|
</Button>
|
|
|
|
<Button variant=ButtonVariant::Link disabled=true>
|
|
|
|
"Link"
|
|
|
|
</Button>
|
|
|
|
</Space>
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### Size
|
|
|
|
|
|
|
|
```rust demo
|
|
|
|
view! {
|
|
|
|
<Space>
|
|
|
|
<Button size=ButtonSize::Tiny>"Primary"</Button>
|
|
|
|
<Button size=ButtonSize::Small>"Primary"</Button>
|
|
|
|
<Button size=ButtonSize::Medium>"Primary"</Button>
|
|
|
|
<Button size=ButtonSize::Large>"Primary"</Button>
|
|
|
|
</Space>
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### Group
|
|
|
|
|
|
|
|
```rust demo
|
|
|
|
view! {
|
|
|
|
<Space>
|
|
|
|
<ButtonGroup>
|
2024-01-29 16:18:01 +08:00
|
|
|
<Button variant=ButtonVariant::Outlined>"Outlined"</Button>
|
|
|
|
<Button variant=ButtonVariant::Outlined>"Outlined"</Button>
|
|
|
|
<Button variant=ButtonVariant::Outlined>"Outlined"</Button>
|
2024-01-03 20:52:56 +08:00
|
|
|
</ButtonGroup>
|
|
|
|
<ButtonGroup vertical=true>
|
2024-01-29 16:18:01 +08:00
|
|
|
<Button variant=ButtonVariant::Outlined>"Outlined"</Button>
|
|
|
|
<Button variant=ButtonVariant::Outlined>"Outlined"</Button>
|
|
|
|
<Button variant=ButtonVariant::Outlined>"Outlined"</Button>
|
2024-01-03 20:52:56 +08:00
|
|
|
</ButtonGroup>
|
|
|
|
</Space>
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
### Button Props
|
|
|
|
|
|
|
|
| Name | Type | Default | Description |
|
|
|
|
| --- | --- | --- | --- |
|
2024-02-09 22:44:22 +08:00
|
|
|
| class | `OptionalProp<MaybeSignal<String>>` | `Default::default()` | Additional classes for the button element. |
|
|
|
|
| style | `Option<MaybeSignal<String>>` | `Default::default()` | Button's style. |
|
2024-01-03 20:52:56 +08:00
|
|
|
| variant | `MaybeSignal<ButtonVariant>` | `ButtonVariant::Primary` | Button's variant. |
|
|
|
|
| color | `MaybeSignal<ButtonColor>` | `ButtonColor::Primary` | Button's color. |
|
|
|
|
| round | `MaybeSignal<bool>` | `false` | Whether the button shows rounded corners. |
|
|
|
|
| circle | `MaybeSignal<bool>` | `false` | Whether the button is round. |
|
|
|
|
| icon | `Option<Icon>` | `None` | The icon of the button. |
|
|
|
|
| loading | `MaybeSignal<bool>` | `false` | Whether the button shows the loading status. |
|
|
|
|
| disabled | `MaybeSignal<bool>` | `false` | Whether the button is disabled. |
|
|
|
|
| size | `MaybeSignal<ButtonSize>` | `ButtonSize::Medium` | Button size. |
|
|
|
|
| on_click | `Option<Callback<ev::MouseEvent>>` | `None` | Listen for button click events. |
|
2024-02-09 22:44:22 +08:00
|
|
|
| children | `Option<Children>` | | Button's content. |
|
|
|
|
|
|
|
|
### ButtonGroup props
|
|
|
|
|
|
|
|
| Name | Type | Default | Description |
|
|
|
|
| -------- | ---------- | ------- | ----------------------------------- |
|
|
|
|
| vertical | `bool` | `false` | Directions of buttons in the group. |
|
|
|
|
| children | `Children` | | ButtonGroup's content. |
|