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

Unified Diff: content/renderer/renderer_webcolorchooser_impl.cc

Issue 9203001: Implement input type=color UI (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: fixed flag Created 8 years, 11 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
« no previous file with comments | « content/renderer/renderer_webcolorchooser_impl.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/renderer/renderer_webcolorchooser_impl.cc
diff --git a/content/renderer/renderer_webcolorchooser_impl.cc b/content/renderer/renderer_webcolorchooser_impl.cc
new file mode 100644
index 0000000000000000000000000000000000000000..7dca22581cdb78775c2b4cc693531a5e07cd1e01
--- /dev/null
+++ b/content/renderer/renderer_webcolorchooser_impl.cc
@@ -0,0 +1,65 @@
+// Copyright (c) 2011 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 "content/renderer/renderer_webcolorchooser_impl.h"
+
+#include "content/common/view_messages.h"
+#include "content/renderer/render_view_impl.h"
+
+#if defined(ENABLE_INPUT_COLOR)
+
+RendererWebColorChooserImpl::RendererWebColorChooserImpl(
+ RenderViewImpl* render_view, WebKit::WebColorChooserClient* client)
+ : content::RenderViewObserver(render_view),
+ client_(client) {
+}
+
+RendererWebColorChooserImpl::~RendererWebColorChooserImpl() {
+ static_cast<RenderViewImpl*>(render_view())->detachColorChooser(this);
+}
+
+bool RendererWebColorChooserImpl::OnMessageReceived(
+ const IPC::Message& message) {
+ bool handled = true;
+ IPC_BEGIN_MESSAGE_MAP(RendererWebColorChooserImpl, message)
+ IPC_MESSAGE_HANDLER(ViewMsg_DidChooseColorResponse,
+ OnDidChooseColorResponse)
+ IPC_MESSAGE_HANDLER(ViewMsg_DidDetachColorChooser,
+ OnDidDetachColorChooser)
+ IPC_MESSAGE_UNHANDLED(handled = false)
+ IPC_END_MESSAGE_MAP()
+ return handled;
+}
+
+void RendererWebColorChooserImpl::setSelectedColor(WebKit::WebColor color) {
+ ViewHostMsg_SetSelectedColorInColorChooser_Params ipc_params;
+ ipc_params.color = color;
+ Send(new ViewHostMsg_SetSelectedColorInColorChooser(routing_id(),
+ ipc_params));
+}
+
+void RendererWebColorChooserImpl::endChooser() {
+ static_cast<RenderViewImpl*>(render_view())->detachColorChooser(this);
+ Send(new ViewHostMsg_DetachColorChooser(routing_id()));
+ if (client_.get())
+ client_->didEndChooser();
+}
+
+void RendererWebColorChooserImpl::OnDidChooseColorResponse(
+ WebKit::WebColor color) {
+ if (client_.get())
+ client_->didChooseColor(color);
+}
+
+void RendererWebColorChooserImpl::OnDidDetachColorChooser() {
+ static_cast<RenderViewImpl*>(render_view())->detachColorChooser(this);
+ if (client_.get())
+ client_->didEndChooser();
+}
+
+WebKit::WebColorChooserClient* RendererWebColorChooserImpl::client() {
+ return client_.get();
+}
+
+#endif // defined(ENABLE_INPUT_COLOR)
« no previous file with comments | « content/renderer/renderer_webcolorchooser_impl.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698