Detailed changes
@@ -30,7 +30,7 @@ impl Render for DiagnosticIndicator {
fn render(&mut self, _: &mut Window, cx: &mut Context<Self>) -> impl IntoElement {
let indicator = h_flex().gap_2();
if !ProjectSettings::get_global(cx).diagnostics.button {
- return indicator;
+ return indicator.hidden();
}
let diagnostic_indicator = match (self.summary.error_count, self.summary.warning_count) {
@@ -72,17 +72,17 @@ impl Render for EditPredictionButton {
fn render(&mut self, _: &mut Window, cx: &mut Context<Self>) -> impl IntoElement {
// Return empty div if AI is disabled
if DisableAiSettings::get_global(cx).disable_ai {
- return div();
+ return div().hidden();
}
let all_language_settings = all_language_settings(None, cx);
match all_language_settings.edit_predictions.provider {
- EditPredictionProvider::None => div(),
+ EditPredictionProvider::None => div().hidden(),
EditPredictionProvider::Copilot => {
let Some(copilot) = Copilot::global(cx) else {
- return div();
+ return div().hidden();
};
let status = copilot.read(cx).status();
@@ -1,5 +1,5 @@
use editor::{Editor, MultiBufferSnapshot};
-use gpui::{App, Entity, FocusHandle, Focusable, Subscription, Task, WeakEntity};
+use gpui::{App, Entity, FocusHandle, Focusable, Styled, Subscription, Task, WeakEntity};
use settings::Settings;
use std::{fmt::Write, num::NonZeroU32, time::Duration};
use text::{Point, Selection};
@@ -208,7 +208,7 @@ impl CursorPosition {
impl Render for CursorPosition {
fn render(&mut self, _window: &mut Window, cx: &mut Context<Self>) -> impl IntoElement {
if !StatusBarSettings::get_global(cx).cursor_position_button {
- return div();
+ return div().hidden();
}
div().when_some(self.position, |el, position| {
@@ -17,12 +17,13 @@
use crate::{
AbsoluteLength, Action, AnyDrag, AnyElement, AnyTooltip, AnyView, App, Bounds, ClickEvent,
- DispatchPhase, Element, ElementId, Entity, FocusHandle, Global, GlobalElementId, Hitbox,
- HitboxBehavior, HitboxId, InspectorElementId, IntoElement, IsZero, KeyContext, KeyDownEvent,
- KeyUpEvent, KeyboardButton, KeyboardClickEvent, LayoutId, ModifiersChangedEvent, MouseButton,
- MouseClickEvent, MouseDownEvent, MouseMoveEvent, MouseUpEvent, Overflow, ParentElement, Pixels,
- Point, Render, ScrollWheelEvent, SharedString, Size, Style, StyleRefinement, Styled, Task,
- TooltipId, Visibility, Window, WindowControlArea, point, px, size,
+ DispatchPhase, Display, Element, ElementId, Entity, FocusHandle, Global, GlobalElementId,
+ Hitbox, HitboxBehavior, HitboxId, InspectorElementId, IntoElement, IsZero, KeyContext,
+ KeyDownEvent, KeyUpEvent, KeyboardButton, KeyboardClickEvent, LayoutId, ModifiersChangedEvent,
+ MouseButton, MouseClickEvent, MouseDownEvent, MouseMoveEvent, MouseUpEvent, Overflow,
+ ParentElement, Pixels, Point, Render, ScrollWheelEvent, SharedString, Size, Style,
+ StyleRefinement, Styled, Task, TooltipId, Visibility, Window, WindowControlArea, point, px,
+ size,
};
use collections::HashMap;
use refineable::Refineable;
@@ -1403,7 +1404,12 @@ impl Element for Div {
content_size,
window,
cx,
- |_style, scroll_offset, hitbox, window, cx| {
+ |style, scroll_offset, hitbox, window, cx| {
+ // skip children
+ if style.display == Display::None {
+ return hitbox;
+ }
+
window.with_element_offset(scroll_offset, |window| {
for child in &mut self.children {
child.prepaint(window, cx);
@@ -1443,7 +1449,12 @@ impl Element for Div {
hitbox.as_ref(),
window,
cx,
- |_style, window, cx| {
+ |style, window, cx| {
+ // skip children
+ if style.display == Display::None {
+ return;
+ }
+
for child in &mut self.children {
child.paint(window, cx);
}
@@ -53,6 +53,13 @@ pub trait Styled: Sized {
self
}
+ /// Sets the display type of the element to `none`.
+ /// [Docs](https://tailwindcss.com/docs/display)
+ fn hidden(mut self) -> Self {
+ self.style().display = Some(Display::None);
+ self
+ }
+
/// Sets the whitespace of the element to `normal`.
/// [Docs](https://tailwindcss.com/docs/whitespace#normal)
fn whitespace_normal(mut self) -> Self {
@@ -47,7 +47,7 @@ impl Render for ImageInfo {
let settings = ImageViewerSettings::get_global(cx);
let Some(metadata) = self.metadata.as_ref() else {
- return div();
+ return div().hidden();
};
let mut components = Vec::new();
@@ -1,6 +1,7 @@
use editor::Editor;
use gpui::{
- Context, Entity, IntoElement, ParentElement, Render, Subscription, WeakEntity, Window, div,
+ Context, Entity, IntoElement, ParentElement, Render, Styled, Subscription, WeakEntity, Window,
+ div,
};
use language::LanguageName;
use settings::Settings as _;
@@ -41,7 +42,7 @@ impl ActiveBufferLanguage {
impl Render for ActiveBufferLanguage {
fn render(&mut self, _: &mut Window, cx: &mut Context<Self>) -> impl IntoElement {
if !StatusBarSettings::get_global(cx).active_language_button {
- return div();
+ return div().hidden();
}
div().when_some(self.active_language.as_ref(), |el, active_language| {
@@ -1011,7 +1011,7 @@ impl StatusItemView for LspButton {
impl Render for LspButton {
fn render(&mut self, _: &mut Window, cx: &mut Context<Self>) -> impl ui::IntoElement {
if self.server_state.read(cx).language_servers.is_empty() || self.lsp_menu.is_none() {
- return div();
+ return div().hidden();
}
let mut has_errors = false;
@@ -18,7 +18,7 @@ impl Render for SearchButton {
let button = div();
if !EditorSettings::get_global(cx).search.button {
- return button.w_0().invisible();
+ return button.hidden();
}
button.child(
@@ -2,12 +2,12 @@ use std::sync::Arc;
use editor::Editor;
use gpui::{
- AsyncWindowContext, Context, Entity, IntoElement, ParentElement, Render, Subscription, Task,
- WeakEntity, Window, div,
+ AsyncWindowContext, Context, Entity, IntoElement, ParentElement, Render, Styled, Subscription,
+ Task, WeakEntity, Window, div,
};
use language::{Buffer, BufferEvent, LanguageName, Toolchain, ToolchainScope};
use project::{Project, ProjectPath, Toolchains, WorktreeId, toolchain_store::ToolchainStoreEvent};
-use ui::{Button, ButtonCommon, Clickable, FluentBuilder, LabelSize, SharedString, Tooltip};
+use ui::{Button, ButtonCommon, Clickable, LabelSize, SharedString, Tooltip};
use util::{maybe, rel_path::RelPath};
use workspace::{StatusItemView, Workspace, item::ItemHandle};
@@ -230,21 +230,22 @@ impl ActiveToolchain {
impl Render for ActiveToolchain {
fn render(&mut self, _window: &mut Window, cx: &mut Context<Self>) -> impl IntoElement {
- div().when_some(self.active_toolchain.as_ref(), |el, active_toolchain| {
- let term = self.term.clone();
- el.child(
- Button::new("change-toolchain", active_toolchain.name.clone())
- .label_size(LabelSize::Small)
- .on_click(cx.listener(|this, _, window, cx| {
- if let Some(workspace) = this.workspace.upgrade() {
- workspace.update(cx, |workspace, cx| {
- ToolchainSelector::toggle(workspace, window, cx)
- });
- }
- }))
- .tooltip(Tooltip::text(format!("Select {}", &term))),
- )
- })
+ let Some(active_toolchain) = self.active_toolchain.as_ref() else {
+ return div().hidden();
+ };
+
+ div().child(
+ Button::new("change-toolchain", active_toolchain.name.clone())
+ .label_size(LabelSize::Small)
+ .on_click(cx.listener(|this, _, window, cx| {
+ if let Some(workspace) = this.workspace.upgrade() {
+ workspace.update(cx, |workspace, cx| {
+ ToolchainSelector::toggle(workspace, window, cx)
+ });
+ }
+ }))
+ .tooltip(Tooltip::text(format!("Select {}", &self.term))),
+ )
}
}
@@ -1,4 +1,4 @@
-use gpui::{Context, Element, Entity, Render, Subscription, WeakEntity, Window, div};
+use gpui::{Context, Entity, Render, Subscription, WeakEntity, Window, div};
use ui::text_for_keystrokes;
use workspace::{StatusItemView, item::ItemHandle, ui::prelude::*};
@@ -89,7 +89,7 @@ impl Render for ModeIndicator {
fn render(&mut self, _: &mut Window, cx: &mut Context<Self>) -> impl IntoElement {
let vim = self.vim();
let Some(vim) = vim else {
- return div().into_any();
+ return div().hidden().into_any_element();
};
let vim_readable = vim.read(cx);