fix: update osk patch to fix more corner cases (#41131)
This is a follow up to https://github.com/electron/electron/pull/35921 that, it fixes more corner cases that on-screen-keyboard does not hide for webviews. This change has been applied in Teams for quite a while and should be reliable enough to introduce to Electron.
This commit is contained in:
parent
8104c7908a
commit
2571396584
1 changed files with 75 additions and 33 deletions
|
@ -3,47 +3,89 @@ From: Kyrylo Hrechykhin <khrechykhin@microsoft.com>
|
||||||
Date: Thu, 6 Oct 2022 18:30:53 +0200
|
Date: Thu, 6 Oct 2022 18:30:53 +0200
|
||||||
Subject: fix: on-screen-keyboard hides on input blur in webview
|
Subject: fix: on-screen-keyboard hides on input blur in webview
|
||||||
|
|
||||||
Changes introduced by this patch fix issue where OSK does not hide on
|
Work around OSK not hiding by notifying RenderWidgetHostViewAura of
|
||||||
input rendered inside webview is blurred. This patch should be removed
|
focus node change via TextInputManager.
|
||||||
when proper fix in chromium repo is available.
|
|
||||||
|
|
||||||
Note: the issue still occurs if input rendered in webview blurred due
|
|
||||||
to touch outside of webview. It is caused by webview implementation
|
|
||||||
details. Specificaly due to webview has its own tree nodes and focused
|
|
||||||
node does not change in this case.
|
|
||||||
|
|
||||||
chromium-bug: https://crbug.com/1369605
|
chromium-bug: https://crbug.com/1369605
|
||||||
|
|
||||||
diff --git a/content/browser/renderer_host/render_widget_host_view_child_frame.cc b/content/browser/renderer_host/render_widget_host_view_child_frame.cc
|
diff --git a/content/browser/renderer_host/render_widget_host_view_aura.cc b/content/browser/renderer_host/render_widget_host_view_aura.cc
|
||||||
index 090d9d58eddac80f8bd191ac4754d2e8d87c1b39..0c5c78020b98795f51f375a526f06599f9c9a273 100644
|
index 4d2de00328f0b6437789612b14a53aae79eb15ab..c1ad97a53b59ccd7528ae51f27f9863b88cdac60 100644
|
||||||
--- a/content/browser/renderer_host/render_widget_host_view_child_frame.cc
|
--- a/content/browser/renderer_host/render_widget_host_view_aura.cc
|
||||||
+++ b/content/browser/renderer_host/render_widget_host_view_child_frame.cc
|
+++ b/content/browser/renderer_host/render_widget_host_view_aura.cc
|
||||||
@@ -1039,6 +1039,12 @@ RenderWidgetHostViewChildFrame::DidUpdateVisualProperties(
|
@@ -2926,6 +2926,12 @@ void RenderWidgetHostViewAura::OnTextSelectionChanged(
|
||||||
return viz::ScopedSurfaceIdAllocator(std::move(allocation_task));
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
+void RenderWidgetHostViewChildFrame::FocusedNodeChanged(
|
+void RenderWidgetHostViewAura::OnFocusedInputElementChanged(
|
||||||
+ bool is_editable_node,
|
+ TextInputManager* text_input_manager,
|
||||||
+ const gfx::Rect& node_bounds_in_screen) {
|
+ RenderWidgetHostViewBase* view) {
|
||||||
+ NOTREACHED();
|
+ FocusedNodeChanged(false, {});
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
ui::TextInputType RenderWidgetHostViewChildFrame::GetTextInputType() const {
|
void RenderWidgetHostViewAura::SetPopupChild(
|
||||||
if (!text_input_manager_)
|
RenderWidgetHostViewAura* popup_child_host_view) {
|
||||||
return ui::TEXT_INPUT_TYPE_NONE;
|
popup_child_host_view_ = popup_child_host_view;
|
||||||
diff --git a/content/browser/renderer_host/render_widget_host_view_child_frame.h b/content/browser/renderer_host/render_widget_host_view_child_frame.h
|
diff --git a/content/browser/renderer_host/render_widget_host_view_aura.h b/content/browser/renderer_host/render_widget_host_view_aura.h
|
||||||
index 58b3038d3aa7ed6babab2e9f6ffe9e4670656243..b2adee153030e0e3c3bf8ae3c2877d78dce56929 100644
|
index 0f8d970ffb54a652c9235d13a7515b5ed3be7945..dcadbdb852ec03539168b4f27488107a800acc23 100644
|
||||||
--- a/content/browser/renderer_host/render_widget_host_view_child_frame.h
|
--- a/content/browser/renderer_host/render_widget_host_view_aura.h
|
||||||
+++ b/content/browser/renderer_host/render_widget_host_view_child_frame.h
|
+++ b/content/browser/renderer_host/render_widget_host_view_aura.h
|
||||||
@@ -181,6 +181,8 @@ class CONTENT_EXPORT RenderWidgetHostViewChildFrame
|
@@ -626,6 +626,8 @@ class CONTENT_EXPORT RenderWidgetHostViewAura
|
||||||
void DisableAutoResize(const gfx::Size& new_size) override;
|
RenderWidgetHostViewBase* updated_view) override;
|
||||||
viz::ScopedSurfaceIdAllocator DidUpdateVisualProperties(
|
void OnTextSelectionChanged(TextInputManager* text_input_mangager,
|
||||||
const cc::RenderFrameMetadata& metadata) override;
|
RenderWidgetHostViewBase* updated_view) override;
|
||||||
+ void FocusedNodeChanged(bool is_editable_node,
|
+ void OnFocusedInputElementChanged(TextInputManager* text_input_manager,
|
||||||
+ const gfx::Rect& node_bounds_in_screen) override;
|
+ RenderWidgetHostViewBase* view) override;
|
||||||
|
|
||||||
// RenderFrameMetadataProvider::Observer implementation.
|
// Detaches |this| from the input method object.
|
||||||
void OnRenderFrameMetadataChangedBeforeActivation(
|
// is_removed flag is true if this is called while the window is
|
||||||
|
diff --git a/content/browser/renderer_host/text_input_manager.cc b/content/browser/renderer_host/text_input_manager.cc
|
||||||
|
index a73f08700e77443b1229ee35f99356be57d376f5..d37da7f122cdd326499d9e89fc83bef89d726014 100644
|
||||||
|
--- a/content/browser/renderer_host/text_input_manager.cc
|
||||||
|
+++ b/content/browser/renderer_host/text_input_manager.cc
|
||||||
|
@@ -167,6 +167,7 @@ void TextInputManager::UpdateTextInputState(
|
||||||
|
|
||||||
|
if (text_input_state.type == ui::TEXT_INPUT_TYPE_NONE &&
|
||||||
|
active_view_ != view) {
|
||||||
|
+ NotifyFocusedInputElementChanged(active_view_);
|
||||||
|
// We reached here because an IPC is received to reset the TextInputState
|
||||||
|
// for |view|. But |view| != |active_view_|, which suggests that at least
|
||||||
|
// one other view has become active and we have received the corresponding
|
||||||
|
@@ -453,6 +454,12 @@ void TextInputManager::NotifyObserversAboutInputStateUpdate(
|
||||||
|
observer.OnUpdateTextInputStateCalled(this, updated_view, did_update_state);
|
||||||
|
}
|
||||||
|
|
||||||
|
+void TextInputManager::NotifyFocusedInputElementChanged(
|
||||||
|
+ RenderWidgetHostViewBase* view) {
|
||||||
|
+ for (auto& observer : observer_list_)
|
||||||
|
+ observer.OnFocusedInputElementChanged(this, view);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
TextInputManager::SelectionRegion::SelectionRegion() = default;
|
||||||
|
|
||||||
|
TextInputManager::SelectionRegion::SelectionRegion(
|
||||||
|
diff --git a/content/browser/renderer_host/text_input_manager.h b/content/browser/renderer_host/text_input_manager.h
|
||||||
|
index 01993347572548e46d8583c0bb568be4f12c7207..c679db5de0e2b60867b8f4b30c9b72b63420d694 100644
|
||||||
|
--- a/content/browser/renderer_host/text_input_manager.h
|
||||||
|
+++ b/content/browser/renderer_host/text_input_manager.h
|
||||||
|
@@ -71,6 +71,10 @@ class CONTENT_EXPORT TextInputManager {
|
||||||
|
virtual void OnTextSelectionChanged(
|
||||||
|
TextInputManager* text_input_manager,
|
||||||
|
RenderWidgetHostViewBase* updated_view) {}
|
||||||
|
+ // Called when focused input element has changed
|
||||||
|
+ virtual void OnFocusedInputElementChanged(
|
||||||
|
+ TextInputManager* text_input_manager,
|
||||||
|
+ RenderWidgetHostViewBase* updated_view) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Text selection bounds.
|
||||||
|
@@ -277,6 +281,7 @@ class CONTENT_EXPORT TextInputManager {
|
||||||
|
|
||||||
|
void NotifyObserversAboutInputStateUpdate(RenderWidgetHostViewBase* view,
|
||||||
|
bool did_update_state);
|
||||||
|
+ void NotifyFocusedInputElementChanged(RenderWidgetHostViewBase* view);
|
||||||
|
|
||||||
|
// The view with active text input state, i.e., a focused <input> element.
|
||||||
|
// It will be nullptr if no such view exists. Note that the active view
|
||||||
diff --git a/content/browser/web_contents/web_contents_impl.cc b/content/browser/web_contents/web_contents_impl.cc
|
diff --git a/content/browser/web_contents/web_contents_impl.cc b/content/browser/web_contents/web_contents_impl.cc
|
||||||
index 1b1983d2ecdbd14bf4e897e43cce6f4182a842cb..28afdf5395ae78dd0c5c7612b8b47efae7e837a3 100644
|
index 1b1983d2ecdbd14bf4e897e43cce6f4182a842cb..28afdf5395ae78dd0c5c7612b8b47efae7e837a3 100644
|
||||||
--- a/content/browser/web_contents/web_contents_impl.cc
|
--- a/content/browser/web_contents/web_contents_impl.cc
|
||||||
|
|
Loading…
Reference in a new issue