summaryrefslogtreecommitdiffstats
path: root/chrome
diff options
context:
space:
mode:
Diffstat (limited to 'chrome')
-rw-r--r--chrome/browser/browser_resources.grd2
-rw-r--r--chrome/browser/extensions/extension_host.cc65
-rw-r--r--chrome/browser/extensions/extension_host.h3
-rw-r--r--chrome/browser/renderer_host/render_view_host.cc14
-rw-r--r--chrome/browser/renderer_host/render_view_host.h6
-rw-r--r--chrome/browser/resources/extensions_toolstrip.css10
-rw-r--r--chrome/browser/views/bookmark_bar_view.cc43
-rw-r--r--chrome/browser/views/bookmark_bar_view.h21
-rw-r--r--chrome/browser/views/detachable_toolbar_view.cc262
-rw-r--r--chrome/browser/views/detachable_toolbar_view.h98
-rw-r--r--chrome/browser/views/extensions/extension_shelf.cc257
-rw-r--r--chrome/browser/views/extensions/extension_shelf.h41
-rw-r--r--chrome/browser/views/frame/browser_view.cc275
-rw-r--r--chrome/browser/views/frame/browser_view.h3
-rw-r--r--chrome/chrome.gyp2
-rw-r--r--chrome/common/render_messages_internal.h5
-rw-r--r--chrome/renderer/render_view.cc10
-rw-r--r--chrome/renderer/render_view.h10
-rw-r--r--chrome/renderer/user_script_slave.cc2
19 files changed, 487 insertions, 642 deletions
diff --git a/chrome/browser/browser_resources.grd b/chrome/browser/browser_resources.grd
index 44ea2c3..15777e7 100644
--- a/chrome/browser/browser_resources.grd
+++ b/chrome/browser/browser_resources.grd
@@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<!-- This comment is only here because changes to resources are not picked up
-without changes to the corresponding grd file. fb01 -->
+without changes to the corresponding grd file. mp2 -->
<grit latest_public_release="0" current_release="1">
<outputs>
<output filename="grit/browser_resources.h" type="rc_header">
diff --git a/chrome/browser/extensions/extension_host.cc b/chrome/browser/extensions/extension_host.cc
index 2a19667..c483070 100644
--- a/chrome/browser/extensions/extension_host.cc
+++ b/chrome/browser/extensions/extension_host.cc
@@ -8,7 +8,6 @@
#include "base/string_util.h"
#include "chrome/browser/browser.h"
#include "chrome/browser/browser_list.h"
-#include "chrome/browser/browser_theme_provider.h"
#include "chrome/browser/debugger/devtools_manager.h"
#include "chrome/browser/extensions/extension_message_service.h"
#include "chrome/browser/extensions/extension_tabs_module.h"
@@ -37,8 +36,6 @@ using WebKit::WebDragOperationsMask;
// static
bool ExtensionHost::enable_dom_automation_ = false;
-static const char* kToolstripTextColorSubstitution = "$TEXT_COLOR$";
-
ExtensionHost::ExtensionHost(Extension* extension, SiteInstance* site_instance,
const GURL& url, ViewType::Type host_type)
: extension_(extension),
@@ -153,57 +150,33 @@ void ExtensionHost::DidNavigate(RenderViewHost* render_view_host,
new ExtensionFunctionDispatcher(render_view_host_, this, url_));
}
-void ExtensionHost::InsertCssIfToolstrip() {
+void ExtensionHost::DidStopLoading(RenderViewHost* render_view_host) {
+ static const base::StringPiece toolstrip_css(
+ ResourceBundle::GetSharedInstance().GetRawDataResource(
+ IDR_EXTENSIONS_TOOLSTRIP_CSS));
#if defined(TOOLKIT_VIEWS)
ExtensionView* view = view_.get();
- if (!view)
- return;
- if (!view->is_toolstrip()) {
- // No CSS injecting currently, but call SetDidInsertCSS to tell the view
- // that it's OK to display.
- view->SetDidInsertCSS(true);
- return;
+ if (view) {
+ // TODO(erikkay) this injection should really happen in the renderer.
+ // When the Jerry's view type change lands, investigate moving this there.
+
+ // As a toolstrip, inject our toolstrip CSS to make it easier for toolstrips
+ // to blend in with the chrome UI.
+ if (view->is_toolstrip()) {
+ render_view_host->InsertCSSInWebFrame(L"", toolstrip_css.as_string());
+ } else {
+ // No CSS injecting currently, but call SetDidInsertCSS to tell the view
+ // that it's OK to display.
+ view->SetDidInsertCSS(true);
+ }
}
#elif defined(OS_LINUX)
ExtensionViewGtk* view = view_.get();
- if (!view || !view->is_toolstrip())
- return;
-#endif
-
- static const base::StringPiece toolstrip_css(
- ResourceBundle::GetSharedInstance().GetRawDataResource(
- IDR_EXTENSIONS_TOOLSTRIP_CSS));
-
- std::string css = toolstrip_css.as_string();
- ThemeProvider* theme_provider =
- render_view_host()->process()->profile()->GetThemeProvider();
-
- SkColor text_color = theme_provider ?
- theme_provider->GetColor(BrowserThemeProvider::COLOR_BOOKMARK_TEXT) :
- SK_ColorBLACK;
-
- std::string hex_color_string = StringPrintf(
- "#%02x%02x%02x", SkColorGetR(text_color),
- SkColorGetG(text_color),
- SkColorGetB(text_color));
- size_t pos = css.find(kToolstripTextColorSubstitution);
- while (pos != std::string::npos) {
- css.replace(pos, 12, hex_color_string);
- pos = css.find(kToolstripTextColorSubstitution);
+ if (view && view->is_toolstrip()) {
+ render_view_host->InsertCSSInWebFrame(L"", toolstrip_css.as_string());
}
-
-#if defined(TOOLKIT_VIEWS) || defined(OS_LINUX)
- // TODO(erikkay) this injection should really happen in the renderer.
- // When the Jerry's view type change lands, investigate moving this there.
-
- // As a toolstrip, inject our toolstrip CSS to make it easier for toolstrips
- // to blend in with the chrome UI.
- render_view_host()->InsertCSSInWebFrame(L"", css, "ToolstripDefaultCss");
#endif
-}
-void ExtensionHost::DidStopLoading(RenderViewHost* render_view_host) {
- InsertCssIfToolstrip();
if (!did_stop_loading_) {
NotificationService::current()->Notify(
NotificationType::EXTENSION_HOST_DID_STOP_LOADING,
diff --git a/chrome/browser/extensions/extension_host.h b/chrome/browser/extensions/extension_host.h
index b6e25e5..76c1014 100644
--- a/chrome/browser/extensions/extension_host.h
+++ b/chrome/browser/extensions/extension_host.h
@@ -76,9 +76,6 @@ class ExtensionHost : public RenderViewHostDelegate,
// Sets |url_| and navigates |render_view_host_|.
void NavigateToURL(const GURL& url);
- // Insert the CSS for a toolstrip.
- void InsertCssIfToolstrip();
-
// RenderViewHostDelegate implementation.
virtual RenderViewHostDelegate::View* GetViewDelegate();
virtual const GURL& GetURL() const { return url_; }
diff --git a/chrome/browser/renderer_host/render_view_host.cc b/chrome/browser/renderer_host/render_view_host.cc
index 6d92b81..bab8ac8 100644
--- a/chrome/browser/renderer_host/render_view_host.cc
+++ b/chrome/browser/renderer_host/render_view_host.cc
@@ -510,10 +510,8 @@ void RenderViewHost::ExecuteJavascriptInWebFrame(
}
void RenderViewHost::InsertCSSInWebFrame(
- const std::wstring& frame_xpath,
- const std::string& css,
- const std::string& id) {
- Send(new ViewMsg_CSSInsertRequest(routing_id(), frame_xpath, css, id));
+ const std::wstring& frame_xpath, const std::string& css) {
+ Send(new ViewMsg_CSSInsertRequest(routing_id(), frame_xpath, css));
}
void RenderViewHost::AddMessageToConsole(
@@ -613,7 +611,7 @@ void RenderViewHost::JavaScriptMessageBoxClosed(IPC::Message* reply_msg,
}
void RenderViewHost::JavaScriptMessageBoxWindowDestroyed() {
- ResetModalDialogEvent();
+ ResetModalDialogEvent();
}
void RenderViewHost::ModalHTMLDialogClosed(IPC::Message* reply_msg,
@@ -1113,7 +1111,7 @@ void RenderViewHost::OnMsgFindReply(int request_id,
void RenderViewHost::OnDeterminePageTextReply(
const std::wstring& page_text) {
-#if defined(OS_WIN) // Only for windows.
+#if defined(OS_WIN) // Only for windows.
int num_languages = 0;
bool is_reliable = false;
const char* language_iso_code = LanguageCodeISO639_1(
@@ -1673,8 +1671,8 @@ void RenderViewHost::SignalModalDialogEvent() {
}
void RenderViewHost::ResetModalDialogEvent() {
- if (--modal_dialog_count_ == 0)
- modal_dialog_event_->Reset();
+ if (--modal_dialog_count_ == 0)
+ modal_dialog_event_->Reset();
}
void RenderViewHost::UpdateBrowserWindowId(int window_id) {
diff --git a/chrome/browser/renderer_host/render_view_host.h b/chrome/browser/renderer_host/render_view_host.h
index 30f9709..5be72a4 100644
--- a/chrome/browser/renderer_host/render_view_host.h
+++ b/chrome/browser/renderer_host/render_view_host.h
@@ -258,11 +258,9 @@ class RenderViewHost : public RenderWidgetHost,
void ExecuteJavascriptInWebFrame(const std::wstring& frame_xpath,
const std::wstring& jscript);
- // Insert some css into a frame in the page. |id| is optional, and specifies
- // the element id given when inserting/replacing the style element.
+ // Insert some css into a frame in the page.
void InsertCSSInWebFrame(const std::wstring& frame_xpath,
- const std::string& css,
- const std::string& id);
+ const std::string& css);
// Logs a message to the console of a frame in the page.
void AddMessageToConsole(const string16& frame_xpath,
diff --git a/chrome/browser/resources/extensions_toolstrip.css b/chrome/browser/resources/extensions_toolstrip.css
index 456978f..ee88de6 100644
--- a/chrome/browser/resources/extensions_toolstrip.css
+++ b/chrome/browser/resources/extensions_toolstrip.css
@@ -12,7 +12,8 @@ body {
margin: 0;
padding:0;
font: menu;
- color: $TEXT_COLOR$;
+ color: #062D75;
+ text-shadow: #FFFFFF 1px 1px 0px;
-webkit-user-select:none;
cursor:default;
}
@@ -52,7 +53,8 @@ div.toolstrip-button {
border:6px solid transparent;
font:menu;
background:transparent;
- color: $TEXT_COLOR$;
+ color: #062D75;
+ text-shadow: #FFFFFF 1px 1px 0px;
line-height:100%;
padding:0;
}
@@ -86,10 +88,10 @@ div.toolstrip-button>span {
*/
div.toolstrip-button:hover {
border-width:6px;
- -webkit-border-image:url() 6 round round;
+ -webkit-border-image:url() 6 round round;
}
div.toolstrip-button:active {
border-width:6px;
- -webkit-border-image:url() 6 round round;
+ -webkit-border-image:url() 6 round round;
}
diff --git a/chrome/browser/views/bookmark_bar_view.cc b/chrome/browser/views/bookmark_bar_view.cc
index 24b287c..96dc4b7 100644
--- a/chrome/browser/views/bookmark_bar_view.cc
+++ b/chrome/browser/views/bookmark_bar_view.cc
@@ -80,6 +80,9 @@ static SkBitmap* kFolderIcon = NULL;
// Border colors for the BookmarBarView.
static const SkColor kTopBorderColor = SkColorSetRGB(222, 234, 248);
+// How round the 'new tab' style bookmarks bar is.
+static const int kNewtabBarRoundness = 5;
+
// Offset for where the menu is shown relative to the bottom of the
// BookmarkBarView.
static const int kMenuOffset = 3;
@@ -294,10 +297,25 @@ class BookmarkBarView::ButtonSeparatorView : public views::View {
virtual ~ButtonSeparatorView() {}
virtual void Paint(gfx::Canvas* canvas) {
- DetachableToolbarView::PaintVerticalDivider(
- canvas, kSeparatorStartX, height(), 1, kTopBorderColor,
+ SkPaint paint;
+ paint.setShader(skia::CreateGradientShader(0,
+ height() / 2,
+ kTopBorderColor,
+ kSeparatorColor))->safeUnref();
+ SkRect rc = {SkIntToScalar(kSeparatorStartX), SkIntToScalar(0),
+ SkIntToScalar(1), SkIntToScalar(height() / 2) };
+ canvas->drawRect(rc, paint);
+
+ SkPaint paint_down;
+ paint_down.setShader(skia::CreateGradientShader(height() / 2,
+ height(),
kSeparatorColor,
- GetThemeProvider()->GetColor(BrowserThemeProvider::COLOR_TOOLBAR));
+ GetThemeProvider()->GetColor(BrowserThemeProvider::COLOR_TOOLBAR)
+ ))->safeUnref();
+ SkRect rc_down = {
+ SkIntToScalar(kSeparatorStartX), SkIntToScalar(height() / 2),
+ SkIntToScalar(1), SkIntToScalar(height() - 1) };
+ canvas->drawRect(rc_down, paint_down);
}
virtual gfx::Size GetPreferredSize() {
@@ -718,8 +736,8 @@ void BookmarkBarView::OnStateChanged() {
// re-enter her password. If extension shelf appears along with the bookmark
// shelf, it too needs to be layed out. Since both have the same parent, it is
// enough to let the parent layout both of these children.
- // TODO(sky): This should not require Layout() and SchedulePaint(). Needs
- // some cleanup.
+ // TODO (sky): This should not require Layout() and SchedulePaint(). Needs
+ // some cleanup.
PreferredSizeChanged();
Layout();
SchedulePaint();
@@ -733,19 +751,15 @@ void BookmarkBarView::OnFullscreenToggled(bool fullscreen) {
size_animation_->Reset(0);
}
-bool BookmarkBarView::IsDetached() const {
+bool BookmarkBarView::IsDetachedStyle() {
return OnNewTabPage() && (size_animation_->GetCurrentValue() != 1);
}
-bool BookmarkBarView::IsOnTop() const {
- return true;
-}
-
-bool BookmarkBarView::IsAlwaysShown() const {
+bool BookmarkBarView::IsAlwaysShown() {
return profile_->GetPrefs()->GetBoolean(prefs::kShowBookmarkBar);
}
-bool BookmarkBarView::OnNewTabPage() const {
+bool BookmarkBarView::OnNewTabPage() {
return (browser_ && browser_->GetSelectedTabContents() &&
browser_->GetSelectedTabContents()->IsBookmarkBarAlwaysVisible());
}
@@ -1076,7 +1090,7 @@ void BookmarkBarView::RunMenu(views::View* view,
int x = view->GetX(APPLY_MIRRORING_TRANSFORMATION);
int bar_height = height() - kMenuOffset;
- if (IsDetached())
+ if (IsDetachedStyle())
bar_height -= kNewtabVerticalPadding;
int start_index = 0;
@@ -1671,8 +1685,7 @@ gfx::Size BookmarkBarView::LayoutItems(bool compute_bounds_only) {
if (should_show_sync_error_button) {
x += kButtonPadding;
if (!compute_bounds_only) {
- sync_error_button_->SetBounds(
- x, y, sync_error_button_pref.width(), height);
+ sync_error_button_->SetBounds(x, y, sync_error_button_pref.width(), height);
sync_error_button_->SetVisible(true);
}
x += sync_error_button_pref.width();
diff --git a/chrome/browser/views/bookmark_bar_view.h b/chrome/browser/views/bookmark_bar_view.h
index 20fcc07..06b44f2 100644
--- a/chrome/browser/views/bookmark_bar_view.h
+++ b/chrome/browser/views/bookmark_bar_view.h
@@ -11,7 +11,6 @@
#include "chrome/browser/extensions/extensions_service.h"
#include "chrome/browser/sync/profile_sync_service.h"
#include "chrome/browser/views/bookmark_menu_controller_views.h"
-#include "chrome/browser/views/detachable_toolbar_view.h"
#include "chrome/common/notification_registrar.h"
#include "views/controls/button/menu_button.h"
#include "views/controls/label.h"
@@ -34,7 +33,7 @@ class MenuItemView;
// BookmarkBarView shows the bookmarks from a specific Profile. BookmarkBarView
// waits until the HistoryService for the profile has been loaded before
// creating the BookmarkModel.
-class BookmarkBarView : public DetachableToolbarView,
+class BookmarkBarView : public views::View,
#ifdef CHROME_PERSONALIZATION
public ProfileSyncServiceObserver,
#endif
@@ -89,13 +88,6 @@ class BookmarkBarView : public DetachableToolbarView,
// the bookmark bar.
void SetPageNavigator(PageNavigator* navigator);
- // DetachableToolbarView methods:
- virtual bool IsDetached() const;
- virtual bool IsOnTop() const;
- virtual double GetAnimationValue() const {
- return size_animation_->GetCurrentValue();
- }
-
// View methods:
virtual gfx::Size GetPreferredSize();
virtual gfx::Size GetMinimumSize();
@@ -116,6 +108,9 @@ class BookmarkBarView : public DetachableToolbarView,
virtual bool GetAccessibleName(std::wstring* name);
virtual bool GetAccessibleRole(AccessibilityTypes::Role* role);
virtual void SetAccessibleName(const std::wstring& name);
+ double GetSizeAnimationValue() const {
+ return size_animation_->GetCurrentValue();
+ }
#ifdef CHROME_PERSONALIZATION
// ProfileSyncServiceObserver method.
@@ -148,11 +143,15 @@ class BookmarkBarView : public DetachableToolbarView,
// Returns the model.
BookmarkModel* GetModel() { return model_; }
+ // Returns true if the bookmark bar is drawn detached from the toolbar. This
+ // can only be true when OnNewTabPage() is true (see below).
+ bool IsDetachedStyle();
+
// Returns true if the bookmarks bar preference is set to 'always show'.
- bool IsAlwaysShown() const;
+ bool IsAlwaysShown();
// True if we're on a page where the bookmarks bar is always visible.
- bool OnNewTabPage() const;
+ bool OnNewTabPage();
// How much we want the bookmark bar to overlap the toolbar. If |return_max|
// is true, we return the maximum overlap rather than the current overlap.
diff --git a/chrome/browser/views/detachable_toolbar_view.cc b/chrome/browser/views/detachable_toolbar_view.cc
deleted file mode 100644
index 9cc81d2..0000000
--- a/chrome/browser/views/detachable_toolbar_view.cc
+++ /dev/null
@@ -1,262 +0,0 @@
-// Copyright (c) 2009 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 "chrome/browser/views/detachable_toolbar_view.h"
-
-#include "app/gfx/canvas.h"
-#include "chrome/browser/browser_theme_provider.h"
-#include "grit/theme_resources.h"
-#include "third_party/skia/include/core/SkBitmap.h"
-
-// How round the 'new tab' style bookmarks bar is.
-static const int kNewtabBarRoundness = 5;
-
-// static
-void DetachableToolbarView::PaintBackgroundDetachedMode(gfx::Canvas* canvas,
- views::View* view) {
- int browser_height = view->GetParent()->GetBounds(
- views::View::APPLY_MIRRORING_TRANSFORMATION).height();
-
- // Draw the background to match the new tab page.
- ThemeProvider* tp = view->GetThemeProvider();
- canvas->FillRectInt(tp->GetColor(BrowserThemeProvider::COLOR_NTP_BACKGROUND),
- 0, 0, view->width(), view->height());
-
- if (tp->HasCustomImage(IDR_THEME_NTP_BACKGROUND)) {
- int tiling = BrowserThemeProvider::NO_REPEAT;
- tp->GetDisplayProperty(BrowserThemeProvider::NTP_BACKGROUND_TILING,
- &tiling);
- int alignment;
- if (tp->GetDisplayProperty(BrowserThemeProvider::NTP_BACKGROUND_ALIGNMENT,
- &alignment)) {
- SkBitmap* ntp_background = tp->GetBitmapNamed(IDR_THEME_NTP_BACKGROUND);
-
- if (alignment & BrowserThemeProvider::ALIGN_TOP) {
- PaintThemeBackgroundTopAligned(
- canvas, ntp_background, tiling, alignment,
- view->width(), view->height());
- } else {
- PaintThemeBackgroundBottomAligned(
- canvas, ntp_background, tiling, alignment,
- view->width(), view->height(), browser_height);
- }
- }
- }
-}
-
-// static
-void DetachableToolbarView::PaintBackgroundAttachedMode(gfx::Canvas* canvas,
- views::View* view) {
- gfx::Rect bounds =
- view->GetBounds(views::View::APPLY_MIRRORING_TRANSFORMATION);
-
- ThemeProvider* tp = view->GetThemeProvider();
- SkColor theme_toolbar_color =
- tp->GetColor(BrowserThemeProvider::COLOR_TOOLBAR);
- canvas->FillRectInt(theme_toolbar_color, 0, 0,
- view->width(), view->height());
-
- canvas->TileImageInt(*tp->GetBitmapNamed(IDR_THEME_TOOLBAR),
- view->GetParent()->GetBounds(
- views::View::APPLY_MIRRORING_TRANSFORMATION).x() + bounds.x(),
- bounds.y(), 0, 0, view->width(), view->height());
-}
-
-// static
-void DetachableToolbarView::CalculateContentArea(
- double animation_state, double horizontal_padding,
- double vertical_padding, SkRect* rect,
- double* roundness, views::View* view) {
- // The 0.5 is to correct for Skia's "draw on pixel boundaries"ness.
- rect->set(SkDoubleToScalar(horizontal_padding - 0.5),
- SkDoubleToScalar(vertical_padding - 0.5),
- SkDoubleToScalar(view->width() - horizontal_padding - 0.5),
- SkDoubleToScalar(view->height() - vertical_padding - 0.5));
-
- *roundness = static_cast<double>(kNewtabBarRoundness) * animation_state;
-}
-
-// static
-void DetachableToolbarView::PaintHorizontalBorder(gfx::Canvas* canvas,
- DetachableToolbarView* view) {
- // Border can be at the top or at the bottom of the view depending on whether
- // the view (bar/shelf) is at the top/at the bottom and whether it is attached
- // or detached.
- int y = view->IsOnTop() == !view->IsDetached() ? view->height() - 1 : 0;
- canvas->FillRectInt(ResourceBundle::toolbar_separator_color,
- 0, y, view->width(), 1);
-}
-
-// static
-void DetachableToolbarView::PaintContentAreaBackground(
- gfx::Canvas* canvas, ThemeProvider* theme_provider,
- const SkRect& rect, double roundness) {
- SkPaint paint;
- paint.setAntiAlias(true);
- paint.setColor(theme_provider->GetColor(BrowserThemeProvider::COLOR_TOOLBAR));
-
- canvas->drawRoundRect(
- rect, SkDoubleToScalar(roundness), SkDoubleToScalar(roundness), paint);
-}
-
-// static
-void DetachableToolbarView::PaintContentAreaBorder(
- gfx::Canvas* canvas, ThemeProvider* theme_provider,
- const SkRect& rect, double roundness) {
- SkPaint border_paint;
- border_paint.setColor(
- theme_provider->GetColor(BrowserThemeProvider::COLOR_NTP_HEADER));
- border_paint.setStyle(SkPaint::kStroke_Style);
- border_paint.setAlpha(96);
- border_paint.setAntiAlias(true);
-
- canvas->drawRoundRect(rect,
- SkDoubleToScalar(roundness),
- SkDoubleToScalar(roundness), border_paint);
-}
-
-// static
-void DetachableToolbarView::PaintVerticalDivider(
- gfx::Canvas* canvas, int x, int height, int vertical_padding,
- const SkColor& top_color,
- const SkColor& middle_color,
- const SkColor& bottom_color) {
- // Draw the upper half of the divider.
- SkPaint paint;
- paint.setShader(skia::CreateGradientShader(vertical_padding + 1,
- height / 2,
- top_color,
- middle_color))->safeUnref();
- SkRect rc = { SkIntToScalar(x),
- SkIntToScalar(vertical_padding + 1),
- SkIntToScalar(x + 1),
- SkIntToScalar(height / 2) };
- canvas->drawRect(rc, paint);
-
- // Draw the lower half of the divider.
- SkPaint paint_down;
- paint_down.setShader(skia::CreateGradientShader(height / 2,
- height - vertical_padding,
- middle_color,
- bottom_color))->safeUnref();
- SkRect rc_down = { SkIntToScalar(x),
- SkIntToScalar(height / 2),
- SkIntToScalar(x + 1),
- SkIntToScalar(height - vertical_padding) };
- canvas->drawRect(rc_down, paint_down);
-}
-
-// static
-void DetachableToolbarView::PaintThemeBackgroundTopAligned(
- gfx::Canvas* canvas, SkBitmap* ntp_background, int tiling, int alignment,
- int width, int height) {
- if (alignment & BrowserThemeProvider::ALIGN_LEFT) {
- if (tiling == BrowserThemeProvider::REPEAT) {
- canvas->TileImageInt(*ntp_background, 0, 0, width, height);
- } else if (tiling == BrowserThemeProvider::REPEAT_X) {
- canvas->TileImageInt(*ntp_background, 0, 0, width,
- ntp_background->height());
- } else {
- canvas->TileImageInt(*ntp_background, 0, 0,
- ntp_background->width(), ntp_background->height());
- }
- } else if (alignment & BrowserThemeProvider::ALIGN_RIGHT) {
- int x_pos = width % ntp_background->width() - ntp_background->width();
- if (tiling == BrowserThemeProvider::REPEAT) {
- canvas->TileImageInt(*ntp_background, x_pos, 0,
- width + ntp_background->width(), height);
- } else if (tiling == BrowserThemeProvider::REPEAT_X) {
- canvas->TileImageInt(*ntp_background, x_pos,
- 0, width + ntp_background->width(), ntp_background->height());
- } else {
- canvas->TileImageInt(*ntp_background, width - ntp_background->width(),
- 0, ntp_background->width(), ntp_background->height());
- }
- } else { // ALIGN == CENTER
- int x_pos = width > ntp_background->width() ?
- ((width / 2 - ntp_background->width() / 2) %
- ntp_background->width()) - ntp_background->width() :
- width / 2 - ntp_background->width() / 2;
- if (tiling == BrowserThemeProvider::REPEAT) {
- canvas->TileImageInt(*ntp_background, x_pos, 0,
- width + ntp_background->width(), height);
- } else if (tiling == BrowserThemeProvider::REPEAT_X) {
- canvas->TileImageInt(*ntp_background, x_pos, 0,
- width + ntp_background->width(),
- ntp_background->height());
- } else {
- canvas->TileImageInt(*ntp_background,
- width / 2 - ntp_background->width() / 2,
- 0, ntp_background->width(), ntp_background->height());
- }
- }
-}
-
-// static
-void DetachableToolbarView::PaintThemeBackgroundBottomAligned(
- gfx::Canvas* canvas, SkBitmap* ntp_background, int tiling, int alignment,
- int width, int height, int browser_height) {
- int border_width = 5;
- int y_pos = ((tiling == BrowserThemeProvider::REPEAT_X) ||
- (tiling == BrowserThemeProvider::NO_REPEAT)) ?
- browser_height - ntp_background->height() - height - border_width :
- browser_height % ntp_background->height() - height - border_width -
- ntp_background->height();
-
- if (alignment & BrowserThemeProvider::ALIGN_LEFT) {
- if (tiling == BrowserThemeProvider::REPEAT) {
- canvas->TileImageInt(*ntp_background, 0, y_pos, width,
- 2 * height + ntp_background->height() + 5);
- } else if (tiling == BrowserThemeProvider::REPEAT_X) {
- canvas->TileImageInt(*ntp_background, 0, y_pos, width,
- ntp_background->height());
- } else if (tiling == BrowserThemeProvider::REPEAT_Y) {
- canvas->TileImageInt(*ntp_background, 0, y_pos,
- ntp_background->width(),
- 2 * height + ntp_background->height() + 5);
- } else {
- canvas->TileImageInt(*ntp_background, 0, y_pos, ntp_background->width(),
- ntp_background->height());
- }
- } else if (alignment & BrowserThemeProvider::ALIGN_RIGHT) {
- int x_pos = width % ntp_background->width() - ntp_background->width();
- if (tiling == BrowserThemeProvider::REPEAT) {
- canvas->TileImageInt(*ntp_background, x_pos, y_pos,
- width + ntp_background->width(),
- 2 * height + ntp_background->height() + 5);
- } else if (tiling == BrowserThemeProvider::REPEAT_X) {
- canvas->TileImageInt(*ntp_background, x_pos, y_pos,
- width + ntp_background->width(), ntp_background->height());
- } else if (tiling == BrowserThemeProvider::REPEAT_Y) {
- canvas->TileImageInt(*ntp_background, width - ntp_background->width(),
- y_pos, ntp_background->width(),
- 2 * height + ntp_background->height() + 5);
- } else {
- canvas->TileImageInt(*ntp_background, width - ntp_background->width(),
- y_pos, ntp_background->width(), ntp_background->height());
- }
- } else { // ALIGN == CENTER
- int x_pos = width > ntp_background->width() ?
- ((width / 2 - ntp_background->width() / 2) %
- ntp_background->width()) - ntp_background->width() :
- width / 2 - ntp_background->width() / 2;
- if (tiling == BrowserThemeProvider::REPEAT) {
- canvas->TileImageInt(*ntp_background, x_pos, y_pos,
- width + ntp_background->width(),
- 2 * height + ntp_background->height() + 5);
- } else if (tiling == BrowserThemeProvider::REPEAT_X) {
- canvas->TileImageInt(*ntp_background, x_pos, y_pos,
- width + ntp_background->width(), ntp_background->height());
- } else if (tiling == BrowserThemeProvider::REPEAT_Y) {
- canvas->TileImageInt(*ntp_background,
- width / 2 - ntp_background->width() / 2,
- y_pos, ntp_background->width(),
- 2 * height + ntp_background->height() + 5);
- } else {
- canvas->TileImageInt(*ntp_background,
- width / 2 - ntp_background->width() / 2,
- y_pos, ntp_background->width(), ntp_background->height());
- }
- }
-}
diff --git a/chrome/browser/views/detachable_toolbar_view.h b/chrome/browser/views/detachable_toolbar_view.h
deleted file mode 100644
index f831ea1..0000000
--- a/chrome/browser/views/detachable_toolbar_view.h
+++ /dev/null
@@ -1,98 +0,0 @@
-// Copyright (c) 2009 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_VIEWS_DETACHABLE_TOOLBAR_VIEW_H_
-#define CHROME_BROWSER_VIEWS_DETACHABLE_TOOLBAR_VIEW_H_
-
-#include "views/view.h"
-
-class SkBitmap;
-struct SkRect;
-
-// DetachableToolbarView contains functionality common to views that can detach
-// from the Chrome frame, such as the BookmarkBarView and the Extension shelf.
-class DetachableToolbarView : public views::View {
- public:
- DetachableToolbarView() {}
- virtual ~DetachableToolbarView() {}
-
- // Whether the view is currently detached from the Chrome frame.
- virtual bool IsDetached() const = 0;
-
- // Whether the shelf/bar is above the page or below it.
- virtual bool IsOnTop() const = 0;
-
- // Gets the current state of the resize animation (show/hide).
- virtual double GetAnimationValue() const = 0;
-
- // Paint the background (including the theme image behind content area) when
- // in bar/shelf is detached from the Chrome frame.
- static void PaintBackgroundDetachedMode(gfx::Canvas* canvas,
- views::View* view);
-
- // Paint the background (including the theme image behind content area) when
- // in bar/shelf is attached to the Chrome frame.
- static void PaintBackgroundAttachedMode(gfx::Canvas* canvas,
- views::View* view);
-
- // Calculate the rect for the content area of the bar/shelf. This is only
- // needed when the bar/shelf is detached from the Chrome frame (otherwise the
- // content area is the whole area of the bar/shelf. When detached, however,
- // only a small round rectangle is for drawing our content on. This calculates
- // how big this area is, where it is located within the shelf and how round
- // the edges should be.
- static void CalculateContentArea(double animation_state,
- double horizontal_padding,
- double vertical_padding,
- SkRect* rect,
- double* roundness,
- views::View* view);
-
- // Paint the horizontal border separating the shelf/bar from the page content.
- static void PaintHorizontalBorder(gfx::Canvas* canvas,
- DetachableToolbarView* view);
-
- // Paint the background of the content area (the surface behind the
- // bookmarks or extension toolstrips). |rect| is the rectangle to paint
- // the background within. |roundness| describes the roundness of the corners.
- static void PaintContentAreaBackground(gfx::Canvas* canvas,
- ThemeProvider* theme_provider,
- const SkRect& rect,
- double roundness);
- // Paint the border around the content area (when in detached mode).
- static void PaintContentAreaBorder(gfx::Canvas* canvas,
- ThemeProvider* theme_provider,
- const SkRect& rect,
- double roundness);
-
- // Paint a themed gradient divider at location |x|. The color of the divider
- // is a gradient starting with |top_color| at the top, and changing into
- // |middle_color| and then over to |bottom_color| as you go further down.
- static void PaintVerticalDivider(gfx::Canvas* canvas,
- int x,
- int height,
- int vertical_padding,
- const SkColor& top_color,
- const SkColor& middle_color,
- const SkColor& bottom_color);
-
- // Paint the theme background with the proper alignment.
- static void PaintThemeBackgroundTopAligned(gfx::Canvas* canvas,
- SkBitmap* ntp_background,
- int tiling,
- int alignment,
- int width,
- int height);
- static void PaintThemeBackgroundBottomAligned(gfx::Canvas* canvas,
- SkBitmap* ntp_background,
- int tiling,
- int alignment,
- int width,
- int height,
- int browser_height);
- private:
- DISALLOW_COPY_AND_ASSIGN(DetachableToolbarView);
-};
-
-#endif // CHROME_BROWSER_VIEWS_DETACHABLE_TOOLBAR_VIEW_H_
diff --git a/chrome/browser/views/extensions/extension_shelf.cc b/chrome/browser/views/extensions/extension_shelf.cc
index 1078f69..91c20b6 100644
--- a/chrome/browser/views/extensions/extension_shelf.cc
+++ b/chrome/browser/views/extensions/extension_shelf.cc
@@ -19,7 +19,6 @@
#include "chrome/browser/profile.h"
#include "chrome/browser/tab_contents/tab_contents.h"
#include "chrome/browser/views/extensions/extension_view.h"
-#include "chrome/common/chrome_switches.h"
#include "chrome/common/extensions/extension.h"
#include "chrome/common/notification_service.h"
#include "chrome/common/pref_names.h"
@@ -46,7 +45,7 @@ static const int kToolstripDividerWidth = 2;
static const int kShelfHeight = 29;
// Preferred height of the Extension shelf when only shown on the new tab page.
-const int kNewtabShelfHeight = 58;
+const int kNewtabShelfHeight = 57;
// How inset the extension shelf is when displayed on the new tab page. This is
// in addition to the margins above.
@@ -59,18 +58,32 @@ static const int kNewtabVerticalPadding = 12;
static const int kNewtabExtraHorMargin = 2;
static const int kNewtabExtraVerMargin = 2;
+// How round the 'new tab' style extension shelf is.
+static const int kNewtabBarRoundness = 5;
+
// Height of the toolstrip within the shelf.
static const int kToolstripHeight = kShelfHeight - (kTopMargin + kBottomMargin);
// Colors for the ExtensionShelf.
+static const SkColor kBackgroundColor = SkColorSetRGB(230, 237, 244);
+static const SkColor kBorderColor = SkColorSetRGB(201, 212, 225);
static const SkColor kDividerHighlightColor = SkColorSetRGB(247, 250, 253);
+// Text colors for the handle.
+static const SkColor kHandleTextColor = SkColorSetRGB(6, 45, 117);
+static const SkColor kHandleTextHighlightColor =
+ SkColorSetARGB(200, 255, 255, 255);
+
// Handle padding.
static const int kHandlePadding = 4;
+// TODO(erikkay) convert back to a gradient when Glen figures out the
+// specs.
+// static const SkColor kBackgroundColor = SkColorSetRGB(237, 244, 252);
+// static const SkColor kTopGradientColor = SkColorSetRGB(222, 234, 248);
+
// Delays for showing and hiding the shelf handle.
-static const int kShowDelayMs = 500;
-static const int kHideDelayMs = 300;
+static const int kHideDelayMs = 500;
} // namespace
@@ -109,7 +122,7 @@ class ExtensionShelf::Toolstrip : public views::View,
// Convenience to calculate just the size of the handle.
gfx::Size GetHandlePreferredSize();
- // View methods:
+ // View
virtual void Paint(gfx::Canvas* canvas);
virtual gfx::Size GetPreferredSize();
virtual void Layout();
@@ -242,6 +255,9 @@ ExtensionShelf::Toolstrip::Toolstrip(ExtensionShelf* shelf,
// the various mouse events necessary for hovering and dragging.
ResourceBundle& rb = ResourceBundle::GetSharedInstance();
title_.reset(new views::Label(name, rb.GetFont(ResourceBundle::BaseFont)));
+ title_->SetColor(kHandleTextColor);
+ title_->SetDrawHighlighted(true);
+ title_->SetHighlightColor(kHandleTextHighlightColor);
title_->SetBounds(kHandlePadding, kHandlePadding, 100, 100);
title_->SizeToPreferredSize();
@@ -254,19 +270,14 @@ ExtensionShelf::Toolstrip::~Toolstrip() {
}
void ExtensionShelf::Toolstrip::Paint(gfx::Canvas* canvas) {
- // Paints the handle for the toolstrip (only called on mouse-hover).
- SkColor theme_toolbar_color =
- shelf_->GetThemeProvider()->GetColor(BrowserThemeProvider::COLOR_TOOLBAR);
- canvas->FillRectInt(theme_toolbar_color, 0, 0, width(), height());
-
- SkColor border_color = ResourceBundle::toolbar_separator_color;
- canvas->FillRectInt(border_color, 0, 0, width(), 1);
- canvas->FillRectInt(border_color, 0, 0, 1, height() - 1);
- canvas->FillRectInt(border_color, width() - 1, 0, 1, height() - 1);
+ canvas->FillRectInt(kBackgroundColor, 0, 0, width(), height());
+ canvas->FillRectInt(kBorderColor, 0, 0, width(), 1);
+ canvas->FillRectInt(kBorderColor, 0, 0, 1, height() - 1);
+ canvas->FillRectInt(kBorderColor, width() - 1, 0, 1, height() - 1);
int ext_width = view()->width() + kToolstripPadding +
kToolstripDividerWidth;
if (ext_width < width()) {
- canvas->FillRectInt(border_color, ext_width, height() - 1,
+ canvas->FillRectInt(kBorderColor, ext_width, height() - 1,
width() - ext_width, 1);
}
@@ -275,8 +286,8 @@ void ExtensionShelf::Toolstrip::Paint(gfx::Canvas* canvas) {
title_->ProcessPaint(canvas);
if (dragging_) {
- // When we're dragging, draw the bottom border.
- canvas->FillRectInt(border_color, 0, height() - 1, width(), 1);
+ // when we're dragging, draw the bottom border.
+ canvas->FillRectInt(kBorderColor, 0, height() - 1, width(), 1);
}
}
@@ -508,11 +519,6 @@ void ExtensionShelf::Toolstrip::AttachToShelf(bool browserAttach) {
void ExtensionShelf::Toolstrip::DoShowShelfHandle() {
GetHandle();
if (!handle_->visible()) {
- // Make sure the text color for the title matches the theme colors.
- title_->SetColor(
- shelf_->GetThemeProvider()->GetColor(
- BrowserThemeProvider::COLOR_BOOKMARK_TEXT));
-
LayoutHandle();
handle_->Show();
}
@@ -590,7 +596,7 @@ void ExtensionShelf::Toolstrip::ShowShelfHandle() {
MessageLoop::current()->PostDelayedTask(FROM_HERE,
timer_factory_.NewRunnableMethod(
&ExtensionShelf::Toolstrip::DoShowShelfHandle),
- kShowDelayMs);
+ 1000);
}
void ExtensionShelf::Toolstrip::HideShelfHandle(int delay_ms) {
@@ -612,9 +618,7 @@ void ExtensionShelf::Toolstrip::HideShelfHandle(int delay_ms) {
////////////////////////////////////////////////////////////////////////////////
ExtensionShelf::ExtensionShelf(Browser* browser)
- : background_needs_repaint_(true),
- background_for_detached_(false),
- browser_(browser),
+ : browser_(browser),
model_(browser->extension_shelf_model()) {
model_->AddObserver(this);
LoadFromModel();
@@ -641,27 +645,95 @@ ExtensionShelf::~ExtensionShelf() {
}
}
-void ExtensionShelf::PaintChildren(gfx::Canvas* canvas) {
- // Capture a background bitmap to give to the toolstrips.
- SkRect background_rect = {
- SkIntToScalar(0),
- SkIntToScalar(0),
- SkIntToScalar(width()),
- SkIntToScalar(height())
- };
- InitBackground(canvas, background_rect);
+void ExtensionShelf::Paint(gfx::Canvas* canvas) {
+ if (IsDetachedStyle()) {
+ // Draw the background to match the new tab page.
+ ThemeProvider* tp = GetThemeProvider();
+ canvas->FillRectInt(
+ tp->GetColor(BrowserThemeProvider::COLOR_NTP_BACKGROUND),
+ 0, 0, width(), height());
+
+ // As 'hidden' according to the animation is the full in-tab state,
+ // we invert the value - when current_state is at '0', we expect the
+ // shelf to be docked.
+ double current_state = 1 - size_animation_->GetCurrentValue();
+
+ // The 0.5 is to correct for Skia's "draw on pixel boundaries"ness.
+ double h_padding = static_cast<double>
+ (kNewtabHorizontalPadding) * current_state;
+ double v_padding = static_cast<double>
+ (kNewtabVerticalPadding) * current_state;
+ SkRect rect;
+ rect.set(SkDoubleToScalar(h_padding - 0.5),
+ SkDoubleToScalar(v_padding - 0.5),
+ SkDoubleToScalar(width() - h_padding - 0.5),
+ SkDoubleToScalar(height() - v_padding - 0.5));
+
+ double roundness = static_cast<double>
+ (kNewtabBarRoundness) * current_state;
+
+ // Draw the background behind the toolstrips.
+ SkPaint paint;
+ paint.setAntiAlias(true);
+ paint.setColor(kBackgroundColor);
+
+ canvas->drawRoundRect(rect,
+ SkDoubleToScalar(roundness),
+ SkDoubleToScalar(roundness), paint);
+
+ SkRect background_rect = {
+ SkIntToScalar(h_padding),
+ SkIntToScalar(v_padding + 2),
+ SkIntToScalar(h_padding + 1),
+ SkIntToScalar(v_padding + kToolstripHeight - 3)};
+ InitBackground(canvas, background_rect);
+
+ // Draw the border around the toolstrips in the extension shelf.
+ SkPaint border_paint;
+ border_paint.setColor(
+ GetThemeProvider()->GetColor(BrowserThemeProvider::COLOR_NTP_HEADER));
+ border_paint.setStyle(SkPaint::kStroke_Style);
+ border_paint.setAlpha(96);
+ border_paint.setAntiAlias(true);
+ canvas->drawRoundRect(rect,
+ SkDoubleToScalar(roundness),
+ SkDoubleToScalar(roundness), border_paint);
+ } else {
+#if 0
+ // TODO(erikkay) Re-enable when Glen has the gradient values worked out.
+ SkPaint paint;
+ paint.setShader(skia::CreateGradientShader(0,
+ height(),
+ kTopGradientColor,
+ kBackgroundColor))->safeUnref();
+ canvas->FillRectInt(0, 0, width(), height(), paint);
+#else
+ canvas->FillRectInt(kBackgroundColor, 0, 0, width(), height());
+#endif
+
+ SkRect background_rect = {
+ SkIntToScalar(0),
+ SkIntToScalar(0),
+ SkIntToScalar(1),
+ SkIntToScalar(height())
+ };
+ InitBackground(canvas, background_rect);
+
+ // Draw border around shelf in attached mode. If we are in detached mode
+ // we've already drawn the borders.
+ canvas->FillRectInt(kBorderColor, 0, 0, width(), 1);
+ canvas->FillRectInt(kBorderColor, 0, height() - 1, width(), 1);
+ }
// Draw vertical dividers between Toolstrip items in the Extension shelf.
int count = GetChildViewCount();
for (int i = 0; i < count; ++i) {
int right = GetChildViewAt(i)->bounds().right() + kToolstripPadding;
- int vertical_padding = IsDetached() ? (height() - kShelfHeight) / 2 : 1;
-
- DetachableToolbarView::PaintVerticalDivider(
- canvas, right, height(), vertical_padding,
- SK_ColorWHITE,
- kDividerHighlightColor,
- GetThemeProvider()->GetColor(BrowserThemeProvider::COLOR_TOOLBAR));
+ int y = IsDetachedStyle() ? kNewtabVerticalPadding : 1;
+ int h = IsDetachedStyle() ? height() - (2 * kNewtabVerticalPadding) - 1:
+ height() - 2;
+ canvas->FillRectInt(kBorderColor, right, y, 1, h);
+ canvas->FillRectInt(kDividerHighlightColor, right + 1, y, 1, h);
}
}
@@ -699,6 +771,7 @@ void ExtensionShelf::Layout() {
LayoutItems(false);
}
+
void ExtensionShelf::OnMouseEntered(const views::MouseEvent& event) {
}
@@ -726,17 +799,6 @@ void ExtensionShelf::SetAccessibleName(const std::wstring& name) {
accessible_name_.assign(name);
}
-void ExtensionShelf::ThemeChanged() {
- background_needs_repaint_ = true;
-
- // Refresh the CSS to update toolstrip text colors from theme.
- int count = model_->count();
- for (int i = 0; i < count; ++i)
- ToolstripAtIndex(i)->view()->host()->InsertCssIfToolstrip();
-
- Layout();
-}
-
void ExtensionShelf::ToolstripInsertedAt(ExtensionHost* host,
int index) {
model_->SetToolstripDataAt(index,
@@ -744,7 +806,8 @@ void ExtensionShelf::ToolstripInsertedAt(ExtensionHost* host,
bool had_views = GetChildViewCount() > 0;
ExtensionView* view = host->view();
- background_needs_repaint_ = true;
+ if (!background_.empty())
+ view->SetBackground(background_);
AddChildView(view);
view->SetContainer(this);
if (!had_views)
@@ -813,8 +876,7 @@ void ExtensionShelf::AnimationEnded(const Animation* animation) {
if (browser_)
browser_->ExtensionShelfSizeChanged();
- background_needs_repaint_ = true;
- Layout();
+ SchedulePaint();
}
void ExtensionShelf::Observe(NotificationType type,
@@ -874,49 +936,38 @@ void ExtensionShelf::CollapseToolstrip(ExtensionHost* host, const GURL& url) {
model_->CollapseToolstrip(toolstrip, url);
}
-void ExtensionShelf::InitBackground(
- gfx::Canvas* canvas, const SkRect& subset) {
- bool detached = IsDetached();
- if (!background_needs_repaint_ && background_for_detached_ == detached)
+void ExtensionShelf::InitBackground(gfx::Canvas* canvas, const SkRect& subset) {
+ if (!background_.empty())
+ return;
+
+ const SkBitmap& background = canvas->getDevice()->accessBitmap(false);
+
+ // Extract the correct subset of the toolstrip background into a bitmap. We
+ // must use a temporary here because extractSubset() returns a bitmap that
+ // references pixels in the original one and we want to actually make a copy
+ // that will have a long lifetime.
+ SkBitmap temp;
+ temp.setConfig(background.config(),
+ static_cast<int>(subset.width()),
+ static_cast<int>(subset.height()));
+
+ SkRect mapped_subset = subset;
+ bool result = canvas->getTotalMatrix().mapRect(&mapped_subset);
+ DCHECK(result);
+
+ SkIRect isubset;
+ mapped_subset.round(&isubset);
+ result = background.extractSubset(&temp, isubset);
+ if (!result)
return;
- background_for_detached_ = detached;
+ temp.copyTo(&background_, temp.config());
+ DCHECK(background_.readyToDraw());
// Tell all extension views about the new background
int count = model_->count();
- for (int i = 0; i < count; ++i) {
- ExtensionView* view = ToolstripAtIndex(i)->view();
-
- const SkBitmap& background = canvas->getDevice()->accessBitmap(false);
-
- // Extract the correct subset of the toolstrip background into a bitmap. We
- // must use a temporary here because extractSubset() returns a bitmap that
- // references pixels in the original one and we want to actually make a copy
- // that will have a long lifetime.
- SkBitmap temp;
- temp.setConfig(background.config(),
- static_cast<int>(subset.width()),
- static_cast<int>(subset.height()));
-
- SkRect mapped_subset = subset;
- gfx::Rect view_bounds = view->bounds();
- mapped_subset.offset(SkIntToScalar(view_bounds.x()),
- SkIntToScalar(view_bounds.y()));
- bool result = canvas->getTotalMatrix().mapRect(&mapped_subset);
- DCHECK(result);
-
- SkIRect isubset;
- mapped_subset.round(&isubset);
- result = background.extractSubset(&temp, isubset);
- if (!result)
- return;
-
- DCHECK(temp.readyToDraw());
-
- view->SetBackground(temp);
- }
-
- background_needs_repaint_ = false;
+ for (int i = 0; i < count; ++i)
+ ToolstripAtIndex(i)->view()->SetBackground(background_);
}
ExtensionShelf::Toolstrip* ExtensionShelf::ToolstripAtX(int x) {
@@ -981,13 +1032,13 @@ gfx::Size ExtensionShelf::LayoutItems(bool compute_bounds_only) {
int count = model_->count();
for (int i = 0; i < count; ++i) {
- x += kToolstripPadding; // Left padding.
+ x += kToolstripPadding; // left padding
Toolstrip* toolstrip = ToolstripAtIndex(i);
- if (!toolstrip) // Can be NULL while in the process of removing.
+ if (!toolstrip) // can be NULL while in the process of removing
continue;
View* view = toolstrip->GetShelfView();
gfx::Size pref = view->GetPreferredSize();
- int next_x = x + pref.width() + kToolstripPadding; // Right padding.
+ int next_x = x + pref.width() + kToolstripPadding; // right padding
if (!compute_bounds_only) {
if (view == toolstrip->view())
toolstrip->view()->set_is_clipped(next_x >= max_x);
@@ -1019,22 +1070,16 @@ gfx::Size ExtensionShelf::LayoutItems(bool compute_bounds_only) {
return prefsize;
}
-bool ExtensionShelf::IsOnTop() const {
- static bool is_on_top = CommandLine::ForCurrentProcess()->HasSwitch(
- switches::kShowExtensionsOnTop);
- return is_on_top;
-}
-
-bool ExtensionShelf::IsDetached() const {
+bool ExtensionShelf::IsDetachedStyle() {
return OnNewTabPage() && (size_animation_->GetCurrentValue() != 1);
}
-bool ExtensionShelf::IsAlwaysShown() const {
+bool ExtensionShelf::IsAlwaysShown() {
Profile* profile = browser_->profile();
return profile->GetPrefs()->GetBoolean(prefs::kShowExtensionShelf);
}
-bool ExtensionShelf::OnNewTabPage() const {
+bool ExtensionShelf::OnNewTabPage() {
return (browser_ && browser_->GetSelectedTabContents() &&
browser_->GetSelectedTabContents()->IsExtensionShelfAlwaysVisible());
}
diff --git a/chrome/browser/views/extensions/extension_shelf.h b/chrome/browser/views/extensions/extension_shelf.h
index c15921b..3f994e4 100644
--- a/chrome/browser/views/extensions/extension_shelf.h
+++ b/chrome/browser/views/extensions/extension_shelf.h
@@ -11,7 +11,6 @@
#include "chrome/browser/extensions/extension_shelf_model.h"
#include "chrome/browser/extensions/extensions_service.h"
#include "chrome/browser/views/browser_bubble.h"
-#include "chrome/browser/views/detachable_toolbar_view.h"
#include "views/view.h"
class Browser;
@@ -21,7 +20,7 @@ namespace views {
}
// A shelf that contains Extension toolstrips.
-class ExtensionShelf : public DetachableToolbarView,
+class ExtensionShelf : public views::View,
public ExtensionContainer,
public ExtensionShelfModelObserver,
public AnimationDelegate,
@@ -33,18 +32,14 @@ class ExtensionShelf : public DetachableToolbarView,
// Get the current model.
ExtensionShelfModel* model() { return model_; }
+ // Returns whether the extension shelf is detached from the Chrome frame.
+ bool IsDetachedStyle();
+
// Toggles a preference for whether to always show the extension shelf.
static void ToggleWhenExtensionShelfVisible(Profile* profile);
- // DetachableToolbarView methods:
- virtual bool IsOnTop() const;
- virtual bool IsDetached() const;
- virtual double GetAnimationValue() const {
- return size_animation_->GetCurrentValue();
- }
-
- // View methods:
- virtual void PaintChildren(gfx::Canvas* canvas);
+ // View
+ virtual void Paint(gfx::Canvas* canvas);
virtual gfx::Size GetPreferredSize();
virtual void Layout();
virtual void OnMouseExited(const views::MouseEvent& event);
@@ -52,13 +47,12 @@ class ExtensionShelf : public DetachableToolbarView,
virtual bool GetAccessibleName(std::wstring* name);
virtual bool GetAccessibleRole(AccessibilityTypes::Role* role);
virtual void SetAccessibleName(const std::wstring& name);
- virtual void ThemeChanged();
- // ExtensionContainer methods:
+ // ExtensionContainer
virtual void OnExtensionMouseEvent(ExtensionView* view);
virtual void OnExtensionMouseLeave(ExtensionView* view);
- // ExtensionShelfModelObserver methods:
+ // ExtensionShelfModelObserver
virtual void ToolstripInsertedAt(ExtensionHost* toolstrip, int index);
virtual void ToolstripRemovingAt(ExtensionHost* toolstrip, int index);
virtual void ToolstripDraggingFrom(ExtensionHost* toolstrip, int index);
@@ -70,17 +64,17 @@ class ExtensionShelf : public DetachableToolbarView,
virtual void ShelfModelReloaded();
virtual void ShelfModelDeleting();
- // AnimationDelegate methods:
+ // AnimationDelegate
virtual void AnimationProgressed(const Animation* animation);
virtual void AnimationEnded(const Animation* animation);
- // NotificationObserver methods:
+ // NotificationObserver
virtual void Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details);
protected:
- // View methods:
+ // View
virtual void ChildPreferredSizeChanged(View* child);
private:
@@ -98,7 +92,7 @@ class ExtensionShelf : public DetachableToolbarView,
// Collapse the specified toolstrip, navigating to |url| if non-empty.
void CollapseToolstrip(ExtensionHost* host, const GURL& url);
- // Initializes the background bitmaps for all views.
+ // Inits the background bitmap.
void InitBackground(gfx::Canvas* canvas, const SkRect& subset);
// Returns the Toolstrip at |x| coordinate. If |x| is out of bounds, returns
@@ -121,21 +115,16 @@ class ExtensionShelf : public DetachableToolbarView,
gfx::Size LayoutItems(bool compute_bounds_only);
// Returns whether the extension shelf always shown (checks pref value).
- bool IsAlwaysShown() const;
+ bool IsAlwaysShown();
// Returns whether the extension shelf is being displayed over the new tab
// page.
- bool OnNewTabPage() const;
+ bool OnNewTabPage();
NotificationRegistrar registrar_;
// Background bitmap to draw under extension views.
- bool background_needs_repaint_;
-
- // Whether the background we are remembering is for detached mode or not.
- // This allows us to switch backgrounds and remember if we've done so, so that
- // we don't have to do it over and over again.
- bool background_for_detached_;
+ SkBitmap background_;
// The browser this extension shelf belongs to.
Browser* browser_;
diff --git a/chrome/browser/views/frame/browser_view.cc b/chrome/browser/views/frame/browser_view.cc
index beef3f4..e42262d 100644
--- a/chrome/browser/views/frame/browser_view.cc
+++ b/chrome/browser/views/frame/browser_view.cc
@@ -127,59 +127,254 @@ static const char kBrowserViewClassName[] = "browser/views/BrowserView";
// and paint the bookmark bar.
class BookmarkExtensionBackground : public views::Background {
public:
- explicit BookmarkExtensionBackground(BrowserView* browser_view,
- DetachableToolbarView* host_view);
+ explicit BookmarkExtensionBackground(BrowserView* browser_view);
// View methods overridden from views:Background.
virtual void Paint(gfx::Canvas* canvas, views::View* view) const;
private:
- BrowserView* browser_view_;
+ // Paint the theme background with the proper alignment.
+ void PaintThemeBackgroundTopAligned(gfx::Canvas* canvas,
+ SkBitmap* ntp_background, int tiling, int alignment) const;
+ void PaintThemeBackgroundBottomAligned(gfx::Canvas* canvas,
+ SkBitmap* ntp_background, int tiling, int alignment) const;
- // The view hosting this background.
- DetachableToolbarView* host_view_;
+ BrowserView* browser_view_;
DISALLOW_COPY_AND_ASSIGN(BookmarkExtensionBackground);
};
BookmarkExtensionBackground::BookmarkExtensionBackground(
- BrowserView* browser_view,
- DetachableToolbarView* host_view)
- : browser_view_(browser_view),
- host_view_(host_view) {
+ BrowserView* browser_view)
+ : browser_view_(browser_view) {
}
void BookmarkExtensionBackground::Paint(gfx::Canvas* canvas,
- views::View* view) const {
- ThemeProvider* tp = host_view_->GetThemeProvider();
- if (host_view_->IsDetached()) {
+ views::View* view) const {
+ // Paint the bookmark bar.
+ BookmarkBarView* bookmark_bar_view = browser_view_->GetBookmarkBarView();
+ if (bookmark_bar_view->IsDetachedStyle()) {
// Draw the background to match the new tab page.
- DetachableToolbarView::PaintBackgroundDetachedMode(canvas, host_view_);
+ ThemeProvider* tp = bookmark_bar_view->GetThemeProvider();
+ canvas->FillRectInt(
+ tp->GetColor(BrowserThemeProvider::COLOR_NTP_BACKGROUND),
+ 0, 0, bookmark_bar_view->width(), bookmark_bar_view->height());
+
+ if (tp->HasCustomImage(IDR_THEME_NTP_BACKGROUND)) {
+ int tiling = BrowserThemeProvider::NO_REPEAT;
+ tp->GetDisplayProperty(BrowserThemeProvider::NTP_BACKGROUND_TILING,
+ &tiling);
+ int alignment;
+ if (tp->GetDisplayProperty(BrowserThemeProvider::NTP_BACKGROUND_ALIGNMENT,
+ &alignment)) {
+ SkBitmap* ntp_background = tp->GetBitmapNamed(
+ IDR_THEME_NTP_BACKGROUND);
+
+ if (alignment & BrowserThemeProvider::ALIGN_TOP) {
+ PaintThemeBackgroundTopAligned(canvas, ntp_background, tiling,
+ alignment);
+ } else {
+ PaintThemeBackgroundBottomAligned(canvas, ntp_background, tiling,
+ alignment);
+ }
+ }
+ }
+
+ // Draw the 'bottom' of the toolbar above our bubble.
+ canvas->FillRectInt(ResourceBundle::toolbar_separator_color, 0, 0,
+ bookmark_bar_view->width(), 1);
SkRect rect;
// As 'hidden' according to the animation is the full in-tab state,
// we invert the value - when current_state is at '0', we expect the
// bar to be docked.
- double current_state = 1 - host_view_->GetAnimationValue();
+ double current_state = 1 - bookmark_bar_view->GetSizeAnimationValue();
// The 0.5 is to correct for Skia's "draw on pixel boundaries"ness.
double h_padding = static_cast<double>
- (BookmarkBarView::kNewtabHorizontalPadding) * current_state;
+ (BookmarkBarView::kNewtabHorizontalPadding) * current_state;
double v_padding = static_cast<double>
- (BookmarkBarView::kNewtabVerticalPadding) * current_state;
- double roundness = 0;
-
- DetachableToolbarView::CalculateContentArea(current_state,
- h_padding, v_padding,
- &rect, &roundness, host_view_);
- DetachableToolbarView::PaintContentAreaBackground(
- canvas, tp, rect, roundness);
- DetachableToolbarView::PaintContentAreaBorder(canvas, tp, rect, roundness);
- DetachableToolbarView::PaintHorizontalBorder(canvas, host_view_);
+ (BookmarkBarView::kNewtabVerticalPadding) * current_state;
+ rect.set(SkDoubleToScalar(h_padding - 0.5),
+ SkDoubleToScalar(v_padding - 0.5),
+ SkDoubleToScalar(bookmark_bar_view->width() - h_padding - 0.5),
+ SkDoubleToScalar(bookmark_bar_view->height() - v_padding - 0.5));
+
+ double roundness = static_cast<double>
+ (kNewtabBarRoundness) * current_state;
+
+ // Draw our background.
+ SkPaint paint;
+ paint.setAntiAlias(true);
+ paint.setColor(bookmark_bar_view->GetThemeProvider()->GetColor(
+ BrowserThemeProvider::COLOR_TOOLBAR));
+
+ canvas->drawRoundRect(rect,
+ SkDoubleToScalar(roundness),
+ SkDoubleToScalar(roundness), paint);
+
+ // Draw border
+ SkPaint border_paint;
+ border_paint.setColor(bookmark_bar_view->GetThemeProvider()->GetColor(
+ BrowserThemeProvider::COLOR_NTP_HEADER));
+ border_paint.setStyle(SkPaint::kStroke_Style);
+ border_paint.setAlpha(96);
+ border_paint.setAntiAlias(true);
+
+ canvas->drawRoundRect(rect,
+ SkDoubleToScalar(roundness),
+ SkDoubleToScalar(roundness), border_paint);
} else {
- DetachableToolbarView::PaintBackgroundAttachedMode(canvas, host_view_);
- DetachableToolbarView::PaintHorizontalBorder(canvas, host_view_);
+ gfx::Rect bounds = bookmark_bar_view->GetBounds(views::View::
+ APPLY_MIRRORING_TRANSFORMATION);
+
+ SkColor theme_toolbar_color =
+ bookmark_bar_view->GetThemeProvider()->GetColor(BrowserThemeProvider::
+ COLOR_TOOLBAR);
+ canvas->FillRectInt(theme_toolbar_color, 0, 0,
+ bookmark_bar_view->width(),
+ bookmark_bar_view->height());
+
+ canvas->TileImageInt(
+ *browser_view_->GetBookmarkBarView()->GetThemeProvider()->
+ GetBitmapNamed(IDR_THEME_TOOLBAR),
+ bookmark_bar_view->GetParent()->GetBounds(views::
+ View::APPLY_MIRRORING_TRANSFORMATION).x() + bounds.x(), bounds.y(),
+ 0, 0,
+ bookmark_bar_view->width(),
+ bookmark_bar_view->height());
+ canvas->FillRectInt(ResourceBundle::toolbar_separator_color,
+ 0,
+ bookmark_bar_view->height() - 1,
+ bookmark_bar_view->width(), 1);
+ }
+}
+
+void BookmarkExtensionBackground::PaintThemeBackgroundTopAligned(
+ gfx::Canvas* canvas, SkBitmap* ntp_background, int tiling,
+ int alignment) const {
+ BookmarkBarView* bookmark_bar_view = browser_view_->GetBookmarkBarView();
+ if (alignment & BrowserThemeProvider::ALIGN_LEFT) {
+ if (tiling == BrowserThemeProvider::REPEAT)
+ canvas->TileImageInt(*ntp_background, 0, 0,
+ bookmark_bar_view->width(), bookmark_bar_view->height());
+ else if (tiling == BrowserThemeProvider::REPEAT_X)
+ canvas->TileImageInt(*ntp_background, 0, 0,
+ bookmark_bar_view->width(),
+ ntp_background->height());
+ else
+ canvas->TileImageInt(*ntp_background, 0, 0,
+ ntp_background->width(), ntp_background->height());
+
+ } else if (alignment & BrowserThemeProvider::ALIGN_RIGHT) {
+ int x_pos = bookmark_bar_view->width() % ntp_background->width() -
+ ntp_background->width();
+ if (tiling == BrowserThemeProvider::REPEAT)
+ canvas->TileImageInt(*ntp_background, x_pos, 0,
+ bookmark_bar_view->width() + ntp_background->width(),
+ bookmark_bar_view->height());
+ else if (tiling == BrowserThemeProvider::REPEAT_X)
+ canvas->TileImageInt(*ntp_background, x_pos,
+ 0, bookmark_bar_view->width() + ntp_background->width(),
+ ntp_background->height());
+ else
+ canvas->TileImageInt(*ntp_background,
+ bookmark_bar_view->width() - ntp_background->width(), 0,
+ ntp_background->width(), ntp_background->height());
+
+ } else { // ALIGN == CENTER
+ int x_pos = bookmark_bar_view->width() > ntp_background->width() ?
+ ((bookmark_bar_view->width() / 2 - ntp_background->width() / 2) %
+ ntp_background->width()) - ntp_background->width() :
+ bookmark_bar_view->width() / 2 - ntp_background->width() / 2;
+ if (tiling == BrowserThemeProvider::REPEAT)
+ canvas->TileImageInt(*ntp_background, x_pos, 0,
+ bookmark_bar_view->width() + ntp_background->width(),
+ bookmark_bar_view->height());
+ else if (tiling == BrowserThemeProvider::REPEAT_X)
+ canvas->TileImageInt(*ntp_background, x_pos, 0,
+ bookmark_bar_view->width() + ntp_background->width(),
+ ntp_background->height());
+ else
+ canvas->TileImageInt(*ntp_background,
+ bookmark_bar_view->width() / 2 - ntp_background->width() / 2,
+ 0, ntp_background->width(), ntp_background->height());
+ }
+}
+
+void BookmarkExtensionBackground::PaintThemeBackgroundBottomAligned(
+ gfx::Canvas* canvas, SkBitmap* ntp_background, int tiling,
+ int alignment) const {
+ BookmarkBarView* bookmark_bar_view = browser_view_->GetBookmarkBarView();
+ int browser_height = bookmark_bar_view->GetParent()->GetBounds(
+ views::View::APPLY_MIRRORING_TRANSFORMATION).height();
+ int border_width = 5;
+ int y_pos = ((tiling == BrowserThemeProvider::REPEAT_X) ||
+ (tiling == BrowserThemeProvider::NO_REPEAT)) ?
+ browser_height - ntp_background->height() - bookmark_bar_view->height() -
+ border_width :
+ browser_height % ntp_background->height() - bookmark_bar_view->height() -
+ border_width - ntp_background->height();
+
+ if (alignment & BrowserThemeProvider::ALIGN_LEFT) {
+ if (tiling == BrowserThemeProvider::REPEAT)
+ canvas->TileImageInt(*ntp_background, 0, y_pos,
+ bookmark_bar_view->width(),
+ 2 * bookmark_bar_view->height() + ntp_background->height() + 5);
+ else if (tiling == BrowserThemeProvider::REPEAT_X)
+ canvas->TileImageInt(*ntp_background, 0, y_pos,
+ bookmark_bar_view->width(), ntp_background->height());
+ else if (tiling == BrowserThemeProvider::REPEAT_Y)
+ canvas->TileImageInt(*ntp_background, 0, y_pos,
+ ntp_background->width(),
+ 2 * bookmark_bar_view->height() + ntp_background->height() + 5);
+ else
+ canvas->TileImageInt(*ntp_background, 0, y_pos, ntp_background->width(),
+ ntp_background->height());
+
+ } else if (alignment & BrowserThemeProvider::ALIGN_RIGHT) {
+ int x_pos = bookmark_bar_view->width() % ntp_background->width() -
+ ntp_background->width();
+ if (tiling == BrowserThemeProvider::REPEAT)
+ canvas->TileImageInt(*ntp_background, x_pos, y_pos,
+ bookmark_bar_view->width() + ntp_background->width(),
+ 2 * bookmark_bar_view->height() + ntp_background->height() + 5);
+ else if (tiling == BrowserThemeProvider::REPEAT_X)
+ canvas->TileImageInt(*ntp_background, x_pos, y_pos,
+ bookmark_bar_view->width() + ntp_background->width(),
+ ntp_background->height());
+ else if (tiling == BrowserThemeProvider::REPEAT_Y)
+ canvas->TileImageInt(*ntp_background, bookmark_bar_view->width() -
+ ntp_background->width(), y_pos, ntp_background->width(),
+ 2 * bookmark_bar_view->height() + ntp_background->height() + 5);
+ else
+ canvas->TileImageInt(*ntp_background,
+ bookmark_bar_view->width() - ntp_background->width(),
+ y_pos, ntp_background->width(), ntp_background->height());
+
+ } else { // ALIGN == CENTER
+ int x_pos = bookmark_bar_view->width() > ntp_background->width() ?
+ ((bookmark_bar_view->width() / 2 - ntp_background->width() / 2) %
+ ntp_background->width()) - ntp_background->width() :
+ bookmark_bar_view->width() / 2 - ntp_background->width() / 2;
+ if (tiling == BrowserThemeProvider::REPEAT)
+ canvas->TileImageInt(*ntp_background, x_pos, y_pos,
+ bookmark_bar_view->width() + ntp_background->width(),
+ 2 * bookmark_bar_view->height() + ntp_background->height() + 5);
+ else if (tiling == BrowserThemeProvider::REPEAT_X)
+ canvas->TileImageInt(*ntp_background, x_pos, y_pos,
+ bookmark_bar_view->width() + ntp_background->width(),
+ ntp_background->height());
+ else if (tiling == BrowserThemeProvider::REPEAT_Y)
+ canvas->TileImageInt(*ntp_background,
+ bookmark_bar_view->width() / 2 - ntp_background->width() / 2,
+ y_pos, ntp_background->width(),
+ 2 * bookmark_bar_view->height() + ntp_background->height() + 5);
+ else
+ canvas->TileImageInt(*ntp_background,
+ bookmark_bar_view->width() / 2 - ntp_background->width() / 2,
+ y_pos, ntp_background->width(), ntp_background->height());
}
}
@@ -1634,8 +1829,6 @@ void BrowserView::Init() {
if (browser_->SupportsWindowFeature(Browser::FEATURE_EXTENSIONSHELF)) {
extension_shelf_ = new ExtensionShelf(browser_.get());
- extension_shelf_->set_background(
- new BookmarkExtensionBackground(this, extension_shelf_));
extension_shelf_->
SetAccessibleName(l10n_util::GetString(IDS_ACCNAME_EXTENSIONS));
AddChildView(extension_shelf_);
@@ -1707,7 +1900,7 @@ int BrowserView::LayoutBookmarkAndInfoBars(int top) {
// If we're showing the Bookmark bar in detached style, then we need to show
// any Info bar _above_ the Bookmark bar, since the Bookmark bar is styled
// to look like it's part of the page.
- if (bookmark_bar_view_->IsDetached())
+ if (bookmark_bar_view_->IsDetachedStyle())
return LayoutTopBar(LayoutInfoBar(top));
// Otherwise, Bookmark bar first, Info bar second.
top = LayoutTopBar(top);
@@ -1729,17 +1922,17 @@ int BrowserView::LayoutTopBar(int top) {
if (!IsBookmarkBarVisible()) {
bookmark_bar_view_->SetVisible(false);
bookmark_bar_view_->SetBounds(0, y, width(), 0);
- if (extension_shelf_->IsOnTop())
+ if (ShowExtensionsOnTop())
extension_shelf_->SetVisible(false);
return y;
}
int bookmark_bar_height = bookmark_bar_view_->GetPreferredSize().height();
- y -= kSeparationLineHeight + (bookmark_bar_view_->IsDetached() ?
+ y -= kSeparationLineHeight + (bookmark_bar_view_->IsDetachedStyle() ?
0 : bookmark_bar_view_->GetToolbarOverlap(false));
- if (extension_shelf_->IsOnTop()) {
- if (!bookmark_bar_view_->IsDetached()) {
+ if (ShowExtensionsOnTop()) {
+ if (!bookmark_bar_view_->IsDetachedStyle()) {
int extension_shelf_width =
extension_shelf_->GetPreferredSize().width();
int bookmark_bar_given_width = width() - extension_shelf_width;
@@ -1756,7 +1949,7 @@ int BrowserView::LayoutTopBar(int top) {
bookmark_bar_height);
x += extension_shelf_width;
} else {
- // TODO(sidchat): For detached style bookmark bar, set the extensions
+ // TODO (sidchat): For detached style bookmark bar, set the extensions
// shelf in a better position. Issue = 20741.
extension_shelf_->SetVisible(false);
}
@@ -1785,7 +1978,7 @@ int BrowserView::LayoutExtensionAndDownloadShelves() {
// to look like it's part of the page.
int bottom = height();
if (extension_shelf_) {
- if (extension_shelf_->IsDetached()) {
+ if (extension_shelf_->IsDetachedStyle()) {
bottom = LayoutDownloadShelf(bottom);
return LayoutExtensionShelf(bottom);
}
@@ -1824,7 +2017,7 @@ void BrowserView::LayoutStatusBubble(int top) {
}
int BrowserView::LayoutExtensionShelf(int bottom) {
- if (!extension_shelf_ || extension_shelf_->IsOnTop())
+ if (ShowExtensionsOnTop())
return bottom;
if (extension_shelf_) {
@@ -1848,8 +2041,7 @@ bool BrowserView::MaybeShowBookmarkBar(TabContents* contents) {
bookmark_bar_view_.reset(new BookmarkBarView(contents->profile(),
browser_.get()));
bookmark_bar_view_->SetParentOwned(false);
- bookmark_bar_view_->set_background(
- new BookmarkExtensionBackground(this, bookmark_bar_view_.get()));
+ bookmark_bar_view_->set_background(new BookmarkExtensionBackground(this));
} else {
bookmark_bar_view_->SetProfile(contents->profile());
}
@@ -2135,6 +2327,11 @@ void BrowserView::InitHangMonitor() {
#endif
}
+bool BrowserView::ShowExtensionsOnTop() {
+ return extension_shelf_ && CommandLine::ForCurrentProcess()->HasSwitch(
+ switches::kShowExtensionsOnTop);
+}
+
// static
void BrowserView::InitClass() {
static bool initialized = false;
diff --git a/chrome/browser/views/frame/browser_view.h b/chrome/browser/views/frame/browser_view.h
index 89cf05a..2d06f98 100644
--- a/chrome/browser/views/frame/browser_view.h
+++ b/chrome/browser/views/frame/browser_view.h
@@ -405,6 +405,9 @@ class BrowserView : public BrowserWindow,
// Initialize the hung plugin detector.
void InitHangMonitor();
+ // Returns true if extensions and bookmarks are positioned next to each other.
+ bool ShowExtensionsOnTop();
+
// Initialize class statics.
static void InitClass();
diff --git a/chrome/chrome.gyp b/chrome/chrome.gyp
index a2bdf0cf..9f36ea0 100644
--- a/chrome/chrome.gyp
+++ b/chrome/chrome.gyp
@@ -1963,8 +1963,6 @@
'browser/views/constrained_window_win.h',
'browser/views/confirm_message_box_dialog.cc',
'browser/views/confirm_message_box_dialog.h',
- 'browser/views/detachable_toolbar_view.cc',
- 'browser/views/detachable_toolbar_view.h',
'browser/views/dialog_stubs_gtk.cc',
'browser/views/dom_view.cc',
'browser/views/dom_view.h',
diff --git a/chrome/common/render_messages_internal.h b/chrome/common/render_messages_internal.h
index 806c0e5..a2b99b5 100644
--- a/chrome/common/render_messages_internal.h
+++ b/chrome/common/render_messages_internal.h
@@ -311,10 +311,9 @@ IPC_BEGIN_MESSAGES(View)
// Request for the renderer to evaluate an xpath to a frame and insert css
// into that frame's document. See ViewMsg_ScriptEvalRequest for details on
// allowed xpath expressions.
- IPC_MESSAGE_ROUTED3(ViewMsg_CSSInsertRequest,
+ IPC_MESSAGE_ROUTED2(ViewMsg_CSSInsertRequest,
std::wstring, /* frame_xpath */
- std::string, /* css string */
- std::string /* element id */)
+ std::string /* css string */)
// Log a message to the console of the target frame
IPC_MESSAGE_ROUTED3(ViewMsg_AddMessageToConsole,
diff --git a/chrome/renderer/render_view.cc b/chrome/renderer/render_view.cc
index b8ee661..f339309 100644
--- a/chrome/renderer/render_view.cc
+++ b/chrome/renderer/render_view.cc
@@ -2734,13 +2734,12 @@ void RenderView::EvaluateScript(const std::wstring& frame_xpath,
}
void RenderView::InsertCSS(const std::wstring& frame_xpath,
- const std::string& css,
- const std::string& id) {
+ const std::string& css) {
WebFrame* web_frame = GetChildFrame(frame_xpath);
if (!web_frame)
return;
- web_frame->insertStyleText(WebString::fromUTF8(css), WebString::fromUTF8(id));
+ web_frame->insertStyleText(WebString::fromUTF8(css));
}
void RenderView::OnScriptEvalRequest(const std::wstring& frame_xpath,
@@ -2749,9 +2748,8 @@ void RenderView::OnScriptEvalRequest(const std::wstring& frame_xpath,
}
void RenderView::OnCSSInsertRequest(const std::wstring& frame_xpath,
- const std::string& css,
- const std::string& id) {
- InsertCSS(frame_xpath, css, id);
+ const std::string& css) {
+ InsertCSS(frame_xpath, css);
// Notify RenderViewHost that css has been inserted into the frame.
Send(new ViewHostMsg_OnCSSInserted(routing_id_));
diff --git a/chrome/renderer/render_view.h b/chrome/renderer/render_view.h
index 2fe5201..5836b52 100644
--- a/chrome/renderer/render_view.h
+++ b/chrome/renderer/render_view.h
@@ -405,12 +405,9 @@ class RenderView : public RenderWidget,
void EvaluateScript(const std::wstring& frame_xpath,
const std::wstring& jscript);
- // Inserts a string of CSS in a particular frame. |id| can be specified to
- // give the CSS style element an id, and (if specified) will replace the
- // element with the same id.
+ // Inserts a string of CSS in a particular frame.
void InsertCSS(const std::wstring& frame_xpath,
- const std::string& css,
- const std::string& id);
+ const std::string& css);
int delay_seconds_for_form_state_sync() const {
return delay_seconds_for_form_state_sync_;
@@ -593,8 +590,7 @@ class RenderView : public RenderWidget,
void OnScriptEvalRequest(const std::wstring& frame_xpath,
const std::wstring& jscript);
void OnCSSInsertRequest(const std::wstring& frame_xpath,
- const std::string& css,
- const std::string& id);
+ const std::string& css);
void OnAddMessageToConsole(const string16& frame_xpath,
const string16& message,
const WebKit::WebConsoleMessage::Level&);
diff --git a/chrome/renderer/user_script_slave.cc b/chrome/renderer/user_script_slave.cc
index 7f7ad31..2ebd68f 100644
--- a/chrome/renderer/user_script_slave.cc
+++ b/chrome/renderer/user_script_slave.cc
@@ -130,7 +130,7 @@ bool UserScriptSlave::InjectScripts(WebFrame* frame,
for (size_t j = 0; j < script->css_scripts().size(); ++j) {
UserScript::File& file = script->css_scripts()[j];
frame->insertStyleText(
- WebString::fromUTF8(file.GetContent().as_string()), WebString());
+ WebString::fromUTF8(file.GetContent().as_string()));
}
}
if (script->run_location() == location) {