Index: ash/system/chromeos/session/tray_session_length_limit.h |
diff --git a/ash/system/chromeos/session/tray_session_length_limit.h b/ash/system/chromeos/session/tray_session_length_limit.h |
index 1c9da1713659256d007e540081e98424c79af473..b4893274f69cbf8ff658b5b3d62231aeea0d5026 100644 |
--- a/ash/system/chromeos/session/tray_session_length_limit.h |
+++ b/ash/system/chromeos/session/tray_session_length_limit.h |
@@ -7,9 +7,11 @@ |
#include "ash/system/chromeos/session/session_length_limit_observer.h" |
#include "ash/system/tray/system_tray_item.h" |
+#include "ash/system/tray/view_click_listener.h" |
#include "base/basictypes.h" |
#include "base/compiler_specific.h" |
#include "base/memory/scoped_ptr.h" |
+#include "base/strings/string16.h" |
#include "base/time/time.h" |
#include "base/timer/timer.h" |
@@ -18,14 +20,13 @@ namespace test { |
class TraySessionLengthLimitTest; |
} |
-namespace tray { |
-class RemainingSessionTimeTrayView; |
-} |
+class LabelTrayView; |
// Adds a countdown timer to the system tray if the session length is limited. |
class ASH_EXPORT TraySessionLengthLimit : public SystemTrayItem, |
- public SessionLengthLimitObserver { |
- public: |
+ public SessionLengthLimitObserver, |
+ public ViewClickListener { |
+public: |
enum LimitState { |
LIMIT_NONE, |
LIMIT_SET, |
@@ -36,33 +37,43 @@ class ASH_EXPORT TraySessionLengthLimit : public SystemTrayItem, |
virtual ~TraySessionLengthLimit(); |
// SystemTrayItem: |
- virtual views::View* CreateTrayView(user::LoginStatus status) OVERRIDE; |
- virtual void DestroyTrayView() OVERRIDE; |
- virtual void UpdateAfterShelfAlignmentChange( |
- ShelfAlignment alignment) OVERRIDE; |
+ virtual views::View* CreateDefaultView(user::LoginStatus status) OVERRIDE; |
+ virtual void DestroyDefaultView() OVERRIDE; |
// SessionLengthLimitObserver: |
virtual void OnSessionStartTimeChanged() OVERRIDE; |
virtual void OnSessionLengthLimitChanged() OVERRIDE; |
- LimitState GetLimitState() const; |
- base::TimeDelta GetRemainingSessionTime() const; |
+ // ViewClickListener: |
+ virtual void OnViewClicked(views::View* sender) OVERRIDE; |
private: |
friend class test::TraySessionLengthLimitTest; |
static const char kNotificationId[]; |
+ // Update state, notifications and tray bubble view. Called by the Timer in |
bartfab (slow)
2014/05/05 17:49:58
Nit: s/notifications/notification/
Thiemo Nagel
2014/05/06 14:28:00
Done.
|
+ // regular intervals and also by OnSession*Changed(). |
void Update(); |
- bool IsTrayViewVisibleForTest(); |
+ // Recalculate |limit_state_| and the message strings. |
+ void UpdateState(); |
- tray::RemainingSessionTimeTrayView* tray_view_; |
+ void UpdateNotification(); |
+ void UpdateTrayBubbleView(); |
- LimitState limit_state_; |
base::TimeTicks session_start_time_; |
base::TimeDelta limit_; |
base::TimeDelta remaining_session_time_; |
+ |
+ LimitState limit_state_; |
+ LimitState last_limit_state_; |
+ base::string16 notification_message_; |
+ base::string16 last_notification_message_; |
+ base::string16 tray_bubble_message_; |
+ base::string16 last_tray_bubble_message_; |
+ LabelTrayView* tray_bubble_view_; |
+ |
scoped_ptr<base::RepeatingTimer<TraySessionLengthLimit> > timer_; |
DISALLOW_COPY_AND_ASSIGN(TraySessionLengthLimit); |