Index: chrome/browser/ui/views/frame/browser_non_client_frame_view_aura.cc |
diff --git a/chrome/browser/ui/views/frame/browser_non_client_frame_view_aura.cc b/chrome/browser/ui/views/frame/browser_non_client_frame_view_aura.cc |
index 6ddca59b240681092640b61f539ad0e1fc76f157..41ddf810144e5030c2c3c22a7ea0fb3934c3745c 100644 |
--- a/chrome/browser/ui/views/frame/browser_non_client_frame_view_aura.cc |
+++ b/chrome/browser/ui/views/frame/browser_non_client_frame_view_aura.cc |
@@ -15,6 +15,8 @@ |
#include "grit/theme_resources.h" |
#include "grit/theme_resources_standard.h" |
#include "grit/ui_resources.h" |
+#include "ui/aura/window.h" |
+#include "ui/aura/client/aura_constants.h" |
#include "ui/base/accessibility/accessible_view_state.h" |
#include "ui/base/hit_test.h" |
#include "ui/base/l10n/l10n_util.h" |
@@ -70,7 +72,16 @@ BrowserNonClientFrameViewAura::~BrowserNonClientFrameViewAura() { |
void BrowserNonClientFrameViewAura::Init() { |
// Caption buttons. |
- maximize_button_ = new ash::FrameMaximizeButton(this, this); |
+ ash::FrameMaximizeButton* maximize_button = |
+ new ash::FrameMaximizeButton(this, this); |
+ maximize_button_ = maximize_button; |
+ // Disable snap left/right and maximize for always-on-top windows |
+ // (e.g. Panels). |
+ if (frame()->GetNativeWindow()->GetProperty( |
sky
2012/03/25 22:53:05
Can we be more explicit and look for panels here r
stevenjb
2012/03/25 23:11:37
Resizing Panels works fine, but the behavior is br
|
+ aura::client::kAlwaysOnTopKey)) { |
+ maximize_button->set_is_left_right_enabled(false); |
+ maximize_button->set_is_maximize_enabled(false); |
+ } |
maximize_button_->SetAccessibleName( |
l10n_util::GetStringUTF16(IDS_ACCNAME_MAXIMIZE)); |
AddChildView(maximize_button_); |
@@ -239,6 +250,9 @@ void BrowserNonClientFrameViewAura::ButtonPressed(views::Button* sender, |
if (sender == maximize_button_) { |
// The maximize button may move out from under the cursor. |
ResetWindowControls(); |
+ // Don't maximize if always-on-top (e.g. Panels). |
+ if (frame()->GetNativeWindow()->GetProperty(aura::client::kAlwaysOnTopKey)) |
+ return; |
if (frame()->IsMaximized()) |
frame()->Restore(); |
else |