* wip: update to use cosmic-advanced-text * use cosmic-advanced-text branch of iced * fix: line height and spacing for segmented button and update to get svg fix * fix: spin button styling & spacing * update iced to fix segmented button border radius * feat: example improvements * feat: helper for loading fonts * feat: add focus style to button * fix: slider height and iced fixed * feat: hash icon width and height * cleanup * update ci * refactor: always use lazy feature of iced * update iced * update iced * cleanup & update iced * update iced: new slider & tiny-skia quad updates * update iced: fixes for tiny-skia quad rendering with edge case border radius * re-export iced_runtime & iced_widget * merge master * udpate iced * update iced * update iced * update iced * fix: make rectangle_tracker subscription only return update if there is some * feat: derive macro for loading a cosmic-config * feat (cosmic-config): iced subscription * fix (example): update to rectangle tracker subscription * fix (cosmic-config) * refactor(cosmic-config-derive): add support for types with generic parameters * fix (cosmic-config): feature gate updates for subscription helpers * feat: support for custom & system themes + move cosmic-theme to libcosmic * feat: sorta hacky way of creating header bars for libcosmic + update iced to get support for resizable windows in iced-sctk * update iced * update and reexport sctk * fix: applet border radius * feat (cosmic-theme): add id and name methods * fix(cosmic-theme): reexport palette from cosmic-theme * fix(cosmic-config-derive): allow use with reexported cosmic-config * feat: update iced with fix and refactor applet env vars * update iced
49 lines
1.7 KiB
Rust
49 lines
1.7 KiB
Rust
// Copyright 2023 System76 <info@system76.com>
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
|
|
//! A selection of multiple choices appearing as a conjoined button.
|
|
//!
|
|
//! See the [`segmented_button`] module for more details.
|
|
|
|
use super::segmented_button::{
|
|
self, HorizontalSegmentedButton, Model, Selectable, VerticalSegmentedButton,
|
|
};
|
|
|
|
/// A selection of multiple choices appearing as a conjoined button.
|
|
///
|
|
/// The data for the widget comes from a model that is maintained the application.
|
|
///
|
|
/// For details on the model, see the [`segmented_button`] module for more details.
|
|
#[must_use]
|
|
pub fn horizontal<SelectionMode: Default, Message>(
|
|
model: &Model<SelectionMode>,
|
|
) -> HorizontalSegmentedButton<SelectionMode, Message, crate::Renderer>
|
|
where
|
|
Model<SelectionMode>: Selectable,
|
|
{
|
|
segmented_button::horizontal(model)
|
|
.button_padding([16, 0, 16, 0])
|
|
.button_height(32)
|
|
.style(crate::theme::SegmentedButton::Selection)
|
|
.font_active(Some(crate::font::FONT_SEMIBOLD))
|
|
}
|
|
|
|
/// A selection of multiple choices appearing as a conjoined button.
|
|
///
|
|
/// The data for the widget comes from a model that is maintained the application.
|
|
///
|
|
/// For details on the model, see the [`segmented_button`] module for more details.
|
|
#[must_use]
|
|
pub fn vertical<SelectionMode, Message>(
|
|
model: &Model<SelectionMode>,
|
|
) -> VerticalSegmentedButton<SelectionMode, Message, crate::Renderer>
|
|
where
|
|
Model<SelectionMode>: Selectable,
|
|
SelectionMode: Default,
|
|
{
|
|
segmented_button::vertical(model)
|
|
.button_padding([16, 0, 16, 0])
|
|
.button_height(32)
|
|
.style(crate::theme::SegmentedButton::Selection)
|
|
.font_active(Some(crate::font::FONT_SEMIBOLD))
|
|
}
|