mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-12 05:15:00 +00:00
Merge pull request #2172 from zed-industries/window-title-shenanigans
Window title shenanigans
This commit is contained in:
commit
df1775326c
2 changed files with 21 additions and 3 deletions
|
@ -19,7 +19,7 @@ use cocoa::{
|
|||
appkit::{
|
||||
CGPoint, NSApplication, NSBackingStoreBuffered, NSScreen, NSView, NSViewHeightSizable,
|
||||
NSViewWidthSizable, NSWindow, NSWindowButton, NSWindowCollectionBehavior,
|
||||
NSWindowStyleMask,
|
||||
NSWindowStyleMask, NSWindowTitleVisibility,
|
||||
},
|
||||
base::{id, nil},
|
||||
foundation::{NSAutoreleasePool, NSInteger, NSPoint, NSRect, NSSize, NSString, NSUInteger},
|
||||
|
@ -536,6 +536,7 @@ impl Window {
|
|||
.map_or(true, |titlebar| titlebar.appears_transparent)
|
||||
{
|
||||
native_window.setTitlebarAppearsTransparent_(YES);
|
||||
native_window.setTitleVisibility_(NSWindowTitleVisibility::NSWindowTitleHidden);
|
||||
}
|
||||
|
||||
native_view.setAutoresizingMask_(NSViewWidthSizable | NSViewHeightSizable);
|
||||
|
@ -734,7 +735,8 @@ impl platform::Window for Window {
|
|||
let app = NSApplication::sharedApplication(nil);
|
||||
let window = self.0.borrow().native_window;
|
||||
let title = ns_string(title);
|
||||
msg_send![app, changeWindowsItem:window title:title filename:false]
|
||||
let _: () = msg_send![app, changeWindowsItem:window title:title filename:false];
|
||||
let _: () = msg_send![window, setTitle: title];
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -491,19 +491,24 @@ impl Workspace {
|
|||
cx.subscribe(&project, move |this, _, event, cx| {
|
||||
match event {
|
||||
project::Event::RemoteIdChanged(remote_id) => {
|
||||
this.update_window_title(cx);
|
||||
this.project_remote_id_changed(*remote_id, cx);
|
||||
}
|
||||
|
||||
project::Event::CollaboratorLeft(peer_id) => {
|
||||
this.collaborator_left(*peer_id, cx);
|
||||
}
|
||||
|
||||
project::Event::WorktreeRemoved(_) | project::Event::WorktreeAdded => {
|
||||
this.update_window_title(cx);
|
||||
this.serialize_workspace(cx);
|
||||
}
|
||||
|
||||
project::Event::DisconnectedFromHost => {
|
||||
this.update_window_edited(cx);
|
||||
cx.blur();
|
||||
}
|
||||
|
||||
_ => {}
|
||||
}
|
||||
cx.notify()
|
||||
|
@ -1841,8 +1846,9 @@ impl Workspace {
|
|||
}
|
||||
|
||||
fn update_window_title(&mut self, cx: &mut ViewContext<Self>) {
|
||||
let mut title = String::new();
|
||||
let project = self.project().read(cx);
|
||||
let mut title = String::new();
|
||||
|
||||
if let Some(path) = self.active_item(cx).and_then(|item| item.project_path(cx)) {
|
||||
let filename = path
|
||||
.path
|
||||
|
@ -1856,20 +1862,30 @@ impl Workspace {
|
|||
.root_name(),
|
||||
))
|
||||
});
|
||||
|
||||
if let Some(filename) = filename {
|
||||
title.push_str(filename.as_ref());
|
||||
title.push_str(" — ");
|
||||
}
|
||||
}
|
||||
|
||||
for (i, name) in project.worktree_root_names(cx).enumerate() {
|
||||
if i > 0 {
|
||||
title.push_str(", ");
|
||||
}
|
||||
title.push_str(name);
|
||||
}
|
||||
|
||||
if title.is_empty() {
|
||||
title = "empty project".to_string();
|
||||
}
|
||||
|
||||
if project.is_remote() {
|
||||
title.push_str(" ↙");
|
||||
} else if project.is_shared() {
|
||||
title.push_str(" ↗");
|
||||
}
|
||||
|
||||
cx.set_window_title(&title);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue