fix: correctly handle Alt+Key shortcuts (#29328)
This commit is contained in:
parent
0208e4adad
commit
d74ad51826
2 changed files with 12 additions and 10 deletions
|
@ -56,6 +56,8 @@ void MenuBar::SetAcceleratorVisibility(bool visible) {
|
||||||
}
|
}
|
||||||
|
|
||||||
MenuBar::View* MenuBar::FindAccelChild(char16_t key) {
|
MenuBar::View* MenuBar::FindAccelChild(char16_t key) {
|
||||||
|
if (key == 0)
|
||||||
|
return nullptr;
|
||||||
for (auto* child : GetChildrenInZOrder()) {
|
for (auto* child : GetChildrenInZOrder()) {
|
||||||
if (static_cast<SubmenuButton*>(child)->accelerator() == key)
|
if (static_cast<SubmenuButton*>(child)->accelerator() == key)
|
||||||
return child;
|
return child;
|
||||||
|
|
|
@ -119,18 +119,18 @@ void RootView::HandleKeyEvent(const content::NativeWebKeyboardEvent& event) {
|
||||||
|
|
||||||
// Show the submenu when "Alt+Key" is pressed.
|
// Show the submenu when "Alt+Key" is pressed.
|
||||||
if (event.GetType() == blink::WebInputEvent::Type::kRawKeyDown &&
|
if (event.GetType() == blink::WebInputEvent::Type::kRawKeyDown &&
|
||||||
!IsAltKey(event) && IsAltModifier(event)) {
|
event.windows_key_code >= ui::VKEY_A &&
|
||||||
if (menu_bar_->HasAccelerator(event.windows_key_code)) {
|
event.windows_key_code <= ui::VKEY_Z && IsAltModifier(event) &&
|
||||||
if (!menu_bar_visible_) {
|
menu_bar_->HasAccelerator(event.windows_key_code)) {
|
||||||
SetMenuBarVisibility(true);
|
if (!menu_bar_visible_) {
|
||||||
|
SetMenuBarVisibility(true);
|
||||||
|
|
||||||
View* focused_view = GetFocusManager()->GetFocusedView();
|
View* focused_view = GetFocusManager()->GetFocusedView();
|
||||||
last_focused_view_tracker_->SetView(focused_view);
|
last_focused_view_tracker_->SetView(focused_view);
|
||||||
menu_bar_->RequestFocus();
|
menu_bar_->RequestFocus();
|
||||||
}
|
|
||||||
|
|
||||||
menu_bar_->ActivateAccelerator(event.windows_key_code);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
menu_bar_->ActivateAccelerator(event.windows_key_code);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue