Chromium Code Reviews| 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); |