-
Notifications
You must be signed in to change notification settings - Fork 16
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'main' into 830-docs-number-field
- Loading branch information
Showing
36 changed files
with
2,912 additions
and
48 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,121 @@ | ||
# Button Group | ||
|
||
A button group is a UI component that groups buttons with related actions together and will automatically handle layout overflow nicely. Only buttons can be used within button groups. | ||
|
||
## Example | ||
|
||
```python | ||
from deephaven import ui | ||
|
||
|
||
my_button_group_basic = ui.button_group( | ||
ui.button("Rate Now", variant="accent"), | ||
ui.button("No, thanks", variant="primary", style="outline"), | ||
ui.button("Remind me later", variant="primary", style="outline"), | ||
) | ||
``` | ||
|
||
## UI Recommendations | ||
|
||
Recommendations for creating button groups: | ||
|
||
1. The most critical action in a button group should use an accent, or negative button style, while other actions should be primary outline buttons. | ||
2. Button groups should be left-aligned to follow content such as blocks of text, center-aligned in empty states, and right-aligned in container components like dialogs, popovers, or cards. | ||
3. Button priority should match text alignment: for left-aligned text, the most critical button is on the left; for right- or center-aligned text, the most critical button is on the right. | ||
4. Icons should be used for higher-priority actions if used in the button group. If the most critical action does not have an icon, avoid using icons for the other lower-priority actions. | ||
|
||
Consider using an [`action_group`](./action_group.md) to allow the user to select from a list of actions. | ||
|
||
|
||
## Content | ||
|
||
A button group is used to handle button overflow and, thus, expects buttons as children. It switches to a vertical layout when horizontal space is limited. | ||
|
||
```python | ||
from deephaven import ui | ||
|
||
|
||
my_button_group_content_space_example = ui.view( | ||
ui.button_group( | ||
ui.button("Rate Now", variant="accent", style="outline"), | ||
ui.button("Remind me later", variant="primary", style="outline"), | ||
ui.button("No, thanks", variant="primary", style="outline"), | ||
), | ||
width=200, | ||
border_width="thin", | ||
padding="size-100", | ||
) | ||
``` | ||
|
||
|
||
## Orientation | ||
|
||
Setting the `orientation` prop to "vertical" will prevent any spacing-related dynamic orientation changes. | ||
|
||
The button group will remain in the orientation regardless of the width. | ||
|
||
```python | ||
from deephaven import ui | ||
|
||
|
||
my_button_group_orientation_example = ui.button_group( | ||
ui.button("No, thanks", variant="primary", style="outline"), | ||
ui.button("Remind me later", variant="primary", style="outline"), | ||
ui.button("Rate Now", variant="accent"), | ||
orientation="vertical", | ||
) | ||
``` | ||
|
||
|
||
## Alignment | ||
|
||
By default, button groups are start-aligned to accord with content, but they can be set to have a different alignment using the `alignment` prop. | ||
|
||
```python | ||
from deephaven import ui | ||
|
||
|
||
@ui.component | ||
def ui_button_group_alignment_examples(): | ||
return [ | ||
ui.button_group( | ||
ui.button("No, thanks", variant="primary", style="outline"), | ||
ui.button("Remind me later", variant="primary", style="outline"), | ||
ui.button("Rate Now", variant="accent"), | ||
align="center", | ||
), | ||
ui.button_group( | ||
ui.button("No, thanks", variant="primary", style="outline"), | ||
ui.button("Remind me later", variant="primary", style="outline"), | ||
ui.button("Rate Now", variant="accent"), | ||
align="end", | ||
), | ||
] | ||
|
||
|
||
my_button_group_alignment_examples = ui_button_group_alignment_examples() | ||
``` | ||
|
||
|
||
## Disabled state | ||
|
||
The `is_disabled` prop disables the button group to prevent user interaction. This is useful when the button group should be visible but not available for selection. | ||
|
||
|
||
```python | ||
from deephaven import ui | ||
|
||
|
||
my_button_group_is_disabled_example = ui.button_group( | ||
ui.button("No, thanks", variant="primary", style="outline"), | ||
ui.button("Remind me later", variant="primary", style="outline"), | ||
ui.button("Rate Now", variant="accent"), | ||
is_disabled=True, | ||
) | ||
``` | ||
|
||
## API Reference | ||
|
||
```{eval-rst} | ||
.. dhautofunction:: deephaven.ui.button_group | ||
``` |
Oops, something went wrong.