diff --git a/style/src/theme.rs b/style/src/theme.rs index 8d1ff23779..77a6a2e756 100644 --- a/style/src/theme.rs +++ b/style/src/theme.rs @@ -721,13 +721,15 @@ impl toggler::StyleSheet for Theme { } else { palette.background.strong.color }, - background_border: None, + background_border_width: 0.0, + background_border_color: Color::TRANSPARENT, foreground: if is_active { palette.primary.strong.text } else { palette.background.base.color }, - foreground_border: None, + foreground_border_width: 0.0, + foreground_border_color: Color::TRANSPARENT, } } Toggler::Custom(custom) => custom.active(self, is_active), diff --git a/style/src/toggler.rs b/style/src/toggler.rs index abc73f2a25..731e87ceb8 100644 --- a/style/src/toggler.rs +++ b/style/src/toggler.rs @@ -6,12 +6,16 @@ use iced_core::Color; pub struct Appearance { /// The background [`Color`] of the toggler. pub background: Color, + /// The width of the background border of the toggler. + pub background_border_width: f32, /// The [`Color`] of the background border of the toggler. - pub background_border: Option, + pub background_border_color: Color, /// The foreground [`Color`] of the toggler. pub foreground: Color, + /// The width of the foreground border of the toggler. + pub foreground_border_width: f32, /// The [`Color`] of the foreground border of the toggler. - pub foreground_border: Option, + pub foreground_border_color: Color, } /// A set of rules that dictate the style of a toggler. diff --git a/widget/src/toggler.rs b/widget/src/toggler.rs index 1d313df3ba..4e3925bad5 100644 --- a/widget/src/toggler.rs +++ b/widget/src/toggler.rs @@ -315,8 +315,8 @@ where bounds: toggler_background_bounds, border: Border { radius: border_radius.into(), - width: 1.0, - color: style.background_border.unwrap_or(style.background), + width: style.background_border_width, + color: style.background_border_color, }, ..renderer::Quad::default() }, @@ -340,8 +340,8 @@ where bounds: toggler_foreground_bounds, border: Border { radius: border_radius.into(), - width: 1.0, - color: style.foreground_border.unwrap_or(style.foreground), + width: style.foreground_border_width, + color: style.foreground_border_color, }, ..renderer::Quad::default() },