Index: chrome/browser/resources/hotword_audio_verification/main.js |
diff --git a/chrome/browser/resources/hotword_audio_verification/main.js b/chrome/browser/resources/hotword_audio_verification/main.js |
index 8c78ef4a4f05b56f796e6e51e81022f7d3b88722..eab99c8655cb96bb1640fba399f3808c3d1a42ef 100644 |
--- a/chrome/browser/resources/hotword_audio_verification/main.js |
+++ b/chrome/browser/resources/hotword_audio_verification/main.js |
@@ -8,75 +8,86 @@ document.addEventListener('DOMContentLoaded', function() { |
var flow = new Flow(); |
flow.startFlow(); |
- // Make the close buttons close the app window. |
- var closeButtons = document.getElementsByClassName('close'); |
- for (var i = 0; i < closeButtons.length; ++i) { |
- var closeButton = closeButtons[i]; |
- closeButton.addEventListener('click', function(e) { |
+ var closeAppWindow = function(e) { |
+ var classes = e.target.classList; |
+ if (classes.contains('close') || classes.contains('finish-button')) { |
appWindow.close(); |
e.preventDefault(); |
- }); |
- } |
+ } |
+ }; |
- $('ah-cancel-button').addEventListener('click', function(e) { |
- appWindow.close(); |
- e.preventDefault(); |
- }); |
+ // TODO(kcarattini): Cancel training in NaCl module for hotword-only and |
+ // speech-training close and cancel buttons. |
+ $('steps').addEventListener('click', closeAppWindow); |
- $('done-button').addEventListener('click', function(e) { |
- appWindow.close(); |
+ $('hw-agree-button').addEventListener('click', function(e) { |
+ flow.advanceStep(); |
e.preventDefault(); |
}); |
- $('ho-cancel-button').addEventListener('click', function(e) { |
- appWindow.close(); |
+ $('settings-link').addEventListener('click', function(e) { |
+ chrome.browser.openTab({'url': 'chrome://settings'}, function() {}); |
e.preventDefault(); |
}); |
- $('hw-cancel-button').addEventListener('click', function(e) { |
- appWindow.close(); |
- e.preventDefault(); |
- }); |
+ /** |
+ * Updates steps of the training UI. |
+ * @param {string} pagePrefix Prefix of the element ids for this page. |
+ * @param {Event} e The click event. |
+ */ |
+ function doTraining(pagePrefix, e) { |
+ // TODO(kcarattini): Update this to respond to a hotword trigger once |
+ // speech training is implemented. |
+ var steps = $(pagePrefix + '-training').querySelectorAll('.train'); |
+ var index = Array.prototype.indexOf.call(steps, e.currentTarget); |
+ if (!steps[index]) |
+ return; |
- $('st-cancel-button').addEventListener('click', function(e) { |
- appWindow.close(); |
- e.preventDefault(); |
- }); |
+ // TODO(kcarattini): Localize this string. |
+ steps[index].querySelector('.text').textContent = 'Recorded'; |
+ steps[index].classList.remove('listening'); |
+ steps[index].classList.add('recorded'); |
- $('ah-agree-button').addEventListener('click', function(e) { |
- // TODO(kcarattini): Set the Audio History setting. |
- appWindow.close(); |
- e.preventDefault(); |
- }); |
+ if (steps[index + 1]) { |
+ steps[index + 1].classList.remove('not-started'); |
+ steps[index + 1].classList.add('listening'); |
+ } |
+ } |
- $('hw-agree-button').addEventListener('click', function(e) { |
- flow.advanceStep(); |
- e.preventDefault(); |
- }); |
+ /** |
+ * Adds event listeners to the training UI. |
+ * @param {string} pagePrefix Prefix of the element ids for this page. |
+ */ |
+ function addTrainingEventListeners(pagePrefix) { |
+ var steps = $(pagePrefix + '-training').querySelectorAll('.train'); |
+ for (var i = 0; i < steps.length; ++i) { |
+ steps[i].addEventListener('click', function(e) { |
+ doTraining(pagePrefix, e); |
+ e.preventDefault(); |
- // TODO(kcarattini): Remove this once speech training is implemented. The |
- // way to get to the next page will be to complete the speech training. |
- $('st-training').addEventListener('click', function(e) { |
- if (chrome.hotwordPrivate.setAudioLoggingEnabled) |
- chrome.hotwordPrivate.setAudioLoggingEnabled(true, function() {}); |
+ if (e.currentTarget != steps[steps.length - 1]) |
+ return; |
- if (chrome.hotwordPrivate.setHotwordAlwaysOnSearchEnabled) { |
- chrome.hotwordPrivate.setHotwordAlwaysOnSearchEnabled(true, |
- flow.advanceStep.bind(flow)); |
- } |
- e.preventDefault(); |
- }); |
+ // Update the 'Cancel' button. |
+ var buttonElem = $(pagePrefix + '-cancel-button'); |
+ // TODO(kcarattini): Localize this string. |
+ buttonElem.textContent = 'Please wait ...'; |
+ buttonElem.classList.add('grayed-out'); |
+ buttonElem.classList.remove('finish-button'); |
- // TODO(kcarattini): Remove this once speech training is implemented. The |
- // way to get to the next page will be to complete the speech training. |
- $('ho-training').addEventListener('click', function(e) { |
- if (chrome.hotwordPrivate.setAudioLoggingEnabled) |
- chrome.hotwordPrivate.setAudioLoggingEnabled(true, function() {}); |
+ setTimeout(function() { |
+ if (chrome.hotwordPrivate.setAudioLoggingEnabled) |
+ chrome.hotwordPrivate.setAudioLoggingEnabled(true, function() {}); |
- if (chrome.hotwordPrivate.setHotwordAlwaysOnSearchEnabled) { |
- chrome.hotwordPrivate.setHotwordAlwaysOnSearchEnabled(true, |
- flow.advanceStep.bind(flow)); |
+ if (chrome.hotwordPrivate.setHotwordAlwaysOnSearchEnabled) { |
+ chrome.hotwordPrivate.setHotwordAlwaysOnSearchEnabled(true, |
+ flow.advanceStep.bind(flow)); |
+ } |
+ }, 2000); |
+ }); |
} |
- e.preventDefault(); |
- }); |
+ } |
+ |
+ addTrainingEventListeners('speech-training'); |
+ addTrainingEventListeners('hotword-only'); |
}); |