iced-yoda/style/src/checkbox.rs

58 lines
1.4 KiB
Rust
Raw Normal View History

2020-01-07 02:54:54 +01:00
//! Show toggle controls using checkboxes.
use iced_core::{Background, Color};
/// The appearance of a checkbox.
#[derive(Debug, Clone, Copy)]
2020-01-07 02:54:54 +01:00
pub struct Style {
pub background: Background,
pub checkmark_color: Color,
pub border_radius: f32,
pub border_width: f32,
2020-01-07 02:54:54 +01:00
pub border_color: Color,
pub text_color: Option<Color>,
2020-01-07 02:54:54 +01:00
}
/// A set of rules that dictate the style of a checkbox.
pub trait StyleSheet {
fn active(&self, is_checked: bool) -> Style;
2020-01-07 02:54:54 +01:00
fn hovered(&self, is_checked: bool) -> Style;
2020-01-07 02:54:54 +01:00
}
struct Default;
impl StyleSheet for Default {
fn active(&self, _is_checked: bool) -> Style {
2020-01-07 02:54:54 +01:00
Style {
background: Background::Color(Color::from_rgb(0.95, 0.95, 0.95)),
checkmark_color: Color::from_rgb(0.3, 0.3, 0.3),
border_radius: 5.0,
border_width: 1.0,
2020-01-07 02:54:54 +01:00
border_color: Color::from_rgb(0.6, 0.6, 0.6),
text_color: None,
2020-01-07 02:54:54 +01:00
}
}
fn hovered(&self, is_checked: bool) -> Style {
2020-01-07 02:54:54 +01:00
Style {
background: Background::Color(Color::from_rgb(0.90, 0.90, 0.90)),
..self.active(is_checked)
2020-01-07 02:54:54 +01:00
}
}
}
impl<'a> std::default::Default for Box<dyn StyleSheet + 'a> {
2020-01-07 02:54:54 +01:00
fn default() -> Self {
Box::new(Default)
}
}
impl<'a, T> From<T> for Box<dyn StyleSheet + 'a>
where
T: StyleSheet + 'a,
{
fn from(style_sheet: T) -> Self {
Box::new(style_sheet)
2020-01-07 02:54:54 +01:00
}
}