Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 SetIconCommon = requireNative('setIcon').SetIconCommon; | 5 var SetIconCommon = requireNative('setIcon').SetIconCommon; |
| 6 var sendRequest = require('sendRequest').sendRequest; | 6 var sendRequest = require('sendRequest').sendRequest; |
| 7 | 7 |
| 8 function loadImagePath(path, iconSize, actionType, callback) { | 8 function loadImagePath(path, iconSize, actionType, callback) { |
| 9 var img = new Image(); | 9 var img = new Image(); |
| 10 img.onerror = function() { | 10 img.onerror = function() { |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 42 } | 42 } |
| 43 | 43 |
| 44 if (imageData.width > iconSize || | 44 if (imageData.width > iconSize || |
| 45 imageData.height > iconSize) { | 45 imageData.height > iconSize) { |
| 46 throw new Error( | 46 throw new Error( |
| 47 'The imageData property must contain an ImageData object that ' + | 47 'The imageData property must contain an ImageData object that ' + |
| 48 'is no larger than ' + iconSize + ' pixels square.'); | 48 'is no larger than ' + iconSize + ' pixels square.'); |
| 49 } | 49 } |
| 50 } | 50 } |
| 51 | 51 |
| 52 function setIcon(details, callback, name, parameters, actionType) { | 52 function setIcon(details, actionType, callback) { |
|
not at google - send to devlin
2014/08/19 00:04:43
It looks like the only reason we need to thread th
gpdavis
2014/08/19 00:54:15
Done.
| |
| 53 var iconSizes = [19, 38]; | 53 var iconSizes = [19, 38]; |
| 54 if ('iconIndex' in details) { | 54 if ('iconIndex' in details) { |
| 55 sendRequest(name, [details, callback], parameters); | 55 callback(details); |
|
not at google - send to devlin
2014/08/19 00:04:43
This code is such a nightmare. Sheesh. Such a nest
gpdavis
2014/08/19 00:54:15
Done.
| |
| 56 } else if ('imageData' in details) { | 56 } else if ('imageData' in details) { |
| 57 if (typeof details.imageData == 'object') { | 57 if (typeof details.imageData == 'object') { |
|
not at google - send to devlin
2014/08/19 00:04:43
Checks like these are so unnecessary, it's exactly
gpdavis
2014/08/19 00:54:15
Done.
| |
| 58 var isEmpty = true; | 58 var isEmpty = true; |
| 59 for (var i = 0; i < iconSizes.length; i++) { | 59 for (var i = 0; i < iconSizes.length; i++) { |
| 60 var sizeKey = iconSizes[i].toString(); | 60 var sizeKey = iconSizes[i].toString(); |
| 61 if (sizeKey in details.imageData) { | 61 if (sizeKey in details.imageData) { |
| 62 verifyImageData(details.imageData[sizeKey], iconSizes[i]); | 62 verifyImageData(details.imageData[sizeKey], iconSizes[i]); |
| 63 isEmpty =false; | 63 isEmpty =false; |
| 64 } | 64 } |
| 65 } | 65 } |
| 66 | 66 |
| 67 if (!isEmpty) { | 67 if (!isEmpty) { |
| 68 sendRequest(name, [details, callback], parameters, | 68 callback(SetIconCommon(details)); |
| 69 {nativeFunction: SetIconCommon}); | |
| 70 } else { | 69 } else { |
| 71 // If details.imageData is not dictionary with keys in set {'19', '38'}, | 70 // If details.imageData is not dictionary with keys in set {'19', '38'}, |
| 72 // it must be an ImageData object. | 71 // it must be an ImageData object. |
| 73 var sizeKey = iconSizes[0].toString(); | 72 var sizeKey = iconSizes[0].toString(); |
| 74 var imageData = details.imageData; | 73 var imageData = details.imageData; |
| 75 details.imageData = {}; | 74 details.imageData = {}; |
| 76 details.imageData[sizeKey] = imageData; | 75 details.imageData[sizeKey] = imageData; |
| 77 verifyImageData(details.imageData[sizeKey], iconSizes[0]); | 76 verifyImageData(details.imageData[sizeKey], iconSizes[0]); |
| 78 sendRequest(name, [details, callback], parameters, | 77 callback(SetIconCommon(details)); |
| 79 {nativeFunction: SetIconCommon}); | |
| 80 } | 78 } |
| 81 } else { | 79 } else { |
| 82 throw new Error('imageData property has unexpected type.'); | 80 throw new Error('imageData property has unexpected type.'); |
| 83 } | 81 } |
| 84 } else if ('path' in details) { | 82 } else if ('path' in details) { |
| 85 if (typeof details.path == 'object') { | 83 if (typeof details.path == 'object') { |
| 86 details.imageData = {}; | 84 details.imageData = {}; |
| 87 var isEmpty = true; | 85 var isEmpty = true; |
| 88 var processIconSize = function(index) { | 86 var processIconSize = function(index) { |
| 89 if (index == iconSizes.length) { | 87 if (index == iconSizes.length) { |
| 90 delete details.path; | 88 delete details.path; |
| 91 if (isEmpty) | 89 if (isEmpty) |
| 92 throw new Error('The path property must not be empty.'); | 90 throw new Error('The path property must not be empty.'); |
| 93 sendRequest(name, [details, callback], parameters, | 91 callback(SetIconCommon(details)); |
| 94 {nativeFunction: SetIconCommon}); | |
| 95 return; | |
| 96 } | 92 } |
| 97 var sizeKey = iconSizes[index].toString(); | 93 var sizeKey = iconSizes[index].toString(); |
| 98 if (!(sizeKey in details.path)) { | 94 if (!(sizeKey in details.path)) { |
| 99 processIconSize(index + 1); | 95 processIconSize(index + 1); |
| 100 return; | 96 return; |
| 101 } | 97 } |
| 102 isEmpty = false; | 98 isEmpty = false; |
| 103 loadImagePath(details.path[sizeKey], iconSizes[index], actionType, | 99 loadImagePath(details.path[sizeKey], iconSizes[index], actionType, |
| 104 function(imageData) { | 100 function(imageData) { |
| 105 details.imageData[sizeKey] = imageData; | 101 details.imageData[sizeKey] = imageData; |
| 106 processIconSize(index + 1); | 102 processIconSize(index + 1); |
| 107 }); | 103 }); |
| 108 } | 104 } |
| 109 | 105 |
| 110 processIconSize(0); | 106 processIconSize(0); |
| 111 } else if (typeof details.path == 'string') { | 107 } else if (typeof details.path == 'string') { |
| 112 var sizeKey = iconSizes[0].toString(); | 108 var sizeKey = iconSizes[0].toString(); |
| 113 details.imageData = {}; | 109 details.imageData = {}; |
| 114 loadImagePath(details.path, iconSizes[0], actionType, | 110 loadImagePath(details.path, iconSizes[0], actionType, |
| 115 function(imageData) { | 111 function(imageData) { |
| 116 details.imageData[sizeKey] = imageData; | 112 details.imageData[sizeKey] = imageData; |
| 117 delete details.path; | 113 delete details.path; |
| 118 sendRequest(name, [details, callback], parameters, | 114 callback(SetIconCommon(details)); |
| 119 {nativeFunction: SetIconCommon}); | |
| 120 }); | 115 }); |
| 121 } else { | 116 } else { |
| 122 throw new Error('The path property should contain either string or ' + | 117 throw new Error('The path property should contain either string or ' + |
| 123 'dictionary of strings.'); | 118 'dictionary of strings.'); |
| 124 } | 119 } |
| 125 } else { | 120 } else { |
| 126 throw new Error( | 121 throw new Error( |
| 127 'Either the path or imageData property must be specified.'); | 122 'Either the path or imageData property must be specified.'); |
| 128 } | 123 } |
| 129 } | 124 } |
| 130 | 125 |
| 131 exports.setIcon = setIcon; | 126 exports.setIcon = setIcon; |
| OLD | NEW |