summaryrefslogtreecommitdiffstats
path: root/native/src/widget/pane_grid
diff options
context:
space:
mode:
Diffstat (limited to 'native/src/widget/pane_grid')
-rw-r--r--native/src/widget/pane_grid/content.rs84
-rw-r--r--native/src/widget/pane_grid/state.rs8
-rw-r--r--native/src/widget/pane_grid/title_bar.rs92
3 files changed, 142 insertions, 42 deletions
diff --git a/native/src/widget/pane_grid/content.rs b/native/src/widget/pane_grid/content.rs
index 4c9e65c9..98ce2c4b 100644
--- a/native/src/widget/pane_grid/content.rs
+++ b/native/src/widget/pane_grid/content.rs
@@ -5,6 +5,7 @@ use crate::overlay;
use crate::renderer;
use crate::widget::container;
use crate::widget::pane_grid::{Draggable, TitleBar};
+use crate::widget::Tree;
use crate::{Clipboard, Element, Layout, Point, Rectangle, Shell, Size};
/// The content of a [`Pane`].
@@ -59,11 +60,37 @@ where
Renderer: crate::Renderer,
Renderer::Theme: container::StyleSheet,
{
+ pub(super) fn state(&self) -> Tree {
+ let children = if let Some(title_bar) = self.title_bar.as_ref() {
+ vec![Tree::new(&self.body), title_bar.state()]
+ } else {
+ vec![Tree::new(&self.body), Tree::empty()]
+ };
+
+ Tree {
+ children,
+ ..Tree::empty()
+ }
+ }
+
+ pub(super) fn diff(&self, tree: &mut Tree) {
+ if tree.children.len() == 2 {
+ if let Some(title_bar) = self.title_bar.as_ref() {
+ title_bar.diff(&mut tree.children[1]);
+ }
+
+ tree.children[0].diff(&self.body);
+ } else {
+ *tree = self.state();
+ }
+ }
+
/// Draws the [`Content`] with the provided [`Renderer`] and [`Layout`].
///
- /// [`Renderer`]: crate::Renderer
+ /// [`Renderer`]: iced_native::Renderer
pub fn draw(
&self,
+ tree: &Tree,
renderer: &mut Renderer,
theme: &Renderer::Theme,
style: &renderer::Style,
@@ -89,6 +116,7 @@ where
let show_controls = bounds.contains(cursor_position);
title_bar.draw(
+ &tree.children[1],
renderer,
theme,
style,
@@ -98,7 +126,8 @@ where
show_controls,
);
- self.body.draw(
+ self.body.as_widget().draw(
+ &tree.children[0],
renderer,
theme,
style,
@@ -107,7 +136,8 @@ where
viewport,
);
} else {
- self.body.draw(
+ self.body.as_widget().draw(
+ &tree.children[0],
renderer,
theme,
style,
@@ -131,7 +161,7 @@ where
let title_bar_size = title_bar_layout.size();
- let mut body_layout = self.body.layout(
+ let mut body_layout = self.body.as_widget().layout(
renderer,
&layout::Limits::new(
Size::ZERO,
@@ -149,12 +179,13 @@ where
vec![title_bar_layout, body_layout],
)
} else {
- self.body.layout(renderer, limits)
+ self.body.as_widget().layout(renderer, limits)
}
}
pub(crate) fn on_event(
&mut self,
+ tree: &mut Tree,
event: Event,
layout: Layout<'_>,
cursor_position: Point,
@@ -169,6 +200,7 @@ where
let mut children = layout.children();
event_status = title_bar.on_event(
+ &mut tree.children[1],
event.clone(),
children.next().unwrap(),
cursor_position,
@@ -185,7 +217,8 @@ where
let body_status = if is_picked {
event::Status::Ignored
} else {
- self.body.on_event(
+ self.body.as_widget_mut().on_event(
+ &mut tree.children[0],
event,
body_layout,
cursor_position,
@@ -200,6 +233,7 @@ where
pub(crate) fn mouse_interaction(
&self,
+ tree: &Tree,
layout: Layout<'_>,
cursor_position: Point,
viewport: &Rectangle,
@@ -218,6 +252,7 @@ where
}
let mouse_interaction = title_bar.mouse_interaction(
+ &tree.children[1],
title_bar_layout,
cursor_position,
viewport,
@@ -230,25 +265,46 @@ where
};
self.body
- .mouse_interaction(body_layout, cursor_position, viewport, renderer)
+ .as_widget()
+ .mouse_interaction(
+ &tree.children[0],
+ body_layout,
+ cursor_position,
+ viewport,
+ renderer,
+ )
.max(title_bar_interaction)
}
- pub(crate) fn overlay(
- &mut self,
+ pub(crate) fn overlay<'b>(
+ &'b self,
+ tree: &'b mut Tree,
layout: Layout<'_>,
renderer: &Renderer,
- ) -> Option<overlay::Element<'_, Message, Renderer>> {
- if let Some(title_bar) = self.title_bar.as_mut() {
+ ) -> Option<overlay::Element<'b, Message, Renderer>> {
+ if let Some(title_bar) = self.title_bar.as_ref() {
let mut children = layout.children();
let title_bar_layout = children.next()?;
- match title_bar.overlay(title_bar_layout, renderer) {
+ let mut states = tree.children.iter_mut();
+ let body_state = states.next().unwrap();
+ let title_bar_state = states.next().unwrap();
+
+ match title_bar.overlay(title_bar_state, title_bar_layout, renderer)
+ {
Some(overlay) => Some(overlay),
- None => self.body.overlay(children.next()?, renderer),
+ None => self.body.as_widget().overlay(
+ body_state,
+ children.next()?,
+ renderer,
+ ),
}
} else {
- self.body.overlay(layout, renderer)
+ self.body.as_widget().overlay(
+ &mut tree.children[0],
+ layout,
+ renderer,
+ )
}
}
}
diff --git a/native/src/widget/pane_grid/state.rs b/native/src/widget/pane_grid/state.rs
index 4e90f645..cdca6267 100644
--- a/native/src/widget/pane_grid/state.rs
+++ b/native/src/widget/pane_grid/state.rs
@@ -31,8 +31,6 @@ pub struct State<T> {
///
/// [`PaneGrid`]: crate::widget::PaneGrid
pub internal: Internal,
-
- pub(super) action: Action,
}
impl<T> State<T> {
@@ -54,11 +52,7 @@ impl<T> State<T> {
let internal =
Internal::from_configuration(&mut panes, config.into(), 0);
- State {
- panes,
- internal,
- action: Action::Idle,
- }
+ State { panes, internal }
}
/// Returns the total amount of panes in the [`State`].
diff --git a/native/src/widget/pane_grid/title_bar.rs b/native/src/widget/pane_grid/title_bar.rs
index 14c3ab4e..f9050e3e 100644
--- a/native/src/widget/pane_grid/title_bar.rs
+++ b/native/src/widget/pane_grid/title_bar.rs
@@ -4,6 +4,7 @@ use crate::mouse;
use crate::overlay;
use crate::renderer;
use crate::widget::container;
+use crate::widget::Tree;
use crate::{
Clipboard, Element, Layout, Padding, Point, Rectangle, Shell, Size,
};
@@ -86,11 +87,37 @@ where
Renderer: crate::Renderer,
Renderer::Theme: container::StyleSheet,
{
+ pub(super) fn state(&self) -> Tree {
+ let children = if let Some(controls) = self.controls.as_ref() {
+ vec![Tree::new(&self.content), Tree::new(controls)]
+ } else {
+ vec![Tree::new(&self.content), Tree::empty()]
+ };
+
+ Tree {
+ children,
+ ..Tree::empty()
+ }
+ }
+
+ pub(super) fn diff(&self, tree: &mut Tree) {
+ if tree.children.len() == 2 {
+ if let Some(controls) = self.controls.as_ref() {
+ tree.children[1].diff(controls);
+ }
+
+ tree.children[0].diff(&self.content);
+ } else {
+ *tree = self.state();
+ }
+ }
+
/// Draws the [`TitleBar`] with the provided [`Renderer`] and [`Layout`].
///
- /// [`Renderer`]: crate::Renderer
+ /// [`Renderer`]: iced_native::Renderer
pub fn draw(
&self,
+ tree: &Tree,
renderer: &mut Renderer,
theme: &Renderer::Theme,
inherited_style: &renderer::Style,
@@ -118,14 +145,15 @@ where
if let Some(controls) = &self.controls {
let controls_layout = children.next().unwrap();
+ if title_layout.bounds().width + controls_layout.bounds().width
+ > padded.bounds().width
+ {
+ show_title = false;
+ }
if show_controls || self.always_show_controls {
- if title_layout.bounds().width + controls_layout.bounds().width
- > padded.bounds().width
- {
- show_title = false;
- }
- controls.draw(
+ controls.as_widget().draw(
+ &tree.children[1],
renderer,
theme,
&inherited_style,
@@ -137,7 +165,8 @@ where
}
if show_title {
- self.content.draw(
+ self.content.as_widget().draw(
+ &tree.children[0],
renderer,
theme,
&inherited_style,
@@ -186,11 +215,14 @@ where
let title_layout = self
.content
+ .as_widget()
.layout(renderer, &layout::Limits::new(Size::ZERO, max_size));
+
let title_size = title_layout.size();
let mut node = if let Some(controls) = &self.controls {
let mut controls_layout = controls
+ .as_widget()
.layout(renderer, &layout::Limits::new(Size::ZERO, max_size));
let controls_size = controls_layout.size();
@@ -221,6 +253,7 @@ where
pub(crate) fn on_event(
&mut self,
+ tree: &mut Tree,
event: Event,
layout: Layout<'_>,
cursor_position: Point,
@@ -243,7 +276,8 @@ where
show_title = false;
}
- controls.on_event(
+ controls.as_widget_mut().on_event(
+ &mut tree.children[1],
event.clone(),
controls_layout,
cursor_position,
@@ -256,7 +290,8 @@ where
};
let title_status = if show_title {
- self.content.on_event(
+ self.content.as_widget_mut().on_event(
+ &mut tree.children[0],
event,
title_layout,
cursor_position,
@@ -273,6 +308,7 @@ where
pub(crate) fn mouse_interaction(
&self,
+ tree: &Tree,
layout: Layout<'_>,
cursor_position: Point,
viewport: &Rectangle,
@@ -284,7 +320,8 @@ where
let mut children = padded.children();
let title_layout = children.next().unwrap();
- let title_interaction = self.content.mouse_interaction(
+ let title_interaction = self.content.as_widget().mouse_interaction(
+ &tree.children[0],
title_layout,
cursor_position,
viewport,
@@ -293,7 +330,8 @@ where
if let Some(controls) = &self.controls {
let controls_layout = children.next().unwrap();
- let controls_interaction = controls.mouse_interaction(
+ let controls_interaction = controls.as_widget().mouse_interaction(
+ &tree.children[1],
controls_layout,
cursor_position,
viewport,
@@ -312,11 +350,12 @@ where
}
}
- pub(crate) fn overlay(
- &mut self,
+ pub(crate) fn overlay<'b>(
+ &'b self,
+ tree: &'b mut Tree,
layout: Layout<'_>,
renderer: &Renderer,
- ) -> Option<overlay::Element<'_, Message, Renderer>> {
+ ) -> Option<overlay::Element<'b, Message, Renderer>> {
let mut children = layout.children();
let padded = children.next()?;
@@ -327,12 +366,23 @@ where
content, controls, ..
} = self;
- content.overlay(title_layout, renderer).or_else(move || {
- controls.as_mut().and_then(|controls| {
- let controls_layout = children.next()?;
-
- controls.overlay(controls_layout, renderer)
+ let mut states = tree.children.iter_mut();
+ let title_state = states.next().unwrap();
+ let controls_state = states.next().unwrap();
+
+ content
+ .as_widget()
+ .overlay(title_state, title_layout, renderer)
+ .or_else(move || {
+ controls.as_ref().and_then(|controls| {
+ let controls_layout = children.next()?;
+
+ controls.as_widget().overlay(
+ controls_state,
+ controls_layout,
+ renderer,
+ )
+ })
})
- })
}
}