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

Side by Side Diff: chrome/browser/ui/webui/print_preview/print_preview_handler.cc

Issue 1125343004: Add a "Simplify Page" option to the print preview dialog (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Update AUTHORS file to reflect the correct HP name used in the CLA Created 5 years, 7 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/webui/print_preview/print_preview_handler.h" 5 #include "chrome/browser/ui/webui/print_preview/print_preview_handler.h"
6 6
7 #include <ctype.h> 7 #include <ctype.h>
8 8
9 #include <map> 9 #include <map>
10 #include <string> 10 #include <string>
(...skipping 12 matching lines...) Expand all
23 #include "base/path_service.h" 23 #include "base/path_service.h"
24 #include "base/prefs/pref_service.h" 24 #include "base/prefs/pref_service.h"
25 #include "base/strings/string_number_conversions.h" 25 #include "base/strings/string_number_conversions.h"
26 #include "base/strings/stringprintf.h" 26 #include "base/strings/stringprintf.h"
27 #include "base/strings/utf_string_conversions.h" 27 #include "base/strings/utf_string_conversions.h"
28 #include "base/threading/thread.h" 28 #include "base/threading/thread.h"
29 #include "base/threading/thread_restrictions.h" 29 #include "base/threading/thread_restrictions.h"
30 #include "base/values.h" 30 #include "base/values.h"
31 #include "chrome/browser/app_mode/app_mode_utils.h" 31 #include "chrome/browser/app_mode/app_mode_utils.h"
32 #include "chrome/browser/browser_process.h" 32 #include "chrome/browser/browser_process.h"
33 #include "chrome/browser/dom_distiller/tab_utils.h"
33 #include "chrome/browser/platform_util.h" 34 #include "chrome/browser/platform_util.h"
34 #include "chrome/browser/printing/print_dialog_cloud.h" 35 #include "chrome/browser/printing/print_dialog_cloud.h"
35 #include "chrome/browser/printing/print_error_dialog.h" 36 #include "chrome/browser/printing/print_error_dialog.h"
36 #include "chrome/browser/printing/print_job_manager.h" 37 #include "chrome/browser/printing/print_job_manager.h"
37 #include "chrome/browser/printing/print_preview_dialog_controller.h" 38 #include "chrome/browser/printing/print_preview_dialog_controller.h"
38 #include "chrome/browser/printing/print_view_manager.h" 39 #include "chrome/browser/printing/print_view_manager.h"
39 #include "chrome/browser/printing/printer_manager_dialog.h" 40 #include "chrome/browser/printing/printer_manager_dialog.h"
40 #include "chrome/browser/profiles/profile.h" 41 #include "chrome/browser/profiles/profile.h"
41 #include "chrome/browser/signin/gaia_cookie_manager_service_factory.h" 42 #include "chrome/browser/signin/gaia_cookie_manager_service_factory.h"
42 #include "chrome/browser/signin/profile_oauth2_token_service_factory.h" 43 #include "chrome/browser/signin/profile_oauth2_token_service_factory.h"
43 #include "chrome/browser/signin/signin_manager_factory.h" 44 #include "chrome/browser/signin/signin_manager_factory.h"
44 #include "chrome/browser/ui/browser_finder.h" 45 #include "chrome/browser/ui/browser_finder.h"
45 #include "chrome/browser/ui/browser_tabstrip.h" 46 #include "chrome/browser/ui/browser_tabstrip.h"
46 #include "chrome/browser/ui/chrome_select_file_policy.h" 47 #include "chrome/browser/ui/chrome_select_file_policy.h"
47 #include "chrome/browser/ui/scoped_tabbed_browser_displayer.h" 48 #include "chrome/browser/ui/scoped_tabbed_browser_displayer.h"
48 #include "chrome/browser/ui/webui/print_preview/print_preview_ui.h" 49 #include "chrome/browser/ui/webui/print_preview/print_preview_ui.h"
49 #include "chrome/browser/ui/webui/print_preview/printer_handler.h" 50 #include "chrome/browser/ui/webui/print_preview/printer_handler.h"
50 #include "chrome/browser/ui/webui/print_preview/sticky_settings.h" 51 #include "chrome/browser/ui/webui/print_preview/sticky_settings.h"
51 #include "chrome/common/chrome_paths.h" 52 #include "chrome/common/chrome_paths.h"
52 #include "chrome/common/chrome_switches.h" 53 #include "chrome/common/chrome_switches.h"
53 #include "chrome/common/cloud_print/cloud_print_cdd_conversion.h" 54 #include "chrome/common/cloud_print/cloud_print_cdd_conversion.h"
54 #include "chrome/common/cloud_print/cloud_print_constants.h" 55 #include "chrome/common/cloud_print/cloud_print_constants.h"
55 #include "chrome/common/crash_keys.h" 56 #include "chrome/common/crash_keys.h"
56 #include "chrome/common/pref_names.h" 57 #include "chrome/common/pref_names.h"
57 #include "components/cloud_devices/common/cloud_device_description.h" 58 #include "components/cloud_devices/common/cloud_device_description.h"
58 #include "components/cloud_devices/common/cloud_devices_urls.h" 59 #include "components/cloud_devices/common/cloud_devices_urls.h"
59 #include "components/cloud_devices/common/printer_description.h" 60 #include "components/cloud_devices/common/printer_description.h"
61 #include "components/dom_distiller/core/url_utils.h"
60 #include "components/printing/common/print_messages.h" 62 #include "components/printing/common/print_messages.h"
61 #include "components/signin/core/browser/gaia_cookie_manager_service.h" 63 #include "components/signin/core/browser/gaia_cookie_manager_service.h"
62 #include "components/signin/core/browser/profile_oauth2_token_service.h" 64 #include "components/signin/core/browser/profile_oauth2_token_service.h"
63 #include "components/signin/core/browser/signin_manager.h" 65 #include "components/signin/core/browser/signin_manager.h"
64 #include "components/signin/core/common/profile_management_switches.h" 66 #include "components/signin/core/common/profile_management_switches.h"
65 #include "content/public/browser/browser_context.h" 67 #include "content/public/browser/browser_context.h"
66 #include "content/public/browser/browser_thread.h" 68 #include "content/public/browser/browser_thread.h"
67 #include "content/public/browser/navigation_controller.h" 69 #include "content/public/browser/navigation_controller.h"
68 #include "content/public/browser/navigation_entry.h" 70 #include "content/public/browser/navigation_entry.h"
69 #include "content/public/browser/render_process_host.h" 71 #include "content/public/browser/render_process_host.h"
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after
158 // Dictionary field to indicate whether Chrome is running in forced app (app 160 // Dictionary field to indicate whether Chrome is running in forced app (app
159 // kiosk) mode. It's not the same as desktop Chrome kiosk (the one above). 161 // kiosk) mode. It's not the same as desktop Chrome kiosk (the one above).
160 const char kAppKioskMode[] = "appKioskMode"; 162 const char kAppKioskMode[] = "appKioskMode";
161 // Dictionary field to store Cloud Print base URL. 163 // Dictionary field to store Cloud Print base URL.
162 const char kCloudPrintUrl[] = "cloudPrintUrl"; 164 const char kCloudPrintUrl[] = "cloudPrintUrl";
163 #if defined(OS_WIN) 165 #if defined(OS_WIN)
164 const char kHidePrintWithSystemDialogLink[] = "hidePrintWithSystemDialogLink"; 166 const char kHidePrintWithSystemDialogLink[] = "hidePrintWithSystemDialogLink";
165 #endif 167 #endif
166 // Name of a dictionary field holding the state of selection for document. 168 // Name of a dictionary field holding the state of selection for document.
167 const char kDocumentHasSelection[] = "documentHasSelection"; 169 const char kDocumentHasSelection[] = "documentHasSelection";
170 // Dictionary field indicating whether to simplify the page.
171 const char kPrintFriendlyEnabled[] = "printFriendlyEnabled";
168 172
169 // Id of the predefined PDF printer. 173 // Id of the predefined PDF printer.
170 const char kLocalPdfPrinterId[] = "Save as PDF"; 174 const char kLocalPdfPrinterId[] = "Save as PDF";
171 175
172 // Additional printer capability setting keys. 176 // Additional printer capability setting keys.
173 const char kPrinterId[] = "printerId"; 177 const char kPrinterId[] = "printerId";
174 const char kPrinterCapabilities[] = "capabilities"; 178 const char kPrinterCapabilities[] = "capabilities";
175 179
176 // Get the print job settings dictionary from |args|. The caller takes 180 // Get the print job settings dictionary from |args|. The caller takes
177 // ownership of the returned DictionaryValue. Returns NULL on failure. 181 // ownership of the returned DictionaryValue. Returns NULL on failure.
(...skipping 638 matching lines...) Expand 10 before | Expand all | Expand 10 after
816 success = args->GetBoolean(2, &preview_modifiable); 820 success = args->GetBoolean(2, &preview_modifiable);
817 DCHECK(success); 821 DCHECK(success);
818 822
819 if (draft_page_count != -1 && preview_modifiable && 823 if (draft_page_count != -1 && preview_modifiable &&
820 print_preview_ui()->GetAvailableDraftPageCount() != draft_page_count) { 824 print_preview_ui()->GetAvailableDraftPageCount() != draft_page_count) {
821 settings->SetBoolean(printing::kSettingGenerateDraftData, true); 825 settings->SetBoolean(printing::kSettingGenerateDraftData, true);
822 } 826 }
823 } 827 }
824 828
825 VLOG(1) << "Print preview request start"; 829 VLOG(1) << "Print preview request start";
826 RenderViewHost* rvh = initiator->GetRenderViewHost(); 830
827 rvh->Send(new PrintMsg_PrintPreview(rvh->GetRoutingID(), *settings)); 831 bool print_friendly = false;
832 if (!settings->GetBoolean(printing::kSettingPrintFriendlyEnabled,
833 &print_friendly)) {
834 NOTREACHED();
835 }
836
837 if (print_friendly) {
838 if (!hidden_print_preview_)
839 MaybeStartDistillation(initiator);
nyquist 2015/05/13 07:56:38 Could this be simplified by using the new DistillA
arjunpatel 2015/05/27 00:16:45 Yes, depending on whether or not we keep the synch
840
841 hidden_print_preview_.reset(
842 new HiddenPrintPreview(initiator, print_preview_ui()));
843 hidden_print_preview_->SetSettings(settings.Pass());
844 } else {
845 RenderViewHost* rvh = initiator->GetRenderViewHost();
846 rvh->Send(new PrintMsg_PrintPreview(rvh->GetRoutingID(), *settings));
847 }
828 } 848 }
829 849
830 void PrintPreviewHandler::HandlePrint(const base::ListValue* args) { 850 void PrintPreviewHandler::HandlePrint(const base::ListValue* args) {
831 ReportStats(); 851 ReportStats();
832 852
833 // Record the number of times the user requests to regenerate preview data 853 // Record the number of times the user requests to regenerate preview data
834 // before printing. 854 // before printing.
835 UMA_HISTOGRAM_COUNTS("PrintPreview.RegeneratePreviewRequest.BeforePrint", 855 UMA_HISTOGRAM_COUNTS("PrintPreview.RegeneratePreviewRequest.BeforePrint",
836 regenerate_preview_request_count_); 856 regenerate_preview_request_count_);
837 857
(...skipping 392 matching lines...) Expand 10 before | Expand all | Expand 10 after
1230 initial_settings.SetBoolean(kAppKioskMode, 1250 initial_settings.SetBoolean(kAppKioskMode,
1231 chrome::IsRunningInForcedAppMode()); 1251 chrome::IsRunningInForcedAppMode());
1232 #if defined(OS_WIN) 1252 #if defined(OS_WIN)
1233 // In Win8 metro, the system print dialog can only open on the desktop. Doing 1253 // In Win8 metro, the system print dialog can only open on the desktop. Doing
1234 // so will cause the browser to appear hung, so we don't show the link in 1254 // so will cause the browser to appear hung, so we don't show the link in
1235 // metro. 1255 // metro.
1236 bool is_ash = (chrome::GetActiveDesktop() == chrome::HOST_DESKTOP_TYPE_ASH); 1256 bool is_ash = (chrome::GetActiveDesktop() == chrome::HOST_DESKTOP_TYPE_ASH);
1237 initial_settings.SetBoolean(kHidePrintWithSystemDialogLink, is_ash); 1257 initial_settings.SetBoolean(kHidePrintWithSystemDialogLink, is_ash);
1238 #endif 1258 #endif
1239 1259
1260 WebContents* initiator = GetInitiator();
1261 bool can_simplify = false;
1262 if (initiator) {
1263 can_simplify = cmdline->HasSwitch(switches::kEnableDomDistiller) &&
nyquist 2015/05/13 07:56:38 Should this also check to see if we assume that th
arjunpatel 2015/05/27 17:10:11 The latest version of the CL does this, showing th
1264 dom_distiller::url_utils::IsUrlDistillable(
1265 initiator->GetLastCommittedURL());
1266 }
1267 initial_settings.SetBoolean(kPrintFriendlyEnabled, can_simplify);
1268
1240 if (print_preview_ui()->source_is_modifiable()) 1269 if (print_preview_ui()->source_is_modifiable())
1241 GetNumberFormatAndMeasurementSystem(&initial_settings); 1270 GetNumberFormatAndMeasurementSystem(&initial_settings);
1242 web_ui()->CallJavascriptFunction("setInitialSettings", initial_settings); 1271 web_ui()->CallJavascriptFunction("setInitialSettings", initial_settings);
1243 } 1272 }
1244 1273
1245 void PrintPreviewHandler::ClosePreviewDialog() { 1274 void PrintPreviewHandler::ClosePreviewDialog() {
1246 print_preview_ui()->OnClosePrintPreviewDialog(); 1275 print_preview_ui()->OnClosePrintPreviewDialog();
1247 } 1276 }
1248 1277
1249 void PrintPreviewHandler::SendAccessToken(const std::string& type, 1278 void PrintPreviewHandler::SendAccessToken(const std::string& type,
(...skipping 486 matching lines...) Expand 10 before | Expand all | Expand 10 after
1736 1765
1737 void PrintPreviewHandler::UnregisterForGaiaCookieChanges() { 1766 void PrintPreviewHandler::UnregisterForGaiaCookieChanges() {
1738 if (gaia_cookie_manager_service_) 1767 if (gaia_cookie_manager_service_)
1739 gaia_cookie_manager_service_->RemoveObserver(this); 1768 gaia_cookie_manager_service_->RemoveObserver(this);
1740 } 1769 }
1741 1770
1742 void PrintPreviewHandler::SetPdfSavedClosureForTesting( 1771 void PrintPreviewHandler::SetPdfSavedClosureForTesting(
1743 const base::Closure& closure) { 1772 const base::Closure& closure) {
1744 pdf_file_saved_closure_ = closure; 1773 pdf_file_saved_closure_ = closure;
1745 } 1774 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698