summaryrefslogtreecommitdiffstats
path: root/lazy/src/pure/component.rs
diff options
context:
space:
mode:
authorLibravatar Nick Senger <nicks@lich.io>2022-05-10 17:18:08 -0700
committerLibravatar Nick Senger <nicks@lich.io>2022-05-10 17:23:30 -0700
commit3be8f6e98990f7e8a3af11400bbecaecddda336c (patch)
treed616239a59b6d3a726d5763fa7eeca2beb7aafc1 /lazy/src/pure/component.rs
parentd4ed8afa1ed15486144dc7afee52c09e044a92e0 (diff)
downloadiced-3be8f6e98990f7e8a3af11400bbecaecddda336c.tar.gz
iced-3be8f6e98990f7e8a3af11400bbecaecddda336c.tar.bz2
iced-3be8f6e98990f7e8a3af11400bbecaecddda336c.zip
fix: prevent building overlay with stale layout
Diffstat (limited to '')
-rw-r--r--lazy/src/pure/component.rs40
1 files changed, 30 insertions, 10 deletions
diff --git a/lazy/src/pure/component.rs b/lazy/src/pure/component.rs
index 2971d2b7..bf6ff908 100644
--- a/lazy/src/pure/component.rs
+++ b/lazy/src/pure/component.rs
@@ -415,6 +415,35 @@ where
let mut local_messages = Vec::new();
let mut local_shell = Shell::new(&mut local_messages);
+ if self
+ .overlay
+ .as_ref()
+ .and_then(|overlay| overlay.borrow_overlay().as_ref())
+ .is_none()
+ {
+ let overlay = self.overlay.take().unwrap().into_heads();
+
+ self.overlay = Some(
+ OverlayBuilder {
+ instance: overlay.instance,
+ instance_ref_builder: |instance| instance.state.borrow(),
+ tree: overlay.tree,
+ types: PhantomData,
+ overlay_builder: |instance, tree| {
+ instance
+ .as_ref()
+ .unwrap()
+ .borrow_element()
+ .as_ref()
+ .unwrap()
+ .as_widget()
+ .overlay(&mut tree.children[0], layout, renderer)
+ },
+ }
+ .build(),
+ );
+ }
+
let event_status = self
.with_overlay_mut_maybe(|overlay| {
overlay.on_event(
@@ -464,16 +493,7 @@ where
instance_ref_builder: |instance| instance.state.borrow(),
tree: overlay.tree,
types: PhantomData,
- overlay_builder: |instance, tree| {
- instance
- .as_ref()
- .unwrap()
- .borrow_element()
- .as_ref()
- .unwrap()
- .as_widget()
- .overlay(&mut tree.children[0], layout, renderer)
- },
+ overlay_builder: |_, _| None,
}
.build(),
);