libcosmic/src/widget/segmented_button/style.rs

51 lines
1.6 KiB
Rust
Raw Normal View History

// Copyright 2022 System76 <info@system76.com>
2022-12-28 12:42:28 +01:00
// SPDX-License-Identifier: MPL-2.0
2022-12-28 12:42:28 +01:00
use iced_core::{Background, BorderRadius, Color};
/// The appearance of a segmented button.
#[derive(Default, Clone, Copy)]
2022-12-28 12:42:28 +01:00
pub struct Appearance {
pub background: Option<Background>,
pub border_radius: BorderRadius,
pub border_bottom: Option<(f32, Color)>,
pub border_end: Option<(f32, Color)>,
pub border_start: Option<(f32, Color)>,
pub border_top: Option<(f32, Color)>,
pub active: ButtonStatusAppearance,
pub inactive: ButtonStatusAppearance,
pub hover: ButtonStatusAppearance,
pub focus: ButtonStatusAppearance,
2022-12-28 12:42:28 +01:00
}
/// The appearance of a button in the segmented button
#[derive(Default, Clone, Copy)]
2022-12-28 12:42:28 +01:00
pub struct ButtonAppearance {
pub border_radius: BorderRadius,
2022-12-28 12:42:28 +01:00
pub border_bottom: Option<(f32, Color)>,
pub border_end: Option<(f32, Color)>,
pub border_start: Option<(f32, Color)>,
pub border_top: Option<(f32, Color)>,
}
#[derive(Default, Clone, Copy)]
pub struct ButtonStatusAppearance {
pub background: Option<Background>,
pub first: ButtonAppearance,
pub middle: ButtonAppearance,
pub last: ButtonAppearance,
2022-12-28 12:42:28 +01:00
pub text_color: Color,
}
/// Defines the [`Appearance`] of a segmented button.
2022-12-28 12:42:28 +01:00
pub trait StyleSheet {
/// The supported style of the [`StyleSheet`].
type Style: Default;
/// The horizontal [`Appearance`] of the segmented button.
fn horizontal(&self, style: &Self::Style) -> Appearance;
/// The vertical [`Appearance`] of the segmented button.
fn vertical(&self, style: &Self::Style) -> Appearance;
2022-12-28 12:42:28 +01:00
}