From 7a50e9e8fbb8d37e53a42c1dd5936b97463ead53 Mon Sep 17 00:00:00 2001 From: Héctor Ramón Jiménez Date: Sun, 21 Jan 2024 17:56:01 +0100 Subject: Convert `Renderer::Theme` to generic `Widget` type --- widget/src/keyed/column.rs | 36 +++++++++++++++++++++++------------- 1 file changed, 23 insertions(+), 13 deletions(-) (limited to 'widget/src/keyed') diff --git a/widget/src/keyed/column.rs b/widget/src/keyed/column.rs index 7f05a81e..6203d2c5 100644 --- a/widget/src/keyed/column.rs +++ b/widget/src/keyed/column.rs @@ -13,8 +13,13 @@ use crate::core::{ /// A container that distributes its contents vertically. #[allow(missing_debug_implementations)] -pub struct Column<'a, Key, Message, Renderer = crate::Renderer> -where +pub struct Column< + 'a, + Key, + Message, + Theme = crate::Theme, + Renderer = crate::Renderer, +> where Key: Copy + PartialEq, { spacing: f32, @@ -24,10 +29,11 @@ where max_width: f32, align_items: Alignment, keys: Vec, - children: Vec>, + children: Vec>, } -impl<'a, Key, Message, Renderer> Column<'a, Key, Message, Renderer> +impl<'a, Key, Message, Theme, Renderer> + Column<'a, Key, Message, Theme, Renderer> where Key: Copy + PartialEq, Renderer: crate::core::Renderer, @@ -48,7 +54,9 @@ where /// Creates a [`Column`] with the given elements. pub fn with_children( - children: impl IntoIterator)>, + children: impl IntoIterator< + Item = (Key, Element<'a, Message, Theme, Renderer>), + >, ) -> Self { children .into_iter() @@ -99,7 +107,7 @@ where pub fn push( mut self, key: Key, - child: impl Into>, + child: impl Into>, ) -> Self { let child = child.into(); let size = child.as_widget().size_hint(); @@ -135,8 +143,8 @@ where keys: Vec, } -impl<'a, Key, Message, Renderer> Widget - for Column<'a, Key, Message, Renderer> +impl<'a, Key, Message, Theme, Renderer> Widget + for Column<'a, Key, Message, Theme, Renderer> where Renderer: crate::core::Renderer, Key: Copy + PartialEq + 'static, @@ -285,7 +293,7 @@ where &self, tree: &Tree, renderer: &mut Renderer, - theme: &Renderer::Theme, + theme: &Theme, style: &renderer::Style, layout: Layout<'_>, cursor: mouse::Cursor, @@ -308,19 +316,21 @@ where tree: &'b mut Tree, layout: Layout<'_>, renderer: &Renderer, - ) -> Option> { + ) -> Option> { overlay::from_children(&mut self.children, tree, layout, renderer) } } -impl<'a, Key, Message, Renderer> From> - for Element<'a, Message, Renderer> +impl<'a, Key, Message, Theme, Renderer> + From> + for Element<'a, Message, Theme, Renderer> where Key: Copy + PartialEq + 'static, Message: 'a, + Theme: 'a, Renderer: crate::core::Renderer + 'a, { - fn from(column: Column<'a, Key, Message, Renderer>) -> Self { + fn from(column: Column<'a, Key, Message, Theme, Renderer>) -> Self { Self::new(column) } } -- cgit