fix: WCO buttons hidden on Linux in fullscreen (#44641)
Closes https://github.com/electron/electron/issues/44569. Fixes an issue where the WCO buttons were hidden on Linux in fullscreen mode but not on Windows or macOS. The Windows behavior is the expected one, so this commit makes the Linux behavior consistent. Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com>
This commit is contained in:
parent
da390c193b
commit
5b3a1a7195
1 changed files with 18 additions and 13 deletions
|
@ -255,6 +255,8 @@ void OpaqueFrameView::LayoutWindowControls() {
|
||||||
buttons_not_shown.push_back(views::FrameButton::kMinimize);
|
buttons_not_shown.push_back(views::FrameButton::kMinimize);
|
||||||
buttons_not_shown.push_back(views::FrameButton::kClose);
|
buttons_not_shown.push_back(views::FrameButton::kClose);
|
||||||
|
|
||||||
|
// We do not want to show the buttons in fullscreen mode.
|
||||||
|
if (!frame()->IsFullscreen()) {
|
||||||
for (const auto& button : leading_buttons_) {
|
for (const auto& button : leading_buttons_) {
|
||||||
ConfigureButton(button, ALIGN_LEADING);
|
ConfigureButton(button, ALIGN_LEADING);
|
||||||
std::erase(buttons_not_shown, button);
|
std::erase(buttons_not_shown, button);
|
||||||
|
@ -264,6 +266,7 @@ void OpaqueFrameView::LayoutWindowControls() {
|
||||||
ConfigureButton(button, ALIGN_TRAILING);
|
ConfigureButton(button, ALIGN_TRAILING);
|
||||||
std::erase(buttons_not_shown, button);
|
std::erase(buttons_not_shown, button);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
for (const auto& button_id : buttons_not_shown)
|
for (const auto& button_id : buttons_not_shown)
|
||||||
HideButton(button_id);
|
HideButton(button_id);
|
||||||
|
@ -401,8 +404,7 @@ void OpaqueFrameView::ConfigureButton(views::FrameButton button_id,
|
||||||
ButtonAlignment alignment) {
|
ButtonAlignment alignment) {
|
||||||
switch (button_id) {
|
switch (button_id) {
|
||||||
case views::FrameButton::kMinimize: {
|
case views::FrameButton::kMinimize: {
|
||||||
bool can_minimize = true; // delegate_->CanMinimize();
|
if (window()->IsMinimizable()) {
|
||||||
if (can_minimize) {
|
|
||||||
minimize_button_->SetVisible(true);
|
minimize_button_->SetVisible(true);
|
||||||
SetBoundsForButton(button_id, minimize_button_, alignment);
|
SetBoundsForButton(button_id, minimize_button_, alignment);
|
||||||
} else {
|
} else {
|
||||||
|
@ -411,8 +413,7 @@ void OpaqueFrameView::ConfigureButton(views::FrameButton button_id,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case views::FrameButton::kMaximize: {
|
case views::FrameButton::kMaximize: {
|
||||||
bool can_maximize = true; // delegate_->CanMaximize();
|
if (window()->IsMaximizable()) {
|
||||||
if (can_maximize) {
|
|
||||||
// When the window is restored, we show a maximized button; otherwise,
|
// When the window is restored, we show a maximized button; otherwise,
|
||||||
// we show a restore button.
|
// we show a restore button.
|
||||||
bool is_restored = !window()->IsMaximized() && !window()->IsMinimized();
|
bool is_restored = !window()->IsMaximized() && !window()->IsMinimized();
|
||||||
|
@ -430,8 +431,12 @@ void OpaqueFrameView::ConfigureButton(views::FrameButton button_id,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case views::FrameButton::kClose: {
|
case views::FrameButton::kClose: {
|
||||||
|
if (window()->IsClosable()) {
|
||||||
close_button_->SetVisible(true);
|
close_button_->SetVisible(true);
|
||||||
SetBoundsForButton(button_id, close_button_, alignment);
|
SetBoundsForButton(button_id, close_button_, alignment);
|
||||||
|
} else {
|
||||||
|
HideButton(button_id);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue