Index: chrome/browser/chromeos/login/screens/user_selection_screen.h |
diff --git a/chrome/browser/chromeos/login/screens/user_selection_screen.h b/chrome/browser/chromeos/login/screens/user_selection_screen.h |
index 9a5c35dee196272be5af0162eeb2e4d663caaee2..1a9dd0395045b18c4b56da3ce5879b97e01e758e 100644 |
--- a/chrome/browser/chromeos/login/screens/user_selection_screen.h |
+++ b/chrome/browser/chromeos/login/screens/user_selection_screen.h |
@@ -5,25 +5,29 @@ |
#ifndef CHROME_BROWSER_CHROMEOS_LOGIN_SCREENS_USER_SELECTION_SCREEN_H_ |
#define CHROME_BROWSER_CHROMEOS_LOGIN_SCREENS_USER_SELECTION_SCREEN_H_ |
+#include <map> |
#include <string> |
#include "base/bind.h" |
#include "base/compiler_specific.h" |
+#include "base/timer/timer.h" |
+#include "chrome/browser/chromeos/login/ui/login_display.h" |
#include "chrome/browser/chromeos/login/users/user.h" |
+#include "ui/wm/core/user_activity_observer.h" |
namespace chromeos { |
class LoginDisplayWebUIHandler; |
// This class represents User Selection screen: user pod-based login screen. |
-class UserSelectionScreen { |
+class UserSelectionScreen : public wm::UserActivityObserver { |
public: |
UserSelectionScreen(); |
virtual ~UserSelectionScreen(); |
void SetHandler(LoginDisplayWebUIHandler* handler); |
- void Init(const UserList& users); |
+ void Init(const UserList& users, bool show_guest); |
const UserList& GetUsers() const; |
void OnUserImageChanged(const User& user); |
void OnBeforeUserRemoved(const std::string& username); |
@@ -33,12 +37,43 @@ class UserSelectionScreen { |
const base::Closure& click_callback); |
void HideUserPodButton(const std::string& username); |
+ void OnPasswordClearTimerExpired(); |
+ void SendUserList(bool animated); |
+ void SetAuthType(const std::string& user_id, |
+ LoginDisplay::AuthType auth_type, |
+ const std::string& initial_value); |
+ LoginDisplay::AuthType GetAuthType(const std::string& user_id) const; |
+ void HandleCustomButtonClicked(const std::string& user_id); |
+ void HandleGetUsers(); |
+ |
+ // wm::UserActivityDetector implementation: |
+ virtual void OnUserActivity(const ui::Event* event) OVERRIDE; |
+ |
+ static void FillUserDictionary(User* user, |
+ bool is_owner, |
+ bool is_signin_to_add, |
+ LoginDisplay::AuthType auth_type, |
+ base::DictionaryValue* user_dict); |
+ static bool ShouldForceOnlineSignIn(const User* user); |
+ |
private: |
LoginDisplayWebUIHandler* handler_; |
// Set of Users that are visible. |
UserList users_; |
+ bool show_guest_; |
Nikita (slow)
2014/05/23 15:52:15
nit: Copy comment as well.
Denis Kuznetsov (DE-MUC)
2014/05/27 17:35:28
Done.
|
+ |
+ // Map of callbacks run when the custom button on a user pod is clicked. |
+ std::map<std::string, base::Closure> user_pod_button_callback_map_; |
+ |
+ // Map of usernames to their current authentication type. If a user is not |
+ // contained in the map, it is using the default authentication type. |
+ std::map<std::string, LoginDisplay::AuthType> user_auth_type_map_; |
+ |
+ // Timer for measuring idle state duration before password clear. |
+ base::OneShotTimer<UserSelectionScreen> password_clear_timer_; |
+ |
DISALLOW_COPY_AND_ASSIGN(UserSelectionScreen); |
}; |