Index: chrome/browser/resources/new_profile.js |
diff --git a/chrome/browser/resources/new_profile.js b/chrome/browser/resources/new_profile.js |
new file mode 100644 |
index 0000000000000000000000000000000000000000..0355b828395b03a6f4d18dba26b6e6524ae433cf |
--- /dev/null |
+++ b/chrome/browser/resources/new_profile.js |
@@ -0,0 +1,95 @@ |
+// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+cr.define("newProfile", function() { |
+ 'use strict'; |
+ |
+ // Tracks the currently selected avatar icon. |
+ var selectedAvatarIconIndex = 0; |
+ |
+ // Initializes everything once the document loads. |
+ function load() { |
+ // Allow platform specific CSS rules. |
+ cr.enablePlatformSpecificCSSRules(); |
+ |
+ // Add handlers to HTML elements. |
+ $('create-button').onclick = onCreate; |
+ $('cancel-button').onclick = onCancel; |
+ $('profile-name-form').onsubmit = function () { |
+ onCreate(); |
+ // Return false to prevent the submit handler from doing a post. |
+ return false; |
+ }; |
+ |
+ chrome.send('requestProfileInfo'); |
+ updateLogo(); |
+ $('profile-name').focus(); |
+ } |
+ |
+ // Sends the profile information to the browser. |
+ function onCreate() { |
+ chrome.send('create', [$('profile-name').value, |
+ String(selectedAvatarIconIndex)]); |
+ } |
+ |
+ // Lets the browser know that the user doesn't want to create the profile. |
+ function onCancel() { |
+ chrome.send('cancel'); |
+ } |
+ |
+ // Changes the selected profile. |
+ function onAvatarClicked(index) { |
+ var menu = $('avatar-menu'); |
+ for (var i = 0; i < menu.childNodes.length; i++) { |
+ var button = menu.childNodes[i]; |
+ if (i == index) |
+ button.classList.add("avatar-button-selected"); |
+ else |
+ button.classList.remove("avatar-button-selected"); |
+ } |
+ selectedAvatarIconIndex = index; |
+ } |
+ |
+ // Sets the logo image. |
+ function updateLogo() { |
+ var imageId = 'IDR_PRODUCT_LOGO'; |
+ if (document.documentElement.getAttribute('customlogo') == 'true') |
+ imageId = 'IDR_CUSTOM_PRODUCT_LOGO'; |
+ |
+ $('logo-img').src = 'chrome://theme/' + imageId + '?' + Date.now(); |
+ } |
+ |
+ // Callback from the browser to set the profile information on the page. |
+ function setProfileInfo(profileName, profileIconIndex) { |
+ $('profile-name').value = profileName; |
+ onAvatarClicked(profileIconIndex); |
+ } |
+ |
+ // Callback from the browser to fill the avatar menu with default avatar |
+ // images. |
+ function setDefaultAvatarImages(imageUrlList) { |
+ var menu = $('avatar-menu'); |
+ for (var i = 0; i < imageUrlList.length; i++) { |
+ var button = document.createElement("input"); |
+ button.setAttribute("type", "image"); |
+ button.setAttribute("class", "avatar-button"); |
+ button.setAttribute("src", imageUrlList[i]); |
+ button.setAttribute("onclick", "newProfile.onAvatarClicked(" + i + ")"); |
+ menu.appendChild(button); |
+ } |
+ } |
+ |
+ // Return an object with all the exports. |
+ return { |
+ load: load, |
+ onCreate: onCreate, |
+ onCancel: onCancel, |
+ onAvatarClicked: onAvatarClicked, |
+ updateLogo: updateLogo, |
+ setProfileInfo: setProfileInfo, |
+ setDefaultAvatarImages: setDefaultAvatarImages, |
+ }; |
+}); |
+ |
+window.addEventListener('DOMContentLoaded', newProfile.load); |