summaryrefslogtreecommitdiffstats
path: root/native/src/overlay
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2021-10-28 15:41:12 +0700
committerLibravatar Héctor Ramón Jiménez <hector0193@gmail.com>2021-10-28 15:41:12 +0700
commitfe4dfeafdbc8f427bd351f394d27f606a3843b44 (patch)
tree4ab6cc372315c0f3fda7d06c4a337db59cd64d0f /native/src/overlay
parent687c35e052a1057042fc8ddf4968c3fa35cc6bcf (diff)
downloadiced-fe4dfeafdbc8f427bd351f394d27f606a3843b44.tar.gz
iced-fe4dfeafdbc8f427bd351f394d27f606a3843b44.tar.bz2
iced-fe4dfeafdbc8f427bd351f394d27f606a3843b44.zip
Wire up style to `PickList` and `overlay::Menu`
Diffstat (limited to 'native/src/overlay')
-rw-r--r--native/src/overlay/menu.rs43
1 files changed, 15 insertions, 28 deletions
diff --git a/native/src/overlay/menu.rs b/native/src/overlay/menu.rs
index 0c335bb6..ebb2a4e1 100644
--- a/native/src/overlay/menu.rs
+++ b/native/src/overlay/menu.rs
@@ -5,16 +5,17 @@ use crate::mouse;
use crate::overlay;
use crate::renderer;
use crate::scrollable;
-use crate::text;
use crate::touch;
use crate::{
Clipboard, Container, Element, Hasher, Layout, Length, Padding, Point,
Rectangle, Scrollable, Size, Vector, Widget,
};
+pub use iced_style::menu::Style;
+
/// A list of selectable options.
#[allow(missing_debug_implementations)]
-pub struct Menu<'a, T, Renderer: self::Renderer> {
+pub struct Menu<'a, T, Renderer: renderer::Text> {
state: &'a mut State,
options: &'a [T],
hovered_option: &'a mut Option<usize>,
@@ -23,13 +24,13 @@ pub struct Menu<'a, T, Renderer: self::Renderer> {
padding: Padding,
text_size: Option<u16>,
font: Renderer::Font,
- style: <Renderer as self::Renderer>::Style,
+ style: Style,
}
impl<'a, T, Renderer> Menu<'a, T, Renderer>
where
T: ToString + Clone,
- Renderer: self::Renderer + 'a,
+ Renderer: renderer::Text + 'a,
{
/// Creates a new [`Menu`] with the given [`State`], a list of options, and
/// the message to produced when an option is selected.
@@ -77,10 +78,7 @@ where
}
/// Sets the style of the [`Menu`].
- pub fn style(
- mut self,
- style: impl Into<<Renderer as self::Renderer>::Style>,
- ) -> Self {
+ pub fn style(mut self, style: impl Into<Style>) -> Self {
self.style = style.into();
self
}
@@ -116,14 +114,14 @@ impl State {
}
}
-struct Overlay<'a, Message, Renderer: self::Renderer> {
+struct Overlay<'a, Message, Renderer: renderer::Text> {
container: Container<'a, Message, Renderer>,
width: u16,
target_height: f32,
- style: <Renderer as self::Renderer>::Style,
+ style: Style,
}
-impl<'a, Message, Renderer: self::Renderer> Overlay<'a, Message, Renderer>
+impl<'a, Message, Renderer: renderer::Text> Overlay<'a, Message, Renderer>
where
Message: 'a,
Renderer: 'a,
@@ -168,7 +166,7 @@ where
impl<'a, Message, Renderer> crate::Overlay<Message, Renderer>
for Overlay<'a, Message, Renderer>
where
- Renderer: self::Renderer,
+ Renderer: renderer::Text,
{
fn layout(
&self,
@@ -258,21 +256,21 @@ where
}
}
-struct List<'a, T, Renderer: self::Renderer> {
+struct List<'a, T, Renderer: renderer::Text> {
options: &'a [T],
hovered_option: &'a mut Option<usize>,
last_selection: &'a mut Option<T>,
padding: Padding,
text_size: Option<u16>,
font: Renderer::Font,
- style: <Renderer as self::Renderer>::Style,
+ style: Style,
}
-impl<'a, T, Message, Renderer: self::Renderer> Widget<Message, Renderer>
+impl<'a, T, Message, Renderer> Widget<Message, Renderer>
for List<'a, T, Renderer>
where
T: Clone + ToString,
- Renderer: self::Renderer,
+ Renderer: renderer::Text,
{
fn width(&self) -> Length {
Length::Fill
@@ -389,23 +387,12 @@ where
}
}
-/// The renderer of a [`Menu`].
-///
-/// Your [renderer] will need to implement this trait before being
-/// able to use a [`Menu`] in your user interface.
-///
-/// [renderer]: crate::renderer
-pub trait Renderer: renderer::Text {
- /// The [`Menu`] style supported by this renderer.
- type Style: Default + Clone;
-}
-
impl<'a, T, Message, Renderer> Into<Element<'a, Message, Renderer>>
for List<'a, T, Renderer>
where
T: ToString + Clone,
Message: 'a,
- Renderer: 'a + self::Renderer,
+ Renderer: 'a + renderer::Text,
{
fn into(self) -> Element<'a, Message, Renderer> {
Element::new(self)