summaryrefslogtreecommitdiff
path: root/chromium/ash/system/chromeos/screen_security/screen_capture_tray_item.cc
diff options
context:
space:
mode:
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.cc91
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