2017-12-07 22:44:24 +01:00
diff --git chrome/browser/ui/BUILD.gn chrome/browser/ui/BUILD.gn
2019-02-01 20:40:18 +01:00
index 46bee4c2a411..182b9b7ccc32 100644
2017-12-07 22:44:24 +01:00
--- chrome/browser/ui/BUILD.gn
+++ chrome/browser/ui/BUILD.gn
2019-02-01 17:42:40 +01:00
@@ -362,6 +362,7 @@ jumbo_split_static_library("ui") {
2017-12-07 22:44:24 +01:00
"//base:i18n",
2018-03-20 21:15:08 +01:00
"//base/allocator:buildflags",
2017-12-07 22:44:24 +01:00
"//cc/paint",
+ "//cef/libcef/features",
"//chrome:extra_resources",
"//chrome:resources",
"//chrome:strings",
2019-02-01 20:40:18 +01:00
@@ -2311,7 +2312,7 @@ jumbo_split_static_library("ui") {
2018-09-06 11:29:45 +02:00
"views/frame/native_browser_frame_factory_ozone.cc",
]
} else {
- if (use_aura) {
+ if (use_aura && use_gtk) {
# This is the only component that can interact with gtk.
deps += [ "//chrome/browser/ui/libgtkui" ]
}
2016-07-14 03:35:07 +02:00
diff --git chrome/browser/ui/cocoa/applescript/tab_applescript.mm chrome/browser/ui/cocoa/applescript/tab_applescript.mm
2018-11-03 02:15:09 +01:00
index 71abc5c50e42..20429f93760a 100644
2016-07-14 03:35:07 +02:00
--- chrome/browser/ui/cocoa/applescript/tab_applescript.mm
+++ chrome/browser/ui/cocoa/applescript/tab_applescript.mm
2017-12-07 22:44:24 +01:00
@@ -9,7 +9,7 @@
2016-07-14 03:35:07 +02:00
#include "base/logging.h"
#import "base/mac/scoped_nsobject.h"
#include "base/strings/sys_string_conversions.h"
2016-11-23 21:54:29 +01:00
-#include "chrome/browser/printing/print_view_manager.h"
2017-12-07 22:44:24 +01:00
+#include "cef/libcef/features/features.h"
#include "chrome/browser/profiles/profile.h"
2016-07-14 03:35:07 +02:00
#include "chrome/browser/sessions/session_tab_helper.h"
#include "chrome/browser/ui/cocoa/applescript/apple_event_util.h"
2017-12-07 22:44:24 +01:00
@@ -27,6 +27,10 @@
2016-11-23 21:54:29 +01:00
#include "content/public/browser/web_contents_delegate.h"
#include "url/gurl.h"
2017-12-07 22:44:24 +01:00
+#if !BUILDFLAG(ENABLE_CEF)
2016-11-23 21:54:29 +01:00
+#include "chrome/browser/printing/print_view_manager.h"
+#endif
+
using content::NavigationController;
using content::NavigationEntry;
using content::OpenURLParams;
2018-11-03 02:15:09 +01:00
@@ -234,11 +238,15 @@ void ResumeAppleEventAndSendReply(NSAppleEventManagerSuspensionID suspension_id,
2016-07-14 03:35:07 +02:00
- (void)handlesPrintScriptCommand:(NSScriptCommand*)command {
AppleScript::LogAppleScriptUMA(AppleScript::AppleScriptCommand::TAB_PRINT);
2017-12-07 22:44:24 +01:00
+#if !BUILDFLAG(ENABLE_CEF)
2016-11-23 21:54:29 +01:00
bool initiated = printing::PrintViewManager::FromWebContents(webContents_)
->PrintNow(webContents_->GetMainFrame());
2016-07-14 03:35:07 +02:00
if (!initiated) {
AppleScript::SetError(AppleScript::errInitiatePrinting);
}
+#else
+ NOTIMPLEMENTED();
+#endif
}
- (void)handlesSaveScriptCommand:(NSScriptCommand*)command {
2017-12-07 22:44:24 +01:00
diff --git chrome/browser/ui/webui/settings/printing_handler.cc chrome/browser/ui/webui/settings/printing_handler.cc
2018-10-02 14:14:11 +02:00
index 8647b2daf9ea..b070ab3e4b86 100644
2017-12-07 22:44:24 +01:00
--- chrome/browser/ui/webui/settings/printing_handler.cc
+++ chrome/browser/ui/webui/settings/printing_handler.cc
@@ -6,9 +6,13 @@
#include "base/bind.h"
#include "base/bind_helpers.h"
-#include "chrome/browser/printing/printer_manager_dialog.h"
+#include "cef/libcef/features/features.h"
#include "content/public/browser/web_ui.h"
+#if !BUILDFLAG(ENABLE_CEF)
+#include "chrome/browser/printing/printer_manager_dialog.h"
+#endif
+
namespace settings {
PrintingHandler::PrintingHandler() {}
@@ -27,7 +31,11 @@ void PrintingHandler::OnJavascriptAllowed() {}
void PrintingHandler::OnJavascriptDisallowed() {}
void PrintingHandler::HandleOpenSystemPrintDialog(const base::ListValue* args) {
+#if !BUILDFLAG(ENABLE_CEF)
printing::PrinterManagerDialog::ShowPrinterManagerDialog();
+#else
+ NOTIMPLEMENTED();
+#endif
}
} // namespace settings
2018-03-20 21:15:08 +01:00
diff --git chrome/common/chrome_utility_printing_messages.h chrome/common/chrome_utility_printing_messages.h
2018-10-02 14:14:11 +02:00
index 6bd558079c97..6832bf9f297b 100644
2018-03-20 21:15:08 +01:00
--- chrome/common/chrome_utility_printing_messages.h
+++ chrome/common/chrome_utility_printing_messages.h
@@ -16,7 +16,7 @@
#define IPC_MESSAGE_START ChromeUtilityPrintingMsgStart
-#if defined(OS_WIN) && BUILDFLAG(ENABLE_PRINT_PREVIEW)
+#if defined(OS_WIN)
// Preview and Cloud Print messages.
IPC_STRUCT_TRAITS_BEGIN(printing::PrinterCapsAndDefaults)
IPC_STRUCT_TRAITS_MEMBER(printer_capabilities)
@@ -94,6 +94,6 @@ IPC_MESSAGE_CONTROL1(ChromeUtilityHostMsg_GetPrinterCapsAndDefaults_Failed,
IPC_MESSAGE_CONTROL1(
ChromeUtilityHostMsg_GetPrinterSemanticCapsAndDefaults_Failed,
std::string /* printer name */)
-#endif // defined(OS_WIN) && BUILDFLAG(ENABLE_PRINT_PREVIEW)
+#endif // defined(OS_WIN)
#endif // CHROME_COMMON_CHROME_UTILITY_PRINTING_MESSAGES_H_
diff --git chrome/utility/printing_handler.h chrome/utility/printing_handler.h
2018-10-02 14:14:11 +02:00
index 006966fd1c58..db9cd49af2a4 100644
2018-03-20 21:15:08 +01:00
--- chrome/utility/printing_handler.h
+++ chrome/utility/printing_handler.h
@@ -11,7 +11,7 @@
#include "build/build_config.h"
2018-04-19 17:44:42 +02:00
#include "printing/buildflags/buildflags.h"
2018-03-20 21:15:08 +01:00
-#if !defined(OS_WIN) || !BUILDFLAG(ENABLE_PRINT_PREVIEW)
+#if !defined(OS_WIN)
#error "Windows printing and print preview must be enabled"
#endif
2018-02-15 01:12:09 +01:00
2016-07-14 03:35:07 +02:00
diff --git components/printing/common/print_messages.cc components/printing/common/print_messages.cc
2018-12-26 16:12:11 +01:00
index 528773d80a2f..3355de3884cd 100644
2016-07-14 03:35:07 +02:00
--- components/printing/common/print_messages.cc
+++ components/printing/common/print_messages.cc
2018-12-26 16:12:11 +01:00
@@ -131,7 +131,6 @@ PrintMsg_PrintFrame_Params::PrintMsg_PrintFrame_Params() {}
2018-03-20 21:15:08 +01:00
PrintMsg_PrintFrame_Params::~PrintMsg_PrintFrame_Params() {}
2016-02-02 22:32:44 +01:00
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
PrintHostMsg_RequestPrintPreview_Params::
PrintHostMsg_RequestPrintPreview_Params()
: is_modifiable(false),
2018-12-26 16:12:11 +01:00
@@ -161,4 +160,3 @@ PrintHostMsg_SetOptionsFromDocument_Params::
2016-02-02 22:32:44 +01:00
PrintHostMsg_SetOptionsFromDocument_Params::
~PrintHostMsg_SetOptionsFromDocument_Params() {
}
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-07-14 03:35:07 +02:00
diff --git components/printing/common/print_messages.h components/printing/common/print_messages.h
2019-02-01 20:40:18 +01:00
index 1802034a6e15..ae0d479ecafa 100644
2016-07-14 03:35:07 +02:00
--- components/printing/common/print_messages.h
+++ components/printing/common/print_messages.h
2018-09-04 11:43:21 +02:00
@@ -85,7 +85,6 @@ struct PrintMsg_PrintFrame_Params {
2018-03-20 21:15:08 +01:00
int document_cookie;
2016-02-02 22:32:44 +01:00
};
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
struct PrintHostMsg_RequestPrintPreview_Params {
PrintHostMsg_RequestPrintPreview_Params();
~PrintHostMsg_RequestPrintPreview_Params();
2018-09-04 11:43:21 +02:00
@@ -112,7 +111,6 @@ struct PrintHostMsg_SetOptionsFromDocument_Params {
2016-02-02 22:32:44 +01:00
printing::DuplexMode duplex;
printing::PageRanges page_ranges;
};
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
2017-12-07 22:44:24 +01:00
#endif // INTERNAL_COMPONENTS_PRINTING_COMMON_PRINT_MESSAGES_H_
2016-02-02 22:32:44 +01:00
2018-09-04 11:43:21 +02:00
@@ -211,7 +209,6 @@ IPC_STRUCT_TRAITS_BEGIN(printing::PageRange)
2016-02-02 22:32:44 +01:00
IPC_STRUCT_TRAITS_MEMBER(to)
IPC_STRUCT_TRAITS_END()
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
IPC_STRUCT_TRAITS_BEGIN(PrintHostMsg_RequestPrintPreview_Params)
IPC_STRUCT_TRAITS_MEMBER(is_modifiable)
IPC_STRUCT_TRAITS_MEMBER(webnode_only)
2018-09-04 11:43:21 +02:00
@@ -237,7 +234,6 @@ IPC_STRUCT_TRAITS_BEGIN(PrintHostMsg_SetOptionsFromDocument_Params)
2016-02-02 22:32:44 +01:00
// Specifies page range to be printed.
IPC_STRUCT_TRAITS_MEMBER(page_ranges)
IPC_STRUCT_TRAITS_END()
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
IPC_STRUCT_TRAITS_BEGIN(printing::PageSizeMargins)
IPC_STRUCT_TRAITS_MEMBER(content_width)
2018-10-02 14:14:11 +02:00
@@ -278,7 +274,6 @@ IPC_STRUCT_BEGIN(PrintHostMsg_DidPrintContent_Params)
2018-03-20 21:15:08 +01:00
IPC_STRUCT_MEMBER(printing::ContentToProxyIdMap, subframe_content_info)
IPC_STRUCT_END()
2016-02-02 22:32:44 +01:00
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2018-09-04 11:43:21 +02:00
// Parameters to describe the to-be-rendered preview document.
IPC_STRUCT_BEGIN(PrintHostMsg_DidStartPreview_Params)
// Total page count for the rendered preview. (Not the number of pages the
2018-10-02 14:14:11 +02:00
@@ -321,7 +316,6 @@ IPC_STRUCT_BEGIN(PrintHostMsg_DidPreviewDocument_Params)
2018-09-04 11:43:21 +02:00
// Store the expected pages count.
IPC_STRUCT_MEMBER(int, expected_pages_count)
2016-02-02 22:32:44 +01:00
IPC_STRUCT_END()
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
// Parameters to describe a rendered page.
2018-02-15 01:12:09 +01:00
IPC_STRUCT_BEGIN(PrintHostMsg_DidPrintDocument_Params)
2018-10-02 14:14:11 +02:00
@@ -356,20 +350,18 @@ IPC_STRUCT_END()
2016-02-02 22:32:44 +01:00
// Messages sent from the browser to the renderer.
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
// Tells the RenderFrame to initiate print preview for the entire document.
IPC_MESSAGE_ROUTED1(PrintMsg_InitiatePrintPreview, bool /* has_selection */)
-#endif
2016-02-02 22:32:44 +01:00
2016-11-23 21:54:29 +01:00
// Tells the RenderFrame to initiate printing or print preview for a particular
// node, depending on which mode the RenderFrame is in.
2018-06-19 00:08:20 +02:00
IPC_MESSAGE_ROUTED0(PrintMsg_PrintNodeUnderContextMenu)
-#if BUILDFLAG(ENABLE_PRINTING)
// Tells the RenderFrame to switch the CSS to print media type, renders every
// requested pages and switch back the CSS to display media type.
IPC_MESSAGE_ROUTED0(PrintMsg_PrintPages)
+#if BUILDFLAG(ENABLE_PRINTING)
// Like PrintMsg_PrintPages, but using the print preview document's frame/node.
IPC_MESSAGE_ROUTED0(PrintMsg_PrintForSystemDialog)
#endif
2019-02-01 17:42:40 +01:00
@@ -384,7 +376,6 @@ IPC_MESSAGE_ROUTED1(PrintMsg_PrintingDone,
2016-11-23 21:54:29 +01:00
// Tells the RenderFrame whether printing is enabled or not.
IPC_MESSAGE_ROUTED1(PrintMsg_SetPrintingEnabled, bool /* enabled */)
2016-02-02 22:32:44 +01:00
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
// Tells the RenderFrame to switch the CSS to print media type, renders every
2016-02-02 22:32:44 +01:00
// requested pages for print preview using the given |settings|. This gets
// called multiple times as the user updates settings.
2019-02-01 17:42:40 +01:00
@@ -393,7 +384,6 @@ IPC_MESSAGE_ROUTED1(PrintMsg_PrintPreview,
2016-02-02 22:32:44 +01:00
2017-10-20 19:45:20 +02:00
// Tells the RenderFrame that print preview dialog was closed.
IPC_MESSAGE_ROUTED0(PrintMsg_ClosePrintPreviewDialog)
2019-02-01 17:42:40 +01:00
-#endif
// Messages sent from the renderer to the browser.
2019-02-01 20:40:18 +01:00
@@ -443,7 +433,6 @@ IPC_SYNC_MESSAGE_ROUTED1_1(PrintHostMsg_ScriptedPrint,
PrintMsg_PrintPages_Params
/* settings chosen by the user*/)
2016-02-02 22:32:44 +01:00
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
// Asks the browser to do print preview.
IPC_MESSAGE_ROUTED1(PrintHostMsg_RequestPrintPreview,
PrintHostMsg_RequestPrintPreview_Params /* params */)
2019-02-01 20:40:18 +01:00
@@ -480,7 +469,6 @@ IPC_SYNC_MESSAGE_ROUTED1_1(PrintHostMsg_CheckForCancel,
2018-06-19 00:08:20 +02:00
IPC_MESSAGE_ROUTED2(PrintHostMsg_MetafileReadyForPrinting,
PrintHostMsg_DidPreviewDocument_Params /* params */,
PrintHostMsg_PreviewIds /* ids */)
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
// This is sent when there are invalid printer settings.
IPC_MESSAGE_ROUTED0(PrintHostMsg_ShowInvalidPrinterSettingsError)
2019-02-01 20:40:18 +01:00
@@ -489,7 +477,6 @@ IPC_MESSAGE_ROUTED0(PrintHostMsg_ShowInvalidPrinterSettingsError)
2016-02-02 22:32:44 +01:00
IPC_MESSAGE_ROUTED1(PrintHostMsg_PrintingFailed,
int /* document cookie */)
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
// Tell the browser print preview failed.
2018-06-19 00:08:20 +02:00
IPC_MESSAGE_ROUTED2(PrintHostMsg_PrintPreviewFailed,
int /* document cookie */,
2019-02-01 20:40:18 +01:00
@@ -520,6 +507,5 @@ IPC_MESSAGE_ROUTED1(PrintHostMsg_ShowScriptedPrintPreview,
2018-06-19 00:08:20 +02:00
IPC_MESSAGE_ROUTED2(PrintHostMsg_SetOptionsFromDocument,
PrintHostMsg_SetOptionsFromDocument_Params /* params */,
PrintHostMsg_PreviewIds /* ids */)
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2017-12-07 22:44:24 +01:00
#endif // COMPONENTS_PRINTING_COMMON_PRINT_MESSAGES_H_
2017-09-06 23:40:58 +02:00
diff --git components/printing/renderer/print_render_frame_helper.cc components/printing/renderer/print_render_frame_helper.cc
2019-02-01 20:40:18 +01:00
index cd9306860bba..3b7b505aff73 100644
2017-09-06 23:40:58 +02:00
--- components/printing/renderer/print_render_frame_helper.cc
+++ components/printing/renderer/print_render_frame_helper.cc
2019-02-01 17:42:40 +01:00
@@ -351,7 +351,6 @@ bool IsPrintingFrameset(const blink::WebLocalFrame* frame) {
frame->GetDocument().Body().TagName().Equals("FRAMESET");
2016-02-02 22:32:44 +01:00
}
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
// Returns true if the current destination printer is PRINT_TO_PDF.
bool IsPrintToPdfRequested(const base::DictionaryValue& job_settings) {
bool print_to_pdf = false;
2019-02-01 17:42:40 +01:00
@@ -373,7 +372,6 @@ bool PrintingFrameHasPageSizeStyle(blink::WebLocalFrame* frame,
2016-02-02 22:32:44 +01:00
}
return frame_has_custom_page_size_style;
}
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
2017-01-23 18:36:54 +01:00
#if BUILDFLAG(ENABLE_PRINTING)
2016-02-02 22:32:44 +01:00
// Disable scaling when either:
2019-02-01 17:42:40 +01:00
@@ -428,7 +426,6 @@ MarginType GetMarginsForPdf(blink::WebLocalFrame* frame,
2018-05-14 13:24:05 +02:00
: PRINTABLE_AREA_MARGINS;
2016-02-02 22:32:44 +01:00
}
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2018-10-02 14:14:11 +02:00
gfx::Size GetPdfPageSize(const gfx::Size& page_size, int dpi) {
return gfx::Size(ConvertUnit(page_size.width(), dpi, kPointsPerInch),
ConvertUnit(page_size.height(), dpi, kPointsPerInch));
2019-02-01 17:42:40 +01:00
@@ -475,7 +472,6 @@ blink::WebPrintScalingOption GetPrintScalingOption(
2016-02-02 22:32:44 +01:00
}
2017-04-20 21:28:17 +02:00
return blink::kWebPrintScalingOptionFitToPrintableArea;
2016-02-02 22:32:44 +01:00
}
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
2016-11-23 21:54:29 +01:00
// Helper function to scale and round an integer value with a double valued
// scaling.
2019-02-01 17:42:40 +01:00
@@ -1106,10 +1102,8 @@ void PrintRenderFrameHelper::ScriptedPrint(bool user_initiated) {
2016-02-02 22:32:44 +01:00
return;
if (g_is_preview_enabled) {
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
print_preview_context_.InitWithFrame(web_frame);
2016-02-02 22:32:44 +01:00
RequestPrintPreview(PRINT_PREVIEW_SCRIPTED);
-#endif
} else {
2017-10-20 19:45:20 +02:00
auto weak_this = weak_ptr_factory_.GetWeakPtr();
2018-05-14 13:24:05 +02:00
web_frame->DispatchBeforePrintEvent();
2019-02-01 17:42:40 +01:00
@@ -1137,13 +1131,11 @@ bool PrintRenderFrameHelper::OnMessageReceived(const IPC::Message& message) {
2018-05-14 13:24:05 +02:00
IPC_BEGIN_MESSAGE_MAP(PrintRenderFrameHelper, message)
2016-02-02 22:32:44 +01:00
IPC_MESSAGE_HANDLER(PrintMsg_PrintPages, OnPrintPages)
IPC_MESSAGE_HANDLER(PrintMsg_PrintForSystemDialog, OnPrintForSystemDialog)
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
IPC_MESSAGE_HANDLER(PrintMsg_InitiatePrintPreview, OnInitiatePrintPreview)
IPC_MESSAGE_HANDLER(PrintMsg_PrintPreview, OnPrintPreview)
IPC_MESSAGE_HANDLER(PrintMsg_PrintingDone, OnPrintingDone)
2017-10-20 19:45:20 +02:00
IPC_MESSAGE_HANDLER(PrintMsg_ClosePrintPreviewDialog,
OnClosePrintPreviewDialog)
2019-02-01 17:42:40 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
IPC_MESSAGE_HANDLER(PrintMsg_PrintFrameContent, OnPrintFrameContent)
IPC_MESSAGE_HANDLER(PrintMsg_SetPrintingEnabled, OnSetPrintingEnabled)
IPC_MESSAGE_UNHANDLED(handled = false)
@@ -1223,7 +1215,6 @@ void PrintRenderFrameHelper::UpdateFrameMarginsCssInfo(
2016-02-02 22:32:44 +01:00
ignore_css_margins_ = (margins_type != DEFAULT_MARGINS);
}
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2017-09-06 23:40:58 +02:00
void PrintRenderFrameHelper::OnPrintPreview(
const base::DictionaryValue& settings) {
2016-02-02 22:32:44 +01:00
if (ipc_nesting_level_ > 1)
2019-02-01 17:42:40 +01:00
@@ -1489,7 +1480,6 @@ int PrintRenderFrameHelper::GetFitToPageScaleFactor(
2018-07-24 00:32:02 +02:00
printable_height / static_cast<double>(uniform_page_size.height);
return static_cast<int>(100.0f * std::min(scale_width, scale_height));
2016-02-02 22:32:44 +01:00
}
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
2017-09-06 23:40:58 +02:00
void PrintRenderFrameHelper::OnPrintingDone(bool success) {
2016-02-02 22:32:44 +01:00
if (ipc_nesting_level_ > 1)
2019-02-01 17:42:40 +01:00
@@ -1504,7 +1494,6 @@ void PrintRenderFrameHelper::OnSetPrintingEnabled(bool enabled) {
2016-11-23 21:54:29 +01:00
is_printing_enabled_ = enabled;
2016-02-02 22:32:44 +01:00
}
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2017-09-06 23:40:58 +02:00
void PrintRenderFrameHelper::OnInitiatePrintPreview(bool has_selection) {
2016-02-02 22:32:44 +01:00
if (ipc_nesting_level_ > 1)
return;
2019-02-01 17:42:40 +01:00
@@ -1515,7 +1504,9 @@ void PrintRenderFrameHelper::OnInitiatePrintPreview(bool has_selection) {
2015-07-24 02:06:56 +02:00
// that instead.
auto plugin = delegate_->GetPdfElement(frame);
2017-04-20 21:28:17 +02:00
if (!plugin.IsNull()) {
2015-07-24 02:06:56 +02:00
+ force_print_preview_ = true;
PrintNode(plugin);
+ force_print_preview_ = false;
return;
}
print_preview_context_.InitWithFrame(frame);
2019-02-01 17:42:40 +01:00
@@ -1527,7 +1518,6 @@ void PrintRenderFrameHelper::OnInitiatePrintPreview(bool has_selection) {
2017-10-20 19:45:20 +02:00
void PrintRenderFrameHelper::OnClosePrintPreviewDialog() {
print_preview_context_.source_frame()->DispatchAfterPrintEvent();
}
2019-02-01 17:42:40 +01:00
-#endif
void PrintRenderFrameHelper::OnPrintFrameContent(
const PrintMsg_PrintFrame_Params& params) {
@@ -1611,11 +1601,9 @@ void PrintRenderFrameHelper::PrintNode(const blink::WebNode& node) {
2017-01-23 18:36:54 +01:00
print_node_in_progress_ = true;
2015-07-24 02:06:56 +02:00
2016-02-02 22:32:44 +01:00
- if (g_is_preview_enabled) {
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
+ if (g_is_preview_enabled || force_print_preview_) {
print_preview_context_.InitWithNode(node);
RequestPrintPreview(PRINT_PREVIEW_USER_INITIATED_CONTEXT_NODE);
-#endif
2015-07-24 02:06:56 +02:00
} else {
2017-01-23 18:36:54 +01:00
// Make a copy of the node, in case RenderView::OnContextMenuClosed() resets
2018-05-14 13:24:05 +02:00
// its |context_menu_node_|.
2019-02-01 17:42:40 +01:00
@@ -1696,13 +1684,11 @@ void PrintRenderFrameHelper::Print(blink::WebLocalFrame* frame,
2018-06-19 00:08:20 +02:00
void PrintRenderFrameHelper::DidFinishPrinting(PrintingResult result) {
int cookie =
print_pages_params_ ? print_pages_params_->params.document_cookie : 0;
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
PrintHostMsg_PreviewIds ids;
if (print_pages_params_) {
ids.ui_id = print_pages_params_->params.preview_ui_id;
ids.request_id = print_pages_params_->params.preview_request_id;
}
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
switch (result) {
case OK:
break;
2019-02-01 17:42:40 +01:00
@@ -1717,7 +1703,6 @@ void PrintRenderFrameHelper::DidFinishPrinting(PrintingResult result) {
2016-02-02 22:32:44 +01:00
}
break;
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
case FAIL_PREVIEW:
2017-07-27 01:19:27 +02:00
if (!is_print_ready_metafile_sent_) {
if (notify_browser_of_print_failure_) {
2019-02-01 17:42:40 +01:00
@@ -1735,7 +1720,6 @@ void PrintRenderFrameHelper::DidFinishPrinting(PrintingResult result) {
2018-06-19 00:08:20 +02:00
cookie, ids));
2017-07-27 01:19:27 +02:00
print_preview_context_.Failed(false);
2016-02-02 22:32:44 +01:00
break;
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
}
prep_frame_view_.reset();
print_pages_params_.reset();
2019-02-01 20:40:18 +01:00
@@ -1908,7 +1892,6 @@ bool PrintRenderFrameHelper::CalculateNumberOfPages(blink::WebLocalFrame* frame,
2016-02-02 22:32:44 +01:00
return true;
}
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2017-09-06 23:40:58 +02:00
bool PrintRenderFrameHelper::SetOptionsFromPdfDocument(
2016-02-02 22:32:44 +01:00
PrintHostMsg_SetOptionsFromDocument_Params* options) {
blink::WebLocalFrame* source_frame = print_preview_context_.source_frame();
2019-02-01 20:40:18 +01:00
@@ -2001,7 +1984,6 @@ bool PrintRenderFrameHelper::UpdatePrintSettings(
2018-02-15 01:12:09 +01:00
print_preview_context_.set_error(PREVIEW_ERROR_INVALID_PRINTER_SETTINGS);
2017-01-23 18:36:54 +01:00
return false;
2016-02-02 22:32:44 +01:00
}
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
2017-09-06 23:40:58 +02:00
void PrintRenderFrameHelper::GetPrintSettingsFromUser(
2018-05-14 13:24:05 +02:00
blink::WebLocalFrame* frame,
2019-02-01 20:40:18 +01:00
@@ -2153,7 +2135,6 @@ bool PrintRenderFrameHelper::CopyMetafileDataToReadOnlySharedMem(
2016-03-16 03:55:59 +01:00
return true;
2016-02-02 22:32:44 +01:00
}
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2017-09-06 23:40:58 +02:00
void PrintRenderFrameHelper::ShowScriptedPrintPreview() {
2016-02-02 22:32:44 +01:00
if (is_scripted_preview_delayed_) {
is_scripted_preview_delayed_ = false;
2019-02-01 20:40:18 +01:00
@@ -2279,7 +2260,6 @@ bool PrintRenderFrameHelper::PreviewPageRendered(
2018-06-19 00:08:20 +02:00
Send(new PrintHostMsg_DidPreviewPage(routing_id(), preview_page_params, ids));
2016-02-02 22:32:44 +01:00
return true;
}
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
2018-07-31 21:21:39 +02:00
PrintRenderFrameHelper::PrintPreviewContext::PrintPreviewContext() = default;
2017-09-06 23:40:58 +02:00
diff --git components/printing/renderer/print_render_frame_helper.h components/printing/renderer/print_render_frame_helper.h
2019-02-01 17:42:40 +01:00
index 34690801675c..bb503ad7f849 100644
2017-09-06 23:40:58 +02:00
--- components/printing/renderer/print_render_frame_helper.h
+++ components/printing/renderer/print_render_frame_helper.h
2018-09-04 11:43:21 +02:00
@@ -150,10 +150,8 @@ class PrintRenderFrameHelper
2016-02-02 22:32:44 +01:00
OK,
FAIL_PRINT_INIT,
FAIL_PRINT,
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
FAIL_PREVIEW,
2017-07-27 01:19:27 +02:00
INVALID_SETTINGS,
2016-02-02 22:32:44 +01:00
-#endif
};
2018-03-20 21:15:08 +01:00
// These values are persisted to logs. Entries should not be renumbered and
2019-02-01 17:42:40 +01:00
@@ -194,11 +192,9 @@ class PrintRenderFrameHelper
2018-05-14 13:24:05 +02:00
// Message handlers ---------------------------------------------------------
2018-02-15 01:12:09 +01:00
void OnPrintPages();
2016-02-02 22:32:44 +01:00
void OnPrintForSystemDialog();
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
void OnInitiatePrintPreview(bool has_selection);
2016-02-02 22:32:44 +01:00
void OnPrintPreview(const base::DictionaryValue& settings);
2017-10-20 19:45:20 +02:00
void OnClosePrintPreviewDialog();
2019-02-01 17:42:40 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2018-03-20 21:15:08 +01:00
void OnPrintFrameContent(const PrintMsg_PrintFrame_Params& params);
2019-02-01 17:42:40 +01:00
void OnPrintingDone(bool success);
@@ -212,7 +208,6 @@ class PrintRenderFrameHelper
2016-02-02 22:32:44 +01:00
// Update |ignore_css_margins_| based on settings.
void UpdateFrameMarginsCssInfo(const base::DictionaryValue& settings);
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
// Prepare frame for creating preview document.
void PrepareFrameForPreviewDocument();
2019-02-01 17:42:40 +01:00
@@ -232,7 +227,6 @@ class PrintRenderFrameHelper
2016-02-02 22:32:44 +01:00
2018-07-24 00:32:02 +02:00
// Helper method to calculate the scale factor for fit-to-page.
int GetFitToPageScaleFactor(const gfx::Rect& printable_area_in_points);
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
2016-11-23 21:54:29 +01:00
// Enable/Disable printing.
void OnSetPrintingEnabled(bool enabled);
2019-02-01 17:42:40 +01:00
@@ -259,7 +253,6 @@ class PrintRenderFrameHelper
2016-02-02 22:32:44 +01:00
const blink::WebNode& node,
int* number_of_pages);
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
// Set options for print preset from source PDF document.
bool SetOptionsFromPdfDocument(
PrintHostMsg_SetOptionsFromDocument_Params* options);
2019-02-01 17:42:40 +01:00
@@ -270,7 +263,6 @@ class PrintRenderFrameHelper
2016-02-02 22:32:44 +01:00
bool UpdatePrintSettings(blink::WebLocalFrame* frame,
const blink::WebNode& node,
const base::DictionaryValue& passed_job_settings);
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
// Get final print settings from the user.
2018-05-14 13:24:05 +02:00
// WARNING: |this| may be gone after this method returns.
2019-02-01 17:42:40 +01:00
@@ -352,7 +344,6 @@ class PrintRenderFrameHelper
2017-01-23 18:36:54 +01:00
bool IsScriptInitiatedPrintAllowed(blink::WebLocalFrame* frame,
2016-02-02 22:32:44 +01:00
bool user_initiated);
2016-11-23 21:54:29 +01:00
-#if BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
// Shows scripted print preview when options from plugin are available.
void ShowScriptedPrintPreview();
2019-02-01 17:42:40 +01:00
@@ -371,7 +362,6 @@ class PrintRenderFrameHelper
2016-02-02 22:32:44 +01:00
// Returns true if print preview should continue, false on failure.
2018-03-20 21:15:08 +01:00
bool PreviewPageRendered(int page_number,
2018-09-04 11:43:21 +02:00
std::unique_ptr<MetafileSkia> metafile);
2016-11-23 21:54:29 +01:00
-#endif // BUILDFLAG(ENABLE_PRINT_PREVIEW)
2016-02-02 22:32:44 +01:00
void SetPrintPagesParams(const PrintMsg_PrintPages_Params& settings);
2019-02-01 17:42:40 +01:00
@@ -526,6 +516,7 @@ class PrintRenderFrameHelper
2015-07-24 02:06:56 +02:00
ScriptingThrottler scripting_throttler_;
2018-07-31 21:21:39 +02:00
bool print_node_in_progress_ = false;
+ bool force_print_preview_ = false;
2015-07-24 02:06:56 +02:00
PrintPreviewContext print_preview_context_;
2018-07-31 21:21:39 +02:00
bool is_loading_ = false;
bool is_scripted_preview_delayed_ = false;
2018-06-01 21:16:26 +02:00
diff --git components/printing_component_strings.grdp components/printing_component_strings.grdp
2018-10-02 14:14:11 +02:00
index f157cbaec42e..5e3c3caa2aa2 100644
2018-06-01 21:16:26 +02:00
--- components/printing_component_strings.grdp
+++ components/printing_component_strings.grdp
2018-04-19 17:44:42 +02:00
@@ -1,10 +1,8 @@
<?xml version="1.0" encoding="utf-8"?>
<grit-part>
- <if expr="enable_print_preview">
<if expr="is_win">
<message name="IDS_PRINT_PREVIEW_FRIENDLY_WIN_NETWORK_PRINTER_NAME" desc="Friendly name for a printer with a given name on a given server. This uses the same format as the Windows print dialog.">
<ph name="PRINTER_NAME">$1<ex>HP LaserJet</ex></ph> on <ph name="SERVER_NAME">$2<ex>printserver</ex></ph>
</message>
</if>
- </if>
</grit-part>
2018-03-20 21:15:08 +01:00
diff --git components/pwg_encoder/BUILD.gn components/pwg_encoder/BUILD.gn
2018-10-02 14:14:11 +02:00
index 96ae254116a9..3697d6034300 100644
2018-03-20 21:15:08 +01:00
--- components/pwg_encoder/BUILD.gn
+++ components/pwg_encoder/BUILD.gn
@@ -4,8 +4,6 @@
2018-04-19 17:44:42 +02:00
import("//printing/buildflags/buildflags.gni")
2018-03-20 21:15:08 +01:00
-assert(enable_print_preview)
-
static_library("pwg_encoder") {
sources = [
"bitmap_image.cc",