Index: chrome/browser/ui/toolbar/toolbar_action_view_controller.h |
diff --git a/chrome/browser/ui/toolbar/toolbar_action_view_controller.h b/chrome/browser/ui/toolbar/toolbar_action_view_controller.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..b185ab4d86b97258604b0dbf138ae269343cb7fa |
--- /dev/null |
+++ b/chrome/browser/ui/toolbar/toolbar_action_view_controller.h |
@@ -0,0 +1,89 @@ |
+// Copyright 2014 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 CHROME_BROWSER_UI_TOOLBAR_TOOLBAR_ACTION_VIEW_CONTROLLER_H_ |
+#define CHROME_BROWSER_UI_TOOLBAR_TOOLBAR_ACTION_VIEW_CONTROLLER_H_ |
+ |
+#include "base/strings/string16.h" |
+#include "ui/gfx/image/image.h" |
+ |
+namespace content { |
+class WebContents; |
+} |
+ |
+namespace gfx { |
+class Canvas; |
+class Rect; |
+} |
+ |
+class ToolbarActionViewDelegate; |
+ |
+// The basic controller class for an action that is shown on the toolbar - |
+// an extension action (like browser actions) or a component action (like |
+// chromecast). |
+class ToolbarActionViewController { |
+ public: |
+ virtual ~ToolbarActionViewController() {} |
+ |
+ // Returns the unique ID of this particular action. For extensions, this is |
+ // the extension id; for component actions, this is the name of the component. |
+ virtual const std::string& GetId() const = 0; |
+ |
+ // Sets the view delegate, which can handle most of the front-end logic. |
+ virtual void SetDelegate(ToolbarActionViewDelegate* delegate) = 0; |
+ |
+ // Returns the icon to use for the given |web_contents|. |
+ virtual gfx::Image GetIcon(content::WebContents* web_contents) = 0; |
+ |
+ // Returns the icon and the badge, if any, for the current tab. |
+ virtual gfx::ImageSkia GetIconWithBadge() = 0; |
+ |
+ // Returns the accessible name to use for the given |web_contents|. |
+ virtual base::string16 GetAccessibleName(content::WebContents* web_contents) |
+ const = 0; |
+ |
+ // Returns the tooltip to use for the given |web_contents|. |
+ virtual base::string16 GetTooltip(content::WebContents* web_contents) |
+ const = 0; |
+ |
+ // Returns true if the action should be enabled on the given |web_contents|. |
+ virtual bool IsEnabled(content::WebContents* web_contents) const = 0; |
+ |
+ // Returns true if the action has a popup for the given |web_contents|. |
+ virtual bool HasPopup(content::WebContents* web_contents) const = 0; |
+ |
+ // Hides the current popup, if one is visible. |
+ virtual void HidePopup() = 0; |
+ |
+ // Returns the native view for the popup, if one is active. |
+ virtual gfx::NativeView GetPopupNativeView() = 0; |
+ |
+ // Returns true if a menu is currently running for the action. |
+ virtual bool IsMenuRunning() const = 0; |
+ |
+ // Returns true if this view can be dragged. This should only be true for |
+ // extensions right now, since they are the only ones the model currently |
+ // supports. |
+ // TODO(devlin): Tweak the model so that it supports generic actions. |
+ virtual bool CanDrag() const = 0; |
+ |
+ // Executes the default action (which is typically showing the popup). If |
+ // |by_user| is true, then this was through a direct user action (as oppposed |
+ // to, e.g., an API call). |
+ // Returns true if a popup is shown. |
+ virtual bool ExecuteAction(bool by_user) = 0; |
+ |
+ // Paints any extra parts of the image (e.g., a badge). |
+ virtual void PaintExtra(gfx::Canvas* canvas, |
+ const gfx::Rect& bounds, |
+ content::WebContents* web_contents) const { |
+ } |
+ |
+ // Registers an accelerator. Called when the view is added to the hierarchy. |
+ // Unregistering any commands is the responsibility of the controller. |
+ virtual void RegisterCommand() { |
+ } |
+}; |
+ |
+#endif // CHROME_BROWSER_UI_TOOLBAR_TOOLBAR_ACTION_VIEW_CONTROLLER_H_ |