diff options
Diffstat (limited to 'chromium/ash/system/chromeos/screen_security/screen_capture_tray_item.cc')
-rw-r--r-- | chromium/ash/system/chromeos/screen_security/screen_capture_tray_item.cc | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/chromium/ash/system/chromeos/screen_security/screen_capture_tray_item.cc b/chromium/ash/system/chromeos/screen_security/screen_capture_tray_item.cc new file mode 100644 index 00000000000..6563e4bad86 --- /dev/null +++ b/chromium/ash/system/chromeos/screen_security/screen_capture_tray_item.cc @@ -0,0 +1,91 @@ +// Copyright 2013 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. + +#include "ash/system/chromeos/screen_security/screen_capture_tray_item.h" + +#include "ash/shell.h" +#include "grit/ash_resources.h" +#include "grit/ash_strings.h" +#include "ui/base/l10n/l10n_util.h" +#include "ui/base/resource/resource_bundle.h" +#include "ui/message_center/message_center.h" +#include "ui/message_center/notification.h" + +using message_center::Notification; + +namespace ash { +namespace internal { +namespace { + +const char kScreenCaptureNotificationId[] = "chrome://screen/capture"; + +} // namespace + +ScreenCaptureTrayItem::ScreenCaptureTrayItem(SystemTray* system_tray) + : ScreenTrayItem(system_tray) { + Shell::GetInstance()->system_tray_notifier()-> + AddScreenCaptureObserver(this); +} + +ScreenCaptureTrayItem::~ScreenCaptureTrayItem() { + Shell::GetInstance()->system_tray_notifier()-> + RemoveScreenCaptureObserver(this); +} + +views::View* ScreenCaptureTrayItem::CreateTrayView(user::LoginStatus status) { + set_tray_view( + new tray::ScreenTrayView(this, IDR_AURA_UBER_TRAY_DISPLAY_LIGHT)); + return tray_view(); +} + +views::View* ScreenCaptureTrayItem::CreateDefaultView( + user::LoginStatus status) { + set_default_view(new tray::ScreenStatusView( + this, + IDR_AURA_UBER_TRAY_DISPLAY, + screen_capture_status_, + l10n_util::GetStringUTF16( + IDS_ASH_STATUS_TRAY_SCREEN_CAPTURE_STOP))); + return default_view(); +} + +void ScreenCaptureTrayItem::CreateOrUpdateNotification() { + message_center::RichNotificationData data; + data.buttons.push_back(message_center::ButtonInfo( + l10n_util::GetStringUTF16(IDS_ASH_STATUS_TRAY_SCREEN_CAPTURE_STOP))); + ui::ResourceBundle& resource_bundle = ui::ResourceBundle::GetSharedInstance(); + scoped_ptr<Notification> notification(new Notification( + message_center::NOTIFICATION_TYPE_SIMPLE, + kScreenCaptureNotificationId, + screen_capture_status_, + base::string16() /* body is blank */, + resource_bundle.GetImageNamed(IDR_AURA_UBER_TRAY_DISPLAY), + base::string16() /* display_source */, + std::string() /* extension_id */, + data, + new tray::ScreenNotificationDelegate(this))); + notification->SetSystemPriority(); + message_center::MessageCenter::Get()->AddNotification(notification.Pass()); +} + +std::string ScreenCaptureTrayItem::GetNotificationId() { + return kScreenCaptureNotificationId; +} + +void ScreenCaptureTrayItem::OnScreenCaptureStart( + const base::Closure& stop_callback, + const base::string16& screen_capture_status) { + screen_capture_status_ = screen_capture_status; + Start(stop_callback); +} + +void ScreenCaptureTrayItem::OnScreenCaptureStop() { + // We do not need to run the stop callback when + // screen capture is stopped externally. + set_is_started(false); + Update(); +} + +} // namespace internal +} // namespace ash |