| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 cr.define('settings_test', function() { | 5 cr.define('settings_test', function() { |
| 6 var changePictureOptions = settings_test.changePictureOptions || { | 6 var changePictureOptions = settings_test.changePictureOptions || { |
| 7 /** | 7 /** |
| 8 * True if property changes should fire events for testing purposes. | 8 * True if property changes should fire events for testing purposes. |
| 9 * @type {boolean} | 9 * @type {boolean} |
| 10 */ | 10 */ |
| (...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 212 break; | 212 break; |
| 213 case 'default': | 213 case 'default': |
| 214 settings.ChangePicturePrivateApi.selectDefaultImage(image.src); | 214 settings.ChangePicturePrivateApi.selectDefaultImage(image.src); |
| 215 break; | 215 break; |
| 216 default: | 216 default: |
| 217 assertNotReached('Selected unknown image type'); | 217 assertNotReached('Selected unknown image type'); |
| 218 } | 218 } |
| 219 }, | 219 }, |
| 220 | 220 |
| 221 /** | 221 /** |
| 222 * Handler for when accessibility-specific keys are pressed. |
| 223 * @param {!{detail: !{key: string}}} e |
| 224 */ |
| 225 onKeysPress_: function(e) { |
| 226 if (!this.selectedItem_) |
| 227 return; |
| 228 |
| 229 // In the old Options user images grid, the 'up' and 'down' keys had |
| 230 // different behavior depending on whether ChromeVox was on or off. |
| 231 // If ChromeVox was on, 'up' or 'down' would select the next or previous |
| 232 // image on the left or right. If ChromeVox was off, it would select the |
| 233 // image spatially above or below using calculated columns. |
| 234 // |
| 235 // The code below implements the simple behavior of selecting the image |
| 236 // to the left or right (as if ChromeVox was always on). |
| 237 // |
| 238 // TODO(tommycli): Investigate if it's necessary to calculate columns |
| 239 // and select the image on the top or bottom for non-ChromeVox users. |
| 240 switch (e.detail.key) { |
| 241 case 'up': |
| 242 case 'left': |
| 243 // This loop always terminates because the file and profile icons are |
| 244 // never hidden. |
| 245 do { |
| 246 this.$.selector.selectPrevious(); |
| 247 } while (this.selectedItem_.hidden); |
| 248 |
| 249 this.lastSelectedImageType_ = this.selectedItem_.dataset.type; |
| 250 break; |
| 251 |
| 252 case 'down': |
| 253 case 'right': |
| 254 // This loop always terminates because the file and profile icons are |
| 255 // never hidden. |
| 256 do { |
| 257 this.$.selector.selectNext(); |
| 258 } while (this.selectedItem_.hidden); |
| 259 |
| 260 this.lastSelectedImageType_ = this.selectedItem_.dataset.type; |
| 261 break; |
| 262 |
| 263 case 'enter': |
| 264 case 'space': |
| 265 if (this.selectedItem_.dataset.type == 'camera') |
| 266 this.$.camera.takePhoto(); |
| 267 else if (this.selectedItem_.dataset.type == 'file') |
| 268 settings.ChangePicturePrivateApi.chooseFile(); |
| 269 else if (this.selectedItem_.dataset.type == 'old') |
| 270 this.onTapDiscardOldImage_(); |
| 271 break; |
| 272 } |
| 273 }, |
| 274 |
| 275 /** |
| 222 * Handler for when the an image is activated. | 276 * Handler for when the an image is activated. |
| 223 * @param {!Event} event | 277 * @param {!Event} event |
| 224 * @private | 278 * @private |
| 225 */ | 279 */ |
| 226 onImageActivate_: function(event) { | 280 onImageActivate_: function(event) { |
| 227 var image = event.detail.item; | 281 var image = event.detail.item; |
| 228 this.lastSelectedImageType_ = image.dataset.type; | 282 this.lastSelectedImageType_ = image.dataset.type; |
| 229 this.selectImage_(image); | 283 this.selectImage_(image); |
| 230 }, | 284 }, |
| 231 | 285 |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 271 * @private | 325 * @private |
| 272 */ | 326 */ |
| 273 isOldImageHidden_: function(oldImageUrl) { return oldImageUrl.length == 0; }, | 327 isOldImageHidden_: function(oldImageUrl) { return oldImageUrl.length == 0; }, |
| 274 | 328 |
| 275 /** | 329 /** |
| 276 * @param {settings.ChangePictureImageElement} selectedItem | 330 * @param {settings.ChangePictureImageElement} selectedItem |
| 277 * @return {boolean} True if the preview image should be hidden. | 331 * @return {boolean} True if the preview image should be hidden. |
| 278 * @private | 332 * @private |
| 279 */ | 333 */ |
| 280 isPreviewImageHidden_: function(selectedItem) { | 334 isPreviewImageHidden_: function(selectedItem) { |
| 281 if (selectedItem == undefined) | 335 if (!selectedItem) |
| 282 return true; | 336 return true; |
| 283 | 337 |
| 284 var type = selectedItem.dataset.type; | 338 var type = selectedItem.dataset.type; |
| 285 return type != 'default' && type != 'profile' && type != 'old'; | 339 return type != 'default' && type != 'profile' && type != 'old'; |
| 286 }, | 340 }, |
| 287 | 341 |
| 288 /** | 342 /** |
| 289 * @param {settings.ChangePictureImageElement} selectedItem | 343 * @param {settings.ChangePictureImageElement} selectedItem |
| 290 * @return {boolean} True if the camera is selected in the image grid. | 344 * @return {boolean} True if the camera is selected in the image grid. |
| 291 * @private | 345 * @private |
| 292 */ | 346 */ |
| 293 isCameraActive_: function(cameraPresent, selectedItem) { | 347 isCameraActive_: function(cameraPresent, selectedItem) { |
| 294 return cameraPresent && | 348 return cameraPresent && selectedItem && |
| 295 selectedItem != undefined && | 349 selectedItem.dataset.type == 'camera'; |
| 296 selectedItem.dataset.type == 'camera'; | |
| 297 }, | 350 }, |
| 298 | 351 |
| 299 /** | 352 /** |
| 300 * @param {settings.ChangePictureImageElement} selectedItem | 353 * @param {settings.ChangePictureImageElement} selectedItem |
| 301 * @return {boolean} True if the discard controls should be hidden. | 354 * @return {boolean} True if the discard controls should be hidden. |
| 302 * @private | 355 * @private |
| 303 */ | 356 */ |
| 304 isDiscardHidden_: function(selectedItem) { | 357 isDiscardHidden_: function(selectedItem) { |
| 305 return selectedItem == undefined || selectedItem.dataset.type != 'old'; | 358 return !selectedItem || selectedItem.dataset.type != 'old'; |
| 306 }, | 359 }, |
| 307 | 360 |
| 308 /** | 361 /** |
| 309 * @param {settings.ChangePictureImageElement} selectedItem | 362 * @param {settings.ChangePictureImageElement} selectedItem |
| 310 * @return {boolean} True if the author credit text is shown. | 363 * @return {boolean} True if the author credit text is shown. |
| 311 * @private | 364 * @private |
| 312 */ | 365 */ |
| 313 isAuthorCreditShown_: function(selectedItem) { | 366 isAuthorCreditShown_: function(selectedItem) { |
| 314 return selectedItem && selectedItem.dataset.type == 'default'; | 367 return selectedItem && selectedItem.dataset.type == 'default'; |
| 315 }, | 368 }, |
| (...skipping 21 matching lines...) Expand all Loading... |
| 337 * @private | 390 * @private |
| 338 */ | 391 */ |
| 339 getAuthorWebsite_: function(selectedItem, defaultImages) { | 392 getAuthorWebsite_: function(selectedItem, defaultImages) { |
| 340 if (!this.isAuthorCreditShown_(selectedItem)) | 393 if (!this.isAuthorCreditShown_(selectedItem)) |
| 341 return ''; | 394 return ''; |
| 342 | 395 |
| 343 assert(selectedItem.dataset.defaultImageIndex < defaultImages.length); | 396 assert(selectedItem.dataset.defaultImageIndex < defaultImages.length); |
| 344 return defaultImages[selectedItem.dataset.defaultImageIndex].website; | 397 return defaultImages[selectedItem.dataset.defaultImageIndex].website; |
| 345 }, | 398 }, |
| 346 }); | 399 }); |
| OLD | NEW |