summaryrefslogtreecommitdiffstats
path: root/widget
diff options
context:
space:
mode:
Diffstat (limited to 'widget')
-rw-r--r--widget/src/combo_box.rs20
-rw-r--r--widget/src/overlay/menu.rs75
-rw-r--r--widget/src/pick_list.rs41
3 files changed, 41 insertions, 95 deletions
diff --git a/widget/src/combo_box.rs b/widget/src/combo_box.rs
index 95667882..ee24d742 100644
--- a/widget/src/combo_box.rs
+++ b/widget/src/combo_box.rs
@@ -42,7 +42,7 @@ pub struct ComboBox<
on_option_hovered: Option<Box<dyn Fn(T) -> Message>>,
on_close: Option<Message>,
on_input: Option<Box<dyn Fn(String) -> Message>>,
- menu_style: menu::Style<Theme>,
+ menu_style: menu::Style<'a, Theme>,
padding: Padding,
size: Option<f32>,
}
@@ -125,7 +125,7 @@ where
}
/// Sets the style of the [`ComboBox`].
- pub fn style(mut self, style: impl Into<Style<Theme>>) -> Self
+ pub fn style(mut self, style: impl Into<Style<'a, Theme>>) -> Self
where
Theme: 'a,
{
@@ -672,7 +672,7 @@ where
self.state.sync_filtered_options(filtered_options);
- let mut menu = menu::Menu::with_style(
+ let mut menu = menu::Menu::new(
menu,
&filtered_options.options,
hovered_option,
@@ -686,7 +686,7 @@ where
(self.on_selected)(x)
},
self.on_option_hovered.as_deref(),
- self.menu_style,
+ &self.menu_style,
)
.width(bounds.width)
.padding(self.padding);
@@ -765,27 +765,27 @@ where
/// The style of a [`ComboBox`].
#[allow(missing_debug_implementations)]
-pub struct Style<Theme> {
+pub struct Style<'a, Theme> {
/// The style of the [`TextInput`] of the [`ComboBox`].
- pub text_input: text_input::Style<'static, Theme>,
+ pub text_input: text_input::Style<'a, Theme>,
/// The style of the [`Menu`] of the [`ComboBox`].
///
/// [`Menu`]: menu::Menu
- pub menu: menu::Style<Theme>,
+ pub menu: menu::Style<'a, Theme>,
}
/// The default style of a [`ComboBox`].
pub trait DefaultStyle: Sized {
/// Returns the default style of a [`ComboBox`].
- fn default_style() -> Style<Self>;
+ fn default_style() -> Style<'static, Self>;
}
impl DefaultStyle for Theme {
- fn default_style() -> Style<Self> {
+ fn default_style() -> Style<'static, Self> {
Style {
text_input: Box::new(text_input::default),
- menu: menu::Style::DEFAULT,
+ menu: menu::DefaultStyle::default_style(),
}
}
}
diff --git a/widget/src/overlay/menu.rs b/widget/src/overlay/menu.rs
index 746407c6..0364f980 100644
--- a/widget/src/overlay/menu.rs
+++ b/widget/src/overlay/menu.rs
@@ -38,7 +38,7 @@ pub struct Menu<
text_line_height: text::LineHeight,
text_shaping: text::Shaping,
font: Option<Renderer::Font>,
- style: Style<Theme>,
+ style: &'a Style<'a, Theme>,
}
impl<'a, T, Message, Theme, Renderer> Menu<'a, T, Message, Theme, Renderer>
@@ -48,37 +48,15 @@ where
Theme: 'a,
Renderer: text::Renderer + 'a,
{
- /// Creates a new [`Menu`] with the given [`State`], a list of options, and
- /// the message to produced when an option is selected.
- pub fn new(
- state: &'a mut State,
- options: &'a [T],
- hovered_option: &'a mut Option<usize>,
- on_selected: impl FnMut(T) -> Message + 'a,
- on_option_hovered: Option<&'a dyn Fn(T) -> Message>,
- ) -> Self
- where
- Theme: DefaultStyle,
- {
- Self::with_style(
- state,
- options,
- hovered_option,
- on_selected,
- on_option_hovered,
- Theme::default_style(),
- )
- }
-
/// Creates a new [`Menu`] with the given [`State`], a list of options,
/// the message to produced when an option is selected, and its [`Style`].
- pub fn with_style(
+ pub fn new(
state: &'a mut State,
options: &'a [T],
hovered_option: &'a mut Option<usize>,
on_selected: impl FnMut(T) -> Message + 'a,
on_option_hovered: Option<&'a dyn Fn(T) -> Message>,
- style: Style<Theme>,
+ style: &'a Style<'a, Theme>,
) -> Self {
Menu {
state,
@@ -135,12 +113,6 @@ where
self
}
- /// Sets the style of the [`Menu`].
- pub fn style(mut self, style: impl Into<Style<Theme>>) -> Self {
- self.style = style.into();
- self
- }
-
/// Turns the [`Menu`] into an overlay [`Element`] at the given target
/// position.
///
@@ -190,7 +162,7 @@ where
container: Container<'a, Message, Theme, Renderer>,
width: f32,
target_height: f32,
- style: Style<Theme>,
+ style: &'a Style<'a, Theme>,
}
impl<'a, Message, Theme, Renderer> Overlay<'a, Message, Theme, Renderer>
@@ -234,10 +206,10 @@ where
text_line_height,
text_shaping,
padding,
- style: style.list,
+ style: &style.list,
},
scrollable::Direction::default(),
- style.scrollable,
+ &style.scrollable,
),
container::transparent,
);
@@ -356,7 +328,7 @@ where
text_line_height: text::LineHeight,
text_shaping: text::Shaping,
font: Option<Renderer::Font>,
- style: fn(&Theme) -> Appearance,
+ style: &'a dyn Fn(&Theme) -> Appearance,
}
impl<'a, T, Message, Theme, Renderer> Widget<Message, Theme, Renderer>
@@ -599,39 +571,26 @@ pub struct Appearance {
}
/// The style of the different parts of a [`Menu`].
-#[derive(Debug, PartialEq, Eq)]
-pub struct Style<Theme> {
+#[allow(missing_debug_implementations)]
+pub struct Style<'a, Theme> {
/// The style of the list of the [`Menu`].
- pub list: fn(&Theme) -> Appearance,
+ pub list: Box<dyn Fn(&Theme) -> Appearance + 'a>,
/// The style of the [`Scrollable`] of the [`Menu`].
- pub scrollable: fn(&Theme, scrollable::Status) -> scrollable::Appearance,
+ pub scrollable: scrollable::Style<'a, Theme>,
}
-impl Style<Theme> {
- /// The default style of a [`Menu`] with the built-in [`Theme`].
- pub const DEFAULT: Self = Self {
- list: default,
- scrollable: scrollable::default,
- };
-}
-
-impl<Theme> Clone for Style<Theme> {
- fn clone(&self) -> Self {
- *self
- }
-}
-
-impl<Theme> Copy for Style<Theme> {}
-
/// The default style of a [`Menu`].
pub trait DefaultStyle: Sized {
/// Returns the default style of a [`Menu`].
- fn default_style() -> Style<Self>;
+ fn default_style() -> Style<'static, Self>;
}
impl DefaultStyle for Theme {
- fn default_style() -> Style<Self> {
- Style::<Theme>::DEFAULT
+ fn default_style() -> Style<'static, Self> {
+ Style {
+ list: Box::new(default),
+ scrollable: Box::new(scrollable::default),
+ }
}
}
diff --git a/widget/src/pick_list.rs b/widget/src/pick_list.rs
index beb4e0c1..52d54397 100644
--- a/widget/src/pick_list.rs
+++ b/widget/src/pick_list.rs
@@ -47,7 +47,7 @@ pub struct PickList<
text_shaping: text::Shaping,
font: Option<Renderer::Font>,
handle: Handle<Renderer::Font>,
- style: Style<Theme>,
+ style: Style<'a, Theme>,
}
impl<'a, T, L, V, Message, Theme, Renderer>
@@ -151,7 +151,7 @@ where
}
/// Sets the style of the [`PickList`].
- pub fn style(mut self, style: impl Into<Style<Theme>>) -> Self {
+ pub fn style(mut self, style: impl Into<Style<'a, Theme>>) -> Self {
self.style = style.into();
self
}
@@ -529,7 +529,7 @@ where
let on_select = &self.on_select;
- let mut menu = Menu::with_style(
+ let mut menu = Menu::new(
&mut state.menu,
self.options.borrow(),
&mut state.hovered_option,
@@ -539,7 +539,7 @@ where
(on_select)(option)
},
None,
- self.style.menu,
+ &self.style.menu,
)
.width(bounds.width)
.padding(self.padding)
@@ -676,40 +676,27 @@ pub struct Appearance {
}
/// The styles of the different parts of a [`PickList`].
-#[derive(Debug, PartialEq, Eq)]
-pub struct Style<Theme> {
+#[allow(missing_debug_implementations)]
+pub struct Style<'a, Theme> {
/// The style of the [`PickList`] itself.
- pub field: fn(&Theme, Status) -> Appearance,
+ pub field: Box<dyn Fn(&Theme, Status) -> Appearance + 'a>,
/// The style of the [`Menu`] of the pick list.
- pub menu: menu::Style<Theme>,
+ pub menu: menu::Style<'a, Theme>,
}
-impl Style<Theme> {
- /// The default style of a [`PickList`] with the built-in [`Theme`].
- pub const DEFAULT: Self = Self {
- field: default,
- menu: menu::Style::<Theme>::DEFAULT,
- };
-}
-
-impl<Theme> Clone for Style<Theme> {
- fn clone(&self) -> Self {
- *self
- }
-}
-
-impl<Theme> Copy for Style<Theme> {}
-
/// The default style of a [`PickList`].
pub trait DefaultStyle: Sized {
/// Returns the default style of a [`PickList`].
- fn default_style() -> Style<Self>;
+ fn default_style() -> Style<'static, Self>;
}
impl DefaultStyle for Theme {
- fn default_style() -> Style<Self> {
- Style::<Self>::DEFAULT
+ fn default_style() -> Style<'static, Self> {
+ Style {
+ field: Box::new(default),
+ menu: menu::DefaultStyle::default_style(),
+ }
}
}