OLD | NEW |
---|---|
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 var localStrings = new LocalStrings(); | 5 var localStrings = new LocalStrings(); |
6 var hasPDFPlugin = true; | 6 var hasPDFPlugin = true; |
7 | 7 |
8 /** | 8 /** |
9 * Window onload handler, sets up the page. | 9 * Window onload handler, sets up the page. |
10 */ | 10 */ |
11 function load() { | 11 function load() { |
12 $('print-button').addEventListener('click', printFile); | |
13 | |
12 $('cancel-button').addEventListener('click', function(e) { | 14 $('cancel-button').addEventListener('click', function(e) { |
13 window.close(); | 15 window.close(); |
14 }); | 16 }); |
15 | 17 |
16 chrome.send('getPrinters'); | 18 chrome.send('getPrinters'); |
17 }; | 19 }; |
18 | 20 |
19 /** | 21 /** |
22 * Parse page range text. | |
23 * Eg: If page range is specified as "1-3,7-9,8". Create an array with three | |
24 * elements. Each array element contains the range information. | |
25 * [{from:1, to:3}, {from:7, to:9}, {from:8, to:8}] | |
26 * TODO (kmadhusu): Check for invalid characters. | |
27 */ | |
28 function pageRange() { | |
29 var pageRangeParams; | |
30 var pageRangesInfo = new Array(); | |
31 var pageRangeText = $('pages').value; | |
32 var pageRangeList = pageRangeText.split(","); | |
arv (Not doing code reviews)
2011/02/16 23:54:41
Use single quotes
kmadhusu
2011/02/17 19:20:31
Done.
| |
33 for (var i = 0; i < pageRangeList.length; i++) { | |
34 var temp_range = pageRangeList[i].split("-"); | |
James Hawkins
2011/02/16 22:58:21
What if the page range text is malformed?
arv (Not doing code reviews)
2011/02/16 23:54:41
no underscores in js
kmadhusu
2011/02/17 19:20:31
Done.
kmadhusu
2011/02/17 19:20:31
Added isValidPageRange() function to validate the
| |
35 if (temp_range.length > 1) { | |
36 pageRangeParams = JSON.stringify({"from" : parseInt(temp_range[0]), | |
arv (Not doing code reviews)
2011/02/16 23:54:41
parseInt(n, 10) please
kmadhusu
2011/02/17 19:20:31
Done.
| |
37 "to" : parseInt(temp_range[1])}); | |
38 } else { | |
39 pageRangeParams = JSON.stringify({"from" : parseInt(temp_range[0]), | |
arv (Not doing code reviews)
2011/02/16 23:54:41
It seems like you can do the from to assignment ou
kmadhusu
2011/02/17 19:20:31
Done.
| |
40 "to" : parseInt(temp_range[0])}); | |
41 } | |
42 pageRangesInfo.push(pageRangeParams); | |
arv (Not doing code reviews)
2011/02/16 23:54:41
Why are we using strings in here?
kmadhusu
2011/02/17 19:20:31
Rather than creating json strings, I modified the
| |
43 } | |
44 return pageRangesInfo; | |
45 } | |
46 | |
47 function printFile() { | |
48 var selected_printer = $('printer-list').selectedIndex; | |
49 var printer_name = $('printer-list').options[selected_printer].textContent; | |
50 var page_range = pageRange(); | |
51 var print_all = $('all-pages').checked; | |
52 var two_sided = $('two-sided').checked; | |
53 var copies = $('copies').value; | |
54 var collate = $('collate').checked; | |
55 var layout = $('layout').options[$('layout').selectedIndex].value; | |
56 var color = $('color').options[$('color').selectedIndex].value; | |
57 | |
58 var job_settings = JSON.stringify({"printerName" : printer_name, | |
arv (Not doing code reviews)
2011/02/16 23:54:41
no ws before :
kmadhusu
2011/02/17 19:20:31
Done.
| |
59 "pageRange" : page_range, | |
arv (Not doing code reviews)
2011/02/16 23:54:41
Won't this lead to double json encoding?
kmadhusu
2011/02/17 19:20:31
Fixed. |pageRange| is now an array of objects. JSO
| |
60 "printAll" : print_all, | |
61 "twoSided" : two_sided, | |
62 "copies" : copies, | |
63 "collate" : collate, | |
64 "layout" : layout, | |
65 "color" : color}); | |
66 chrome.send('print', [job_settings]); | |
67 } | |
68 | |
69 /** | |
20 * Fill the printer list drop down. | 70 * Fill the printer list drop down. |
21 */ | 71 */ |
22 function setPrinters(printers) { | 72 function setPrinters(printers) { |
23 if (printers.length > 0) { | 73 if (printers.length > 0) { |
24 for (var i = 0; i < printers.length; ++i) { | 74 for (var i = 0; i < printers.length; ++i) { |
25 var option = document.createElement('option'); | 75 var option = document.createElement('option'); |
26 option.textContent = printers[i]; | 76 option.textContent = printers[i]; |
27 $('printer-list').add(option); | 77 $('printer-list').add(option); |
28 } | 78 } |
29 } else { | 79 } else { |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
64 if (!pdfPlugin.onload) { | 114 if (!pdfPlugin.onload) { |
65 hasPDFPlugin = false; | 115 hasPDFPlugin = false; |
66 mainView.removeChild(pdfPlugin); | 116 mainView.removeChild(pdfPlugin); |
67 $('no-plugin').classList.remove('hidden'); | 117 $('no-plugin').classList.remove('hidden'); |
68 return; | 118 return; |
69 } | 119 } |
70 pdfPlugin.onload('onPDFLoad()'); | 120 pdfPlugin.onload('onPDFLoad()'); |
71 } | 121 } |
72 | 122 |
73 window.addEventListener('DOMContentLoaded', load); | 123 window.addEventListener('DOMContentLoaded', load); |
OLD | NEW |