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

Unified Diff: chrome/renderer/printing/chrome_print_web_view_helper_delegate.cc

Issue 858363002: OOP PDF: Override printing for MimeHandlerViewContainers. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@mime-handler-api-simpler
Patch Set: Created 5 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
Index: chrome/renderer/printing/chrome_print_web_view_helper_delegate.cc
diff --git a/chrome/renderer/printing/chrome_print_web_view_helper_delegate.cc b/chrome/renderer/printing/chrome_print_web_view_helper_delegate.cc
index 131555763cfb3035acbf923f5adc617e2a659968..f2141875bced39b4fecb0cee156be60dd74a1ca9 100644
--- a/chrome/renderer/printing/chrome_print_web_view_helper_delegate.cc
+++ b/chrome/renderer/printing/chrome_print_web_view_helper_delegate.cc
@@ -4,9 +4,13 @@
#include "chrome/renderer/printing/chrome_print_web_view_helper_delegate.h"
+#include <vector>
+
#include "chrome/common/render_messages.h"
#include "chrome/renderer/prerender/prerender_helper.h"
+#include "content/public/renderer/render_frame.h"
#include "content/public/renderer/render_view.h"
+#include "extensions/renderer/guest_view/mime_handler_view/mime_handler_view_container.h"
#include "ipc/ipc_message.h"
#include "third_party/WebKit/public/web/WebDocument.h"
#include "third_party/WebKit/public/web/WebElement.h"
@@ -48,3 +52,20 @@ blink::WebElement ChromePrintWebViewHelperDelegate::GetPdfElement(
#endif // defined(ENABLE_EXTENSIONS)
return blink::WebElement();
}
+
+bool ChromePrintWebViewHelperDelegate::OverridePrint(
+ blink::WebLocalFrame* frame) {
+ if (!frame->document().isPluginDocument())
+ return false;
+
+ std::vector<extensions::MimeHandlerViewContainer*> mime_handlers =
+ extensions::MimeHandlerViewContainer::FromRenderFrame(
+ content::RenderFrame::FromWebFrame(frame));
+ if (mime_handlers.empty())
+ return false;
+
+ base::DictionaryValue message;
raymes 2015/01/22 00:58:57 Please add a comment here with a link to the PDF c
Sam McNally 2015/01/22 03:23:29 Done.
+ message.SetString("type", "print");
+ mime_handlers.front()->PostMessageFromValue(message);
+ return true;
+}

Powered by Google App Engine
This is Rietveld 408576698