diff options
Diffstat (limited to 'crates/material_theme/src')
| -rw-r--r-- | crates/material_theme/src/lib.rs | 1 | ||||
| -rw-r--r-- | crates/material_theme/src/radio.rs | 65 |
2 files changed, 66 insertions, 0 deletions
diff --git a/crates/material_theme/src/lib.rs b/crates/material_theme/src/lib.rs index a68f0ae..cbebdc9 100644 --- a/crates/material_theme/src/lib.rs +++ b/crates/material_theme/src/lib.rs @@ -17,6 +17,7 @@ pub mod pick_list; pub mod progress_bar; #[cfg(feature = "qr_code")] pub mod qr_code; +pub mod radio; pub mod scrollable; #[cfg(feature = "svg")] pub mod svg; diff --git a/crates/material_theme/src/radio.rs b/crates/material_theme/src/radio.rs new file mode 100644 index 0000000..d249413 --- /dev/null +++ b/crates/material_theme/src/radio.rs @@ -0,0 +1,65 @@ +use iced_widget::core::{Background, Color}; +use iced_widget::radio::{Catalog, Status, Style, StyleFn}; + +use super::Theme; +use crate::utils::{DISABLED_TEXT_OPACITY, HOVERED_LAYER_OPACITY, mix}; + +impl Catalog for Theme { + type Class<'a> = StyleFn<'a, Self>; + + fn default<'a>() -> Self::Class<'a> { + Box::new(default) + } + + fn style(&self, class: &Self::Class<'_>, status: Status) -> Style { + class(self, status) + } +} + +pub fn default(theme: &Theme, status: Status) -> Style { + let surface = theme.colorscheme.surface; + let primary = theme.colorscheme.primary; + + let active = Style { + background: Color::TRANSPARENT.into(), + dot_color: primary.color, + border_width: 1.0, + border_color: primary.color, + text_color: None, + }; + + match status { + Status::Active { is_selected } => Style { + border_color: if is_selected { + active.border_color + } else { + surface.on_surface + }, + ..active + }, + Status::Hovered { is_selected } => Style { + dot_color: mix( + primary.color, + surface.on_surface, + HOVERED_LAYER_OPACITY, + ), + border_color: if is_selected { + mix(primary.color, surface.on_surface, HOVERED_LAYER_OPACITY) + } else { + Color { + a: DISABLED_TEXT_OPACITY, + ..surface.on_surface + } + }, + background: Background::Color(if is_selected { + Color { + a: HOVERED_LAYER_OPACITY, + ..surface.on_surface + } + } else { + Color::TRANSPARENT + }), + ..active + }, + } +} |
