From 18abb068b18aa2a894b0da13f12609b1e5f62f20 Mon Sep 17 00:00:00 2001 From: Antonio Scandurra Date: Tue, 17 Oct 2023 11:35:48 +0200 Subject: [PATCH] Checkpoint --- crates/gpui3/src/elements/nested.rs | 53 +++++++++++++++++++++++++++-- 1 file changed, 51 insertions(+), 2 deletions(-) diff --git a/crates/gpui3/src/elements/nested.rs b/crates/gpui3/src/elements/nested.rs index 8800b26d9e..360a0a319c 100644 --- a/crates/gpui3/src/elements/nested.rs +++ b/crates/gpui3/src/elements/nested.rs @@ -1,7 +1,7 @@ use crate::{ group_bounds, AnyElement, BorrowWindow, Bounds, DispatchPhase, Element, ElementId, - IdentifiedElement, IntoAnyElement, MouseDownEvent, MouseMoveEvent, MouseUpEvent, SharedString, - Style, StyleCascade, StyleRefinement, ViewContext, + IdentifiedElement, IntoAnyElement, MouseDownEvent, MouseMoveEvent, MouseUpEvent, Overflow, + ScrollState, SharedString, Style, StyleCascade, StyleRefinement, ViewContext, }; use parking_lot::Mutex; use refineable::{CascadeSlot, Refineable}; @@ -466,6 +466,55 @@ pub struct Div( ClickableElement>>, ); +impl Div { + pub fn z_index(mut self, z_index: u32) -> Self { + self.base_style().z_index = Some(z_index); + self + } + + pub fn overflow_hidden(mut self) -> Self { + self.base_style().overflow.x = Some(Overflow::Hidden); + self.base_style().overflow.y = Some(Overflow::Hidden); + self + } + + pub fn overflow_hidden_x(mut self) -> Self { + self.base_style().overflow.x = Some(Overflow::Hidden); + self + } + + pub fn overflow_hidden_y(mut self) -> Self { + self.base_style().overflow.y = Some(Overflow::Hidden); + self + } + + pub fn overflow_scroll(mut self, scroll_state: ScrollState) -> Self { + // todo!("impl scrolling") + // self.scroll_state = Some(scroll_state); + self.base_style().overflow.x = Some(Overflow::Scroll); + self.base_style().overflow.y = Some(Overflow::Scroll); + self + } + + pub fn overflow_x_scroll(mut self, scroll_state: ScrollState) -> Self { + // todo!("impl scrolling") + // self.scroll_state = Some(scroll_state); + self.base_style().overflow.x = Some(Overflow::Scroll); + self + } + + pub fn overflow_y_scroll(mut self, scroll_state: ScrollState) -> Self { + // todo!("impl scrolling") + // self.scroll_state = Some(scroll_state); + self.base_style().overflow.y = Some(Overflow::Scroll); + self + } + + fn base_style(&mut self) -> &mut StyleRefinement { + self.style_cascade().base() + } +} + impl Div { pub fn id(self, id: impl Into) -> Div { Div(self.0.replace_child(|hoverable| {