-
Notifications
You must be signed in to change notification settings - Fork 8.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Tray Icon PR followup #10938
Tray Icon PR followup #10938
Changes from all commits
2c2a880
fdd14b3
b94e199
dd8d07e
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -92,11 +92,6 @@ AppHost::AppHost() noexcept : | |
|
||
AppHost::~AppHost() | ||
{ | ||
if (_window->IsQuakeWindow()) | ||
{ | ||
_windowManager.RequestHideTrayIcon(); | ||
} | ||
|
||
// destruction order is important for proper teardown here | ||
_window = nullptr; | ||
_app.Close(); | ||
|
@@ -324,6 +319,15 @@ void AppHost::AppTitleChanged(const winrt::Windows::Foundation::IInspectable& /* | |
// - <none> | ||
void AppHost::LastTabClosed(const winrt::Windows::Foundation::IInspectable& /*sender*/, const winrt::TerminalApp::LastTabClosedEventArgs& /*args*/) | ||
{ | ||
if (_windowManager.IsMonarch() && _trayIcon) | ||
{ | ||
_DestroyTrayIcon(); | ||
} | ||
else if (_window->IsQuakeWindow()) | ||
{ | ||
_HideTrayIconRequested(); | ||
} | ||
|
||
_window->Close(); | ||
} | ||
|
||
|
@@ -656,9 +660,6 @@ void AppHost::_BecomeMonarch(const winrt::Windows::Foundation::IInspectable& /*s | |
{ | ||
_setupGlobalHotkeys(); | ||
|
||
// The monarch is just going to be THE listener for inbound connections. | ||
_listenForInboundConnections(); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't understand this change. Otherwise I'd approve this PR. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Oh this was originally removed as part of this defapp bug fix #10823, and my bad merge left it in 😥. In short, the fix made it so that instead of making the monarch receive default terminal handoffs by default, the monarch should first figure out which peasant (or itself) should handle a default terminal handoff and tell that window to receive the connection. |
||
|
||
if (_windowManager.DoesQuakeWindowExist() || | ||
_window->IsQuakeWindow() || | ||
(_logic.GetAlwaysShowTrayIcon() || _logic.GetMinimizeToTray())) | ||
|
@@ -1055,11 +1056,10 @@ void AppHost::_DestroyTrayIcon() | |
} | ||
} | ||
|
||
winrt::fire_and_forget AppHost::_ShowTrayIconRequested() | ||
void AppHost::_ShowTrayIconRequested() | ||
{ | ||
if constexpr (Feature_TrayIcon::IsEnabled()) | ||
{ | ||
co_await winrt::resume_background(); | ||
if (_windowManager.IsMonarch()) | ||
{ | ||
if (!_trayIcon) | ||
|
@@ -1074,11 +1074,10 @@ winrt::fire_and_forget AppHost::_ShowTrayIconRequested() | |
} | ||
} | ||
|
||
winrt::fire_and_forget AppHost::_HideTrayIconRequested() | ||
void AppHost::_HideTrayIconRequested() | ||
{ | ||
if constexpr (Feature_TrayIcon::IsEnabled()) | ||
{ | ||
co_await winrt::resume_background(); | ||
if (_windowManager.IsMonarch()) | ||
{ | ||
// Destroy it only if our settings allow it | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
you might hate me for asking . . . but does this fire when you use the [x] on the window? I know that we try to kill all the tabs, but this might only be a side effect... unless it is the main effect 😀
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It does in fact go off on the X button 🙂