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

Side by Side Diff: chrome/browser/ui/webui/print_preview_ui.cc

Issue 7063030: PrintPreview: Print Preview is not staying associated with initiator renderer. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: '' Created 9 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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_ui.h" 5 #include "chrome/browser/ui/webui/print_preview_ui.h"
6 6
7 #include "base/string_util.h"
7 #include "base/values.h" 8 #include "base/values.h"
8 #include "chrome/browser/profiles/profile.h" 9 #include "chrome/browser/profiles/profile.h"
10 #include "chrome/browser/printing/print_preview_data_service_factory.h"
11 #include "chrome/browser/ui/webui/print_preview_data_source.h"
9 #include "chrome/browser/ui/webui/print_preview_handler.h" 12 #include "chrome/browser/ui/webui/print_preview_handler.h"
10 #include "chrome/browser/ui/webui/print_preview_ui_html_source.h"
11 #include "content/browser/browser_thread.h"
12 #include "content/browser/tab_contents/tab_contents.h" 13 #include "content/browser/tab_contents/tab_contents.h"
13 14
14 PrintPreviewUI::PrintPreviewUI(TabContents* contents) 15 PrintPreviewUI::PrintPreviewUI(TabContents* contents) : WebUI(contents) {
15 : WebUI(contents),
16 html_source_(new PrintPreviewUIHTMLSource()) {
17 // PrintPreviewUI owns |handler|. 16 // PrintPreviewUI owns |handler|.
18 PrintPreviewHandler* handler = new PrintPreviewHandler(); 17 PrintPreviewHandler* handler = new PrintPreviewHandler();
19 AddMessageHandler(handler->Attach(this)); 18 AddMessageHandler(handler->Attach(this));
20 19
21 // Set up the chrome://print/ source. 20 // Set up the chrome://print/ data source.
22 contents->profile()->GetChromeURLDataManager()->AddDataSource(html_source_); 21 PrintPreviewDataSource* data_source =
22 new PrintPreviewDataSource(contents->profile());
23 contents->profile()->GetChromeURLDataManager()->AddDataSource(data_source);
24
25 // Store the PrintPreviewUIAddress as a string. Since the memory address is
26 // used as the identifier the string size is (2 * sizeof(this)) + 3, where
27 // 3 is for '0x' and null terminator.
Lei Zhang 2011/05/28 00:12:38 How about: // "0x" + deadc0de + '\0' = 2 + 2 * siz
kmadhusu 2011/05/29 00:04:26 Done.
28 char preview_ui_addr[(2 * sizeof(this)) + 3];
29 base::snprintf(preview_ui_addr, sizeof(preview_ui_addr), "%p", this);
30 preview_ui_addr_str_ = preview_ui_addr;
23 } 31 }
24 32
25 PrintPreviewUI::~PrintPreviewUI() { 33 PrintPreviewUI::~PrintPreviewUI() {
34 print_preview_data_service()->RemoveEntry(preview_ui_addr_str_);
26 } 35 }
27 36
28 PrintPreviewUIHTMLSource* PrintPreviewUI::html_source() { 37 void PrintPreviewUI::GetPrintPreviewData(scoped_refptr<RefCountedBytes>* data) {
29 return html_source_.get(); 38 print_preview_data_service()->GetDataEntry(preview_ui_addr_str_, data);
39 }
40
41 void PrintPreviewUI::SetPrintPreviewData(const RefCountedBytes* data) {
42 print_preview_data_service()->SetDataEntry(preview_ui_addr_str_, data);
30 } 43 }
31 44
32 void PrintPreviewUI::OnInitiatorTabClosed( 45 void PrintPreviewUI::OnInitiatorTabClosed(
33 const std::string& initiator_url) { 46 const std::string& initiator_url) {
34 StringValue initiator_tab_url(initiator_url); 47 StringValue initiator_tab_url(initiator_url);
35 CallJavascriptFunction("onInitiatorTabClosed", initiator_tab_url); 48 CallJavascriptFunction("onInitiatorTabClosed", initiator_tab_url);
36 } 49 }
37 50
38 void PrintPreviewUI::OnPreviewDataIsAvailable(int expected_pages_count, 51 void PrintPreviewUI::OnPreviewDataIsAvailable(int expected_pages_count,
39 const string16& job_title, 52 const string16& job_title,
40 bool modifiable) { 53 bool modifiable) {
41 VLOG(1) << "Print preview request finished with " 54 VLOG(1) << "Print preview request finished with "
42 << expected_pages_count << " pages"; 55 << expected_pages_count << " pages";
43 FundamentalValue pages_count(expected_pages_count); 56 FundamentalValue pages_count(expected_pages_count);
44 StringValue title(job_title); 57 StringValue title(job_title);
45 FundamentalValue is_preview_modifiable(modifiable); 58 FundamentalValue is_preview_modifiable(modifiable);
59 StringValue ui_identifier(preview_ui_addr_str_);
46 CallJavascriptFunction("updatePrintPreview", pages_count, title, 60 CallJavascriptFunction("updatePrintPreview", pages_count, title,
47 is_preview_modifiable); 61 is_preview_modifiable, ui_identifier);
48 } 62 }
63
64 PrintPreviewDataService* PrintPreviewUI::print_preview_data_service() {
65 return PrintPreviewDataServiceFactory::GetForProfile(
66 tab_contents()->profile());
67 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698