Rename item to panel in various locations

This commit is contained in:
Nathan Sobo 2023-05-10 09:54:20 -06:00
parent 0ccb4a50e6
commit cc21421ea8
2 changed files with 43 additions and 43 deletions

View file

@ -83,9 +83,9 @@ impl From<&dyn PanelHandle> for AnyViewHandle {
pub struct Dock {
position: DockPosition,
panels: Vec<PanelEntry>,
panel_entries: Vec<PanelEntry>,
is_open: bool,
active_item_ix: usize,
active_panel_index: usize,
}
#[derive(Clone, Copy, Debug, Deserialize, PartialEq)]
@ -127,7 +127,7 @@ pub struct PanelButtons {
#[derive(Clone, Debug, Deserialize, PartialEq)]
pub struct TogglePanel {
pub dock_position: DockPosition,
pub item_index: usize,
pub panel_index: usize,
}
impl_actions!(workspace, [TogglePanel]);
@ -136,8 +136,8 @@ impl Dock {
pub fn new(position: DockPosition) -> Self {
Self {
position,
panels: Default::default(),
active_item_ix: 0,
panel_entries: Default::default(),
active_panel_index: 0,
is_open: false,
}
}
@ -146,8 +146,8 @@ impl Dock {
self.is_open
}
pub fn active_item_ix(&self) -> usize {
self.active_item_ix
pub fn active_panel_index(&self) -> usize {
self.active_panel_index
}
pub fn set_open(&mut self, open: bool, cx: &mut ViewContext<Self>) {
@ -168,11 +168,11 @@ impl Dock {
cx.subscribe(&panel, |this, view, event, cx| {
if view.read(cx).should_activate_on_event(event, cx) {
if let Some(ix) = this
.panels
.panel_entries
.iter()
.position(|item| item.panel.id() == view.id())
.position(|entry| entry.panel.id() == view.id())
{
this.activate_item(ix, cx);
this.activate_panel(ix, cx);
}
} else if view.read(cx).should_close_on_event(event, cx) {
this.set_open(false, cx);
@ -181,7 +181,7 @@ impl Dock {
];
let dock_view_id = cx.view_id();
self.panels.push(PanelEntry {
self.panel_entries.push(PanelEntry {
panel: Rc::new(panel),
context_menu: cx.add_view(|cx| {
let mut menu = ContextMenu::new(dock_view_id, cx);
@ -195,40 +195,40 @@ impl Dock {
pub fn remove_panel<T: Panel>(&mut self, panel: &ViewHandle<T>, cx: &mut ViewContext<Self>) {
if let Some(panel_ix) = self
.panels
.panel_entries
.iter()
.position(|item| item.panel.id() == panel.id())
.position(|entry| entry.panel.id() == panel.id())
{
if panel_ix == self.active_item_ix {
self.active_item_ix = 0;
if panel_ix == self.active_panel_index {
self.active_panel_index = 0;
self.set_open(false, cx);
}
self.panels.remove(panel_ix);
self.panel_entries.remove(panel_ix);
cx.notify();
}
}
pub fn panels_len(&self) -> usize {
self.panels.len()
self.panel_entries.len()
}
pub fn activate_item(&mut self, item_ix: usize, cx: &mut ViewContext<Self>) {
self.active_item_ix = item_ix;
pub fn activate_panel(&mut self, panel_ix: usize, cx: &mut ViewContext<Self>) {
self.active_panel_index = panel_ix;
cx.notify();
}
pub fn toggle_item(&mut self, item_ix: usize, cx: &mut ViewContext<Self>) {
if self.active_item_ix == item_ix {
pub fn toggle_panel(&mut self, panel_ix: usize, cx: &mut ViewContext<Self>) {
if self.active_panel_index == panel_ix {
self.is_open = false;
} else {
self.active_item_ix = item_ix;
self.active_panel_index = panel_ix;
}
cx.notify();
}
pub fn active_item(&self) -> Option<&Rc<dyn PanelHandle>> {
pub fn active_panel(&self) -> Option<&Rc<dyn PanelHandle>> {
if self.is_open {
self.panels.get(self.active_item_ix).map(|item| &item.panel)
self.panel_entries.get(self.active_panel_index).map(|entry| &entry.panel)
} else {
None
}
@ -245,10 +245,10 @@ impl View for Dock {
}
fn render(&mut self, cx: &mut ViewContext<Self>) -> AnyElement<Self> {
if let Some(active_item) = self.active_item() {
if let Some(active_panel) = self.active_panel() {
enum ResizeHandleTag {}
let style = &cx.global::<Settings>().theme.workspace.dock;
ChildView::new(active_item.as_any(), cx)
ChildView::new(active_panel.as_any(), cx)
.contained()
.with_style(style.container)
.with_resize_handle::<ResizeHandleTag>(
@ -289,9 +289,9 @@ impl View for PanelButtons {
let theme = &cx.global::<Settings>().theme;
let tooltip_style = theme.tooltip.clone();
let theme = &theme.workspace.status_bar.panel_buttons;
let item_style = theme.button.clone();
let button_style = theme.button.clone();
let dock = self.dock.read(cx);
let active_ix = dock.active_item_ix;
let active_ix = dock.active_panel_index;
let is_open = dock.is_open;
let dock_position = dock.position;
let group_style = match dock_position {
@ -304,27 +304,27 @@ impl View for PanelButtons {
DockPosition::Bottom | DockPosition::Right => AnchorCorner::BottomRight,
};
let items = dock
.panels
let panels = dock
.panel_entries
.iter()
.map(|item| (item.panel.clone(), item.context_menu.clone()))
.collect::<Vec<_>>();
Flex::row()
.with_children(
items
panels
.into_iter()
.enumerate()
.map(|(ix, (view, context_menu))| {
let action = TogglePanel {
dock_position,
item_index: ix,
panel_index: ix,
};
Stack::new()
.with_child(
MouseEventHandler::<Self, _>::new(ix, cx, |state, cx| {
let is_active = is_open && ix == active_ix;
let style = item_style.style_for(state, is_active);
let style = button_style.style_for(state, is_active);
Flex::row()
.with_child(
Svg::new(view.icon_path(cx))

View file

@ -858,7 +858,7 @@ impl Workspace {
dock.update(cx, |dock, cx| {
was_visible = dock.is_open()
&& dock
.active_item()
.active_panel()
.map_or(false, |item| item.as_any().is::<T>());
dock.remove_panel(&panel, cx);
});
@ -872,7 +872,7 @@ impl Workspace {
dock.add_panel(panel, cx);
if was_visible {
dock.set_open(true, cx);
dock.activate_item(dock.panels_len() - 1, cx);
dock.activate_panel(dock.panels_len() - 1, cx);
}
});
}
@ -1392,13 +1392,13 @@ impl Workspace {
DockPosition::Right => &mut self.right_dock,
};
let active_item = dock.update(cx, move |dock, cx| {
if dock.is_open() && dock.active_item_ix() == action.item_index {
if dock.is_open() && dock.active_panel_index() == action.panel_index {
dock.set_open(false, cx);
None
} else {
dock.set_open(true, cx);
dock.activate_item(action.item_index, cx);
dock.active_item().cloned()
dock.activate_panel(action.panel_index, cx);
dock.active_panel().cloned()
}
});
@ -1430,8 +1430,8 @@ impl Workspace {
};
let active_item = dock.update(cx, |dock, cx| {
dock.set_open(true, cx);
dock.activate_item(panel_index, cx);
dock.active_item().cloned()
dock.activate_panel(panel_index, cx);
dock.active_panel().cloned()
});
if let Some(active_item) = active_item {
if active_item.is_focused(cx) {
@ -2655,7 +2655,7 @@ impl View for Workspace {
let project = self.project.clone();
Flex::row()
.with_children(
if self.left_dock.read(cx).active_item().is_some() {
if self.left_dock.read(cx).active_panel().is_some() {
Some(
ChildView::new(&self.left_dock, cx)
.constrained()
@ -2688,7 +2688,7 @@ impl View for Workspace {
.flex(1., true),
)
.with_children(
if self.bottom_dock.read(cx).active_item().is_some()
if self.bottom_dock.read(cx).active_panel().is_some()
{
Some(ChildView::new(&self.bottom_dock, cx))
} else {
@ -2698,7 +2698,7 @@ impl View for Workspace {
.flex(1., true),
)
.with_children(
if self.right_dock.read(cx).active_item().is_some() {
if self.right_dock.read(cx).active_panel().is_some() {
Some(
ChildView::new(&self.right_dock, cx)
.constrained()