Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "printing/printing_context_mac.h" | 5 #include "printing/printing_context_mac.h" |
| 6 | 6 |
| 7 #import <ApplicationServices/ApplicationServices.h> | 7 #import <ApplicationServices/ApplicationServices.h> |
| 8 #import <AppKit/AppKit.h> | 8 #import <AppKit/AppKit.h> |
| 9 | 9 |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| (...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 75 PMPrintSettingsSetJobName(printSettings, (CFStringRef)job_title); | 75 PMPrintSettingsSetJobName(printSettings, (CFStringRef)job_title); |
| 76 [printInfo updateFromPMPrintSettings]; | 76 [printInfo updateFromPMPrintSettings]; |
| 77 } | 77 } |
| 78 } | 78 } |
| 79 | 79 |
| 80 // TODO(stuartmorgan): We really want a tab sheet here, not a modal window. | 80 // TODO(stuartmorgan): We really want a tab sheet here, not a modal window. |
| 81 // Will require restructuring the PrintingContext API to use a callback. | 81 // Will require restructuring the PrintingContext API to use a callback. |
| 82 NSInteger selection = [panel runModalWithPrintInfo:printInfo]; | 82 NSInteger selection = [panel runModalWithPrintInfo:printInfo]; |
| 83 if (selection == NSOKButton) { | 83 if (selection == NSOKButton) { |
| 84 print_info_.reset([[panel printInfo] retain]); | 84 print_info_.reset([[panel printInfo] retain]); |
| 85 InitPrintSettingsFromPrintInfo(GetPageRangesFromPrintInfo()); | 85 DictionaryValue header_footer_info; |
| 86 header_footer_info.SetBoolean(printing::kSettingHeaderFooterEnabled, | |
| 87 false); | |
| 88 InitPrintSettingsFromPrintInfo(GetPageRangesFromPrintInfo(), | |
| 89 header_footer_info); | |
| 86 callback->Run(OK); | 90 callback->Run(OK); |
| 87 } else { | 91 } else { |
| 88 callback->Run(CANCEL); | 92 callback->Run(CANCEL); |
| 89 } | 93 } |
| 90 } | 94 } |
| 91 | 95 |
| 92 PrintingContext::Result PrintingContextMac::UseDefaultSettings() { | 96 PrintingContext::Result PrintingContextMac::UseDefaultSettings() { |
| 93 DCHECK(!in_print_job_); | 97 DCHECK(!in_print_job_); |
| 94 | 98 |
| 95 print_info_.reset([[NSPrintInfo sharedPrintInfo] copy]); | 99 print_info_.reset([[NSPrintInfo sharedPrintInfo] copy]); |
| 96 InitPrintSettingsFromPrintInfo(GetPageRangesFromPrintInfo()); | 100 DictionaryValue header_footer_info; |
| 101 header_footer_info.SetBoolean(printing::kSettingHeaderFooterEnabled, | |
|
kmadhusu
2011/08/12 20:27:11
nit: If possible, have a function that populates t
Aayush Kumar
2011/08/13 04:04:53
Done.
| |
| 102 false); | |
| 103 InitPrintSettingsFromPrintInfo(GetPageRangesFromPrintInfo(), | |
| 104 header_footer_info); | |
| 97 | 105 |
| 98 return OK; | 106 return OK; |
| 99 } | 107 } |
| 100 | 108 |
| 101 PrintingContext::Result PrintingContextMac::UpdatePrintSettings( | 109 PrintingContext::Result PrintingContextMac::UpdatePrintSettings( |
| 102 const DictionaryValue& job_settings, const PageRanges& ranges) { | 110 const DictionaryValue& job_settings, const PageRanges& ranges) { |
| 103 DCHECK(!in_print_job_); | 111 DCHECK(!in_print_job_); |
| 104 | 112 |
| 105 // NOTE: Reset |print_info_| with a copy of |sharedPrintInfo| so as to start | 113 // NOTE: Reset |print_info_| with a copy of |sharedPrintInfo| so as to start |
| 106 // with a clean slate. | 114 // with a clean slate. |
| (...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 143 | 151 |
| 144 if (!SetOutputIsColor(color)) | 152 if (!SetOutputIsColor(color)) |
| 145 return OnError(); | 153 return OnError(); |
| 146 } | 154 } |
| 147 | 155 |
| 148 if (!SetOrientationIsLandscape(landscape)) | 156 if (!SetOrientationIsLandscape(landscape)) |
| 149 return OnError(); | 157 return OnError(); |
| 150 | 158 |
| 151 [print_info_.get() updateFromPMPrintSettings]; | 159 [print_info_.get() updateFromPMPrintSettings]; |
| 152 | 160 |
| 153 InitPrintSettingsFromPrintInfo(ranges); | 161 DictionaryValue header_footer_info; |
| 162 GetHeaderFooterInfo(job_settings, &header_footer_info); | |
| 163 | |
| 164 InitPrintSettingsFromPrintInfo(ranges, header_footer_info); | |
| 154 return OK; | 165 return OK; |
| 155 } | 166 } |
| 156 | 167 |
| 157 void PrintingContextMac::InitPrintSettingsFromPrintInfo( | 168 void PrintingContextMac::InitPrintSettingsFromPrintInfo( |
| 158 const PageRanges& ranges) { | 169 const PageRanges& ranges, |
| 170 const DictionaryValue& header_footer_info) { | |
| 159 PMPrintSession print_session = | 171 PMPrintSession print_session = |
| 160 static_cast<PMPrintSession>([print_info_.get() PMPrintSession]); | 172 static_cast<PMPrintSession>([print_info_.get() PMPrintSession]); |
| 161 PMPageFormat page_format = | 173 PMPageFormat page_format = |
| 162 static_cast<PMPageFormat>([print_info_.get() PMPageFormat]); | 174 static_cast<PMPageFormat>([print_info_.get() PMPageFormat]); |
| 163 PMPrinter printer; | 175 PMPrinter printer; |
| 164 PMSessionGetCurrentPrinter(print_session, &printer); | 176 PMSessionGetCurrentPrinter(print_session, &printer); |
| 165 PrintSettingsInitializerMac::InitPrintSettings( | 177 PrintSettingsInitializerMac::InitPrintSettings( |
| 166 printer, page_format, ranges, false, &settings_); | 178 printer, page_format, ranges, false, &settings_); |
| 167 } | 179 } |
| 168 | 180 |
| (...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 370 void PrintingContextMac::ReleaseContext() { | 382 void PrintingContextMac::ReleaseContext() { |
| 371 print_info_.reset(); | 383 print_info_.reset(); |
| 372 context_ = NULL; | 384 context_ = NULL; |
| 373 } | 385 } |
| 374 | 386 |
| 375 gfx::NativeDrawingContext PrintingContextMac::context() const { | 387 gfx::NativeDrawingContext PrintingContextMac::context() const { |
| 376 return context_; | 388 return context_; |
| 377 } | 389 } |
| 378 | 390 |
| 379 } // namespace printing | 391 } // namespace printing |
| OLD | NEW |