Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(286)

Unified Diff: ash/system/tray_locale.h

Issue 10391177: Add TrayLocale for locale change notifications. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: ash/system/tray_locale.h
diff --git a/ash/system/tray_locale.h b/ash/system/tray_locale.h
new file mode 100644
index 0000000000000000000000000000000000000000..231e8ab64266dbe95e43edaad79a2552d4d1623c
--- /dev/null
+++ b/ash/system/tray_locale.h
@@ -0,0 +1,70 @@
+// Copyright (c) 2012 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.
+
+#ifndef ASH_SYSTEM_TRAY_LOCALE_H_
+#define ASH_SYSTEM_TRAY_LOCALE_H_
+#pragma once
+
+#include <string>
+
+#include "ash/system/tray/tray_image_item.h"
+
+namespace ash {
+
+class ASH_EXPORT LocaleChangeDelegate {
sadrul 2012/05/17 03:15:44 LocaleChangeDelegate and LocaleObserver could move
stevenjb 2012/05/17 16:58:57 Fair point. Created a locale/ subdirectory Moved
+ public:
+ virtual ~LocaleChangeDelegate() {}
+
+ virtual void AcceptLocaleChange() = 0;
+ virtual void RevertLocaleChange() = 0;
+};
+
+class ASH_EXPORT LocaleObserver {
+ public:
+ virtual ~LocaleObserver() {}
+
+ virtual void OnLocaleChanged(LocaleChangeDelegate* delegate,
+ const std::string& cur_locale,
+ const std::string& from_locale,
+ const std::string& to_locale) = 0;
+};
+
+namespace internal {
+
+namespace tray {
+class LocaleNotificationView;
+}
+
+class TrayLocale : public TrayImageItem,
+ public LocaleObserver {
+ public:
+ TrayLocale();
+ virtual ~TrayLocale();
+
+ private:
+ // Overridden from TrayImageItem.
+ virtual bool GetInitialVisibility() OVERRIDE;
+ virtual views::View* CreateNotificationView(
+ user::LoginStatus status) OVERRIDE;
+ virtual void DestroyNotificationView() OVERRIDE;
+
+ // Overridden from LocaleObserver.
+ virtual void OnLocaleChanged(LocaleChangeDelegate* delegate,
+ const std::string& cur_locale,
+ const std::string& from_locale,
+ const std::string& to_locale) OVERRIDE;
+
+ tray::LocaleNotificationView* notification_;
+ LocaleChangeDelegate* delegate_;
+ std::string cur_locale_;
+ std::string from_locale_;
+ std::string to_locale_;
+
+ DISALLOW_COPY_AND_ASSIGN(TrayLocale);
+};
+
+} // namespace internal
+} // namespace ash
+
+#endif // ASH_SYSTEM_TRAY_LOCALE_H_

Powered by Google App Engine
This is Rietveld 408576698