OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "ash/system/chromeos/tray_caps_lock.h" | 5 #include "ash/system/chromeos/tray_caps_lock.h" |
6 | 6 |
7 #include "ash/metrics/user_metrics_recorder.h" | 7 #include "ash/metrics/user_metrics_recorder.h" |
8 #include "ash/shell.h" | 8 #include "ash/shell.h" |
9 #include "ash/system/tray/actionable_view.h" | 9 #include "ash/system/tray/actionable_view.h" |
10 #include "ash/system/tray/fixed_sized_image_view.h" | 10 #include "ash/system/tray/fixed_sized_image_view.h" |
(...skipping 111 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
122 | 122 |
123 DISALLOW_COPY_AND_ASSIGN(CapsLockDefaultView); | 123 DISALLOW_COPY_AND_ASSIGN(CapsLockDefaultView); |
124 }; | 124 }; |
125 | 125 |
126 TrayCapsLock::TrayCapsLock(SystemTray* system_tray) | 126 TrayCapsLock::TrayCapsLock(SystemTray* system_tray) |
127 : TrayImageItem(system_tray, IDR_AURA_UBER_TRAY_CAPS_LOCK), | 127 : TrayImageItem(system_tray, IDR_AURA_UBER_TRAY_CAPS_LOCK), |
128 default_(NULL), | 128 default_(NULL), |
129 detailed_(NULL), | 129 detailed_(NULL), |
130 caps_lock_enabled_(CapsLockIsEnabled()), | 130 caps_lock_enabled_(CapsLockIsEnabled()), |
131 message_shown_(false) { | 131 message_shown_(false) { |
132 // Make sure the event is processed by this before the IME. | 132 chromeos::input_method::XKeyboard* xkeyboard = |
133 Shell::GetInstance()->PrependPreTargetHandler(this); | 133 chromeos::input_method::InputMethodManager::Get()->GetXKeyboard(); |
134 xkeyboard->AddObserver(this); | |
134 } | 135 } |
135 | 136 |
136 TrayCapsLock::~TrayCapsLock() { | 137 TrayCapsLock::~TrayCapsLock() { |
137 Shell::GetInstance()->RemovePreTargetHandler(this); | 138 chromeos::input_method::XKeyboard* xkeyboard = |
139 chromeos::input_method::InputMethodManager::Get()->GetXKeyboard(); | |
140 xkeyboard->RemoveObserver(this); | |
138 } | 141 } |
139 | 142 |
140 void TrayCapsLock::OnCapsLockChanged(bool enabled) { | 143 void TrayCapsLock::OnCapsLockChanged() { |
144 caps_lock_enabled_ = !caps_lock_enabled_; | |
Daniel Erat
2014/04/09 20:27:00
i don't like this -- it seems like it's too easy t
Mr4D (OOO till 08-26)
2014/04/09 23:27:02
Done!
| |
145 | |
141 if (tray_view()) | 146 if (tray_view()) |
142 tray_view()->SetVisible(enabled); | 147 tray_view()->SetVisible(caps_lock_enabled_); |
143 | |
144 caps_lock_enabled_ = enabled; | |
145 | 148 |
146 if (default_) { | 149 if (default_) { |
147 default_->Update(enabled); | 150 default_->Update(caps_lock_enabled_); |
148 } else { | 151 } else { |
149 if (enabled) { | 152 if (caps_lock_enabled_) { |
150 if (!message_shown_) { | 153 if (!message_shown_) { |
151 Shell::GetInstance()->metrics()->RecordUserMetricsAction( | 154 Shell::GetInstance()->metrics()->RecordUserMetricsAction( |
152 ash::UMA_STATUS_AREA_CAPS_LOCK_POPUP); | 155 ash::UMA_STATUS_AREA_CAPS_LOCK_POPUP); |
153 PopupDetailedView(kTrayPopupAutoCloseDelayForTextInSeconds, false); | 156 PopupDetailedView(kTrayPopupAutoCloseDelayForTextInSeconds, false); |
154 message_shown_ = true; | 157 message_shown_ = true; |
155 } | 158 } |
156 } else if (detailed_) { | 159 } else if (detailed_) { |
157 detailed_->GetWidget()->Close(); | 160 detailed_->GetWidget()->Close(); |
158 } | 161 } |
159 } | 162 } |
160 } | 163 } |
161 | 164 |
162 void TrayCapsLock::OnKeyEvent(ui::KeyEvent* key) { | |
163 if (key->type() == ui::ET_KEY_PRESSED && key->key_code() == ui::VKEY_CAPITAL) | |
164 OnCapsLockChanged(!caps_lock_enabled_); | |
165 } | |
166 | |
167 bool TrayCapsLock::GetInitialVisibility() { | 165 bool TrayCapsLock::GetInitialVisibility() { |
168 return CapsLockIsEnabled(); | 166 return CapsLockIsEnabled(); |
169 } | 167 } |
170 | 168 |
171 views::View* TrayCapsLock::CreateDefaultView(user::LoginStatus status) { | 169 views::View* TrayCapsLock::CreateDefaultView(user::LoginStatus status) { |
172 if (!caps_lock_enabled_) | 170 if (!caps_lock_enabled_) |
173 return NULL; | 171 return NULL; |
174 DCHECK(default_ == NULL); | 172 DCHECK(default_ == NULL); |
175 default_ = new CapsLockDefaultView; | 173 default_ = new CapsLockDefaultView; |
176 default_->Update(caps_lock_enabled_); | 174 default_->Update(caps_lock_enabled_); |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
208 | 206 |
209 void TrayCapsLock::DestroyDefaultView() { | 207 void TrayCapsLock::DestroyDefaultView() { |
210 default_ = NULL; | 208 default_ = NULL; |
211 } | 209 } |
212 | 210 |
213 void TrayCapsLock::DestroyDetailedView() { | 211 void TrayCapsLock::DestroyDetailedView() { |
214 detailed_ = NULL; | 212 detailed_ = NULL; |
215 } | 213 } |
216 | 214 |
217 } // namespace ash | 215 } // namespace ash |
OLD | NEW |