Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(836)

Unified Diff: components/spellcheck/renderer/spellcheck_panel.cc

Issue 2792233003: Split SpellCheckPanel off SpellCheckProvider (Closed)
Patch Set: Remove histograms.xml from patch Created 3 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: components/spellcheck/renderer/spellcheck_panel.cc
diff --git a/components/spellcheck/renderer/spellcheck_panel.cc b/components/spellcheck/renderer/spellcheck_panel.cc
new file mode 100644
index 0000000000000000000000000000000000000000..cee271c699fbe81cec8db8d98e5daf13f89b524e
--- /dev/null
+++ b/components/spellcheck/renderer/spellcheck_panel.cc
@@ -0,0 +1,80 @@
+// Copyright 2017 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "components/spellcheck/renderer/spellcheck_panel.h"
+
+#include "base/metrics/histogram_macros.h"
+#include "components/spellcheck/common/spellcheck_messages.h"
+#include "content/public/renderer/render_view.h"
+#include "third_party/WebKit/public/web/WebLocalFrame.h"
+#include "third_party/WebKit/public/web/WebView.h"
+
+using blink::WebString;
+
+SpellCheckPanel::SpellCheckPanel(content::RenderView* render_view)
+ : content::RenderViewObserver(render_view),
+ content::RenderViewObserverTracker<SpellCheckPanel>(render_view),
+ spelling_panel_visible_(false) {
+ render_view->GetWebView()->setSpellCheckClient(this);
+}
+
+SpellCheckPanel::~SpellCheckPanel() = default;
+
+void SpellCheckPanel::showSpellingUI(bool show) {
+#if BUILDFLAG(USE_BROWSER_SPELLCHECKER)
+ UMA_HISTOGRAM_BOOLEAN("SpellCheck.api.showUI", show);
+ Send(new SpellCheckHostMsg_ShowSpellingPanel(routing_id(), show));
+#endif
+}
+
+bool SpellCheckPanel::isShowingSpellingUI() {
+ return spelling_panel_visible_;
+}
+
+void SpellCheckPanel::updateSpellingUIWithMisspelledWord(
+ const WebString& word) {
+#if BUILDFLAG(USE_BROWSER_SPELLCHECKER)
+ Send(new SpellCheckHostMsg_UpdateSpellingPanelWithMisspelledWord(
+ routing_id(), word.utf16()));
+#endif
+}
+
+bool SpellCheckPanel::OnMessageReceived(const IPC::Message& message) {
+#if !BUILDFLAG(USE_BROWSER_SPELLCHECKER)
+ return false;
+#endif
+#if BUILDFLAG(USE_BROWSER_SPELLCHECKER)
+ bool handled = true;
+ IPC_BEGIN_MESSAGE_MAP(SpellCheckPanel, message)
+ IPC_MESSAGE_HANDLER(SpellCheckMsg_AdvanceToNextMisspelling,
+ OnAdvanceToNextMisspelling)
+ IPC_MESSAGE_HANDLER(SpellCheckMsg_ToggleSpellPanel, OnToggleSpellPanel)
+ IPC_MESSAGE_UNHANDLED(handled = false)
+ IPC_END_MESSAGE_MAP()
+ return handled;
+#endif
+}
+
+#if BUILDFLAG(USE_BROWSER_SPELLCHECKER)
+void SpellCheckPanel::OnAdvanceToNextMisspelling() {
+ if (!render_view()->GetWebView())
+ return;
+ render_view()->GetWebView()->focusedFrame()->executeCommand(
+ WebString::fromUTF8("AdvanceToNextMisspelling"));
+}
+
+void SpellCheckPanel::OnToggleSpellPanel(bool is_currently_visible) {
+ if (!render_view()->GetWebView())
+ return;
+ // We need to tell the webView whether the spelling panel is visible or not so
+ // that it won't need to make ipc calls later.
+ spelling_panel_visible_ = is_currently_visible;
+ render_view()->GetWebView()->focusedFrame()->executeCommand(
+ WebString::fromUTF8("ToggleSpellPanel"));
+}
+#endif
+
+void SpellCheckPanel::OnDestruct() {
+ delete this;
+}
« no previous file with comments | « components/spellcheck/renderer/spellcheck_panel.h ('k') | components/spellcheck/renderer/spellcheck_provider.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698