blob: f7491dd13b23c9e3d2191c966d6a1ab8f8dca737 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
|
// 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.
#ifndef CHROME_BROWSER_UI_WEBUI_PRINT_PREVIEW_HANDLER_H_
#define CHROME_BROWSER_UI_WEBUI_PRINT_PREVIEW_HANDLER_H_
#pragma once
#include <string>
#include "base/memory/ref_counted.h"
#include "base/memory/scoped_ptr.h"
#include "base/memory/weak_ptr.h"
#include "build/build_config.h"
#include "chrome/browser/printing/print_view_manager_observer.h"
#include "chrome/browser/ui/shell_dialogs.h"
#include "content/browser/webui/web_ui.h"
#include "printing/print_job_constants.h"
class FilePath;
class PrintSystemTaskProxy;
class TabContentsWrapper;
namespace base {
class DictionaryValue;
class FundamentalValue;
class StringValue;
}
namespace printing {
class PrintBackend;
}
// The handler for Javascript messages related to the print preview dialog.
class PrintPreviewHandler : public WebUIMessageHandler,
public base::SupportsWeakPtr<PrintPreviewHandler>,
public SelectFileDialog::Listener,
public printing::PrintViewManagerObserver {
public:
PrintPreviewHandler();
virtual ~PrintPreviewHandler();
// WebUIMessageHandler implementation.
virtual void RegisterMessages() OVERRIDE;
// SelectFileDialog::Listener implementation.
virtual void FileSelected(const FilePath& path,
int index,
void* params) OVERRIDE;
virtual void FileSelectionCanceled(void* params) OVERRIDE;
// PrintViewManagerObserver implementation.
virtual void OnPrintDialogShown() OVERRIDE;
// Displays a modal dialog, prompting the user to select a file.
void SelectFile(const FilePath& default_path);
// Called when the print preview tab is destroyed. This is the last time
// this object has access to the PrintViewManager in order to disconnect the
// observer.
void OnTabDestroyed();
// Called when print preview failed.
void OnPrintPreviewFailed();
// Called when the user press ctrl+shift+p to display the native system
// dialog.
void ShowSystemDialog();
private:
friend class PrintSystemTaskProxy;
TabContentsWrapper* preview_tab_wrapper() const;
TabContents* preview_tab() const;
// Gets the default printer. |args| is unused.
void HandleGetDefaultPrinter(const base::ListValue* args);
// Gets the list of printers. |args| is unused.
void HandleGetPrinters(const base::ListValue* args);
// Asks the initiator renderer to generate a preview. First element of |args|
// is a job settings JSON string.
void HandleGetPreview(const base::ListValue* args);
// Gets the job settings from Web UI and initiate printing. First element of
// |args| is a job settings JSON string.
void HandlePrint(const base::ListValue* args);
// Handles printing to PDF. |settings| points to a dictionary containing all
// the print request parameters.
void HandlePrintToPdf(const base::DictionaryValue& settings);
// Handles the request to hide the preview tab for printing. |args| is unused.
void HandleHidePreview(const base::ListValue* args);
// Handles the request to cancel the pending print request. |args| is unused.
void HandleCancelPendingPrintRequest(const base::ListValue* args);
// Handles a request to back up data about the last used cloud print
// printer.
// First element of |args| is the printer name.
// Second element of |args| is the current cloud print data JSON.
void HandleSaveLastPrinter(const base::ListValue* args);
// Gets the printer capabilities. First element of |args| is the printer name.
void HandleGetPrinterCapabilities(const base::ListValue* args);
// Asks the initiator renderer to show the native print system dialog. |args|
// is unused.
void HandleShowSystemDialog(const base::ListValue* args);
// Brings up a dialog to allow the user to sign into cloud print.
// |args| is unused.
void HandleSignin(const base::ListValue* args);
// Brings up a web page to allow the user to configure cloud print.
// |args| is unused.
void HandleManageCloudPrint(const base::ListValue* args);
// Reloads the initiator tab and closes the associated preview tab. |args| is
// unused.
void HandleReloadCrashedInitiatorTab(const base::ListValue* args);
// Asks the browser to show the native printer management dialog.
// |args| is unused.
void HandleManagePrinters(const base::ListValue* args);
// Asks the browser to show the cloud print dialog.
void HandlePrintWithCloudPrint();
// Asks the browser to close the preview tab. |args| is unused.
void HandleClosePreviewTab(const base::ListValue* args);
// Asks the browser for the title of the initiator tab.
// |args| is unused.
void HandleGetInitiatorTabTitle(const base::ListValue* args);
// Sends the printer capabilities to the Web UI. |settings_info| contains
// printer capabilities information.
void SendPrinterCapabilities(const base::DictionaryValue& settings_info);
// Sends the default printer to the Web UI.
void SendDefaultPrinter(const base::StringValue& default_printer,
const base::StringValue& cloud_print_data);
// Send the list of printers to the Web UI.
void SetupPrinterList(const base::ListValue& printers);
// Send whether cloud print integration should be enabled.
void SendCloudPrintEnabled();
// Send the PDF data to the cloud to print.
void SendCloudPrintJob(const base::DictionaryValue& settings,
std::string print_ticket);
// Gets the initiator tab for the print preview tab.
TabContentsWrapper* GetInitiatorTab() const;
// Closes the print preview tab.
void ClosePrintPreviewTab();
// Activates the initiator tab and close the preview tab.
void ActivateInitiatorTabAndClosePreviewTab();
// Adds all the recorded stats taken so far to histogram counts.
void ReportStats();
// Hides the preview tab for printing.
void HidePreviewTab();
// Clears initiator tab details for this preview tab.
void ClearInitiatorTabDetails();
// Posts a task to save to pdf at |print_to_pdf_path_|.
void PostPrintToPdfTask();
// Pointer to current print system.
scoped_refptr<printing::PrintBackend> print_backend_;
// The underlying dialog object.
scoped_refptr<SelectFileDialog> select_file_dialog_;
static FilePath* last_saved_path_;
static std::string* last_used_printer_cloud_print_data_;
static std::string* last_used_printer_name_;
static printing::ColorModels last_used_color_model_;
// A count of how many requests received to regenerate preview data.
// Initialized to 0 then incremented and emitted to a histogram.
int regenerate_preview_request_count_;
// A count of how many requests received to show manage printers dialog.
int manage_printers_dialog_request_count_;
// Whether we have already logged a failed print preview.
bool reported_failed_preview_;
// Whether we have already logged the number of printers this session.
bool has_logged_printers_count_;
// Holds the path to the print to pdf request. It is empty if no such request
// exists.
scoped_ptr<FilePath> print_to_pdf_path_;
DISALLOW_COPY_AND_ASSIGN(PrintPreviewHandler);
};
#endif // CHROME_BROWSER_UI_WEBUI_PRINT_PREVIEW_HANDLER_H_
|