Index: chrome/browser/ui/views/constrained_window_views.h |
diff --git a/chrome/browser/ui/views/constrained_window_views.h b/chrome/browser/ui/views/constrained_window_views.h |
index 97d5b6049c28080bead032b941a0d4f92e7537d6..2e20a54df5db098788638e40180a641551b52af8 100644 |
--- a/chrome/browser/ui/views/constrained_window_views.h |
+++ b/chrome/browser/ui/views/constrained_window_views.h |
@@ -7,6 +7,8 @@ |
#include "base/compiler_specific.h" |
#include "chrome/browser/ui/constrained_window.h" |
+#include "content/public/browser/notification_observer.h" |
+#include "content/public/browser/notification_registrar.h" |
#include "content/public/browser/web_contents_observer.h" |
#include "ui/gfx/native_widget_types.h" |
#include "ui/gfx/rect.h" |
@@ -59,11 +61,19 @@ class NativeConstrainedWindow { |
class ConstrainedWindowViews : public views::Widget, |
public ConstrainedWindow, |
public NativeConstrainedWindowDelegate, |
- public content::WebContentsObserver { |
+ public content::WebContentsObserver, |
+ public content::NotificationObserver { |
public: |
+ // Types of insets to use with chrome style frame. |
+ enum ChromeStyleClientInsets { |
+ DEFAULT_INSETS, |
+ NO_INSETS, |
+ }; |
+ |
ConstrainedWindowViews(content::WebContents* web_contents, |
views::WidgetDelegate* widget_delegate, |
- bool enable_chrome_style); |
+ bool enable_chrome_style, |
+ ChromeStyleClientInsets chrome_style_client_insets); |
virtual ~ConstrainedWindowViews(); |
// Returns the WebContents that constrains this Constrained Window. |
@@ -78,6 +88,9 @@ class ConstrainedWindowViews : public views::Widget, |
// Overridden from views::Widget: |
void CenterWindow(const gfx::Size& size); |
+ // Default insets for the dialog: |
+ static gfx::Insets GetDefaultInsets(); |
+ |
private: |
void NotifyTabHelperWillClose(); |
@@ -91,21 +104,30 @@ class ConstrainedWindowViews : public views::Widget, |
AsNativeWidgetDelegate() OVERRIDE; |
virtual int GetNonClientComponent(const gfx::Point& point) OVERRIDE; |
- // Set the top of the window to overlap the browser chrome. |
- void PositionChromeStyleWindow(); |
- |
// Overridden from content::WebContentsObserver: |
virtual void WebContentsDestroyed(content::WebContents* web_contents) |
OVERRIDE; |
- content::WebContents* web_contents_; |
+ // Overridden from content::NotificationObserver: |
+ virtual void Observe(int type, |
+ const content::NotificationSource& source, |
+ const content::NotificationDetails& details) OVERRIDE; |
- NativeConstrainedWindow* native_constrained_window_; |
+ // Set the top of the window to overlap the browser chrome. |
+ void PositionChromeStyleWindow(const gfx::Size& size); |
+ |
+ content::NotificationRegistrar registrar_; |
+ content::WebContents* web_contents_; |
// TODO(wittman): remove once all constrained window dialogs are moved |
// over to Chrome style. |
const bool enable_chrome_style_; |
+ // Client insets to use when |enable_chrome_style_| is true. |
+ ChromeStyleClientInsets chrome_style_client_insets_; |
+ |
+ NativeConstrainedWindow* native_constrained_window_; |
+ |
DISALLOW_COPY_AND_ASSIGN(ConstrainedWindowViews); |
}; |