diff options
author | finnur@chromium.org <finnur@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-14 23:40:15 +0000 |
---|---|---|
committer | finnur@chromium.org <finnur@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-14 23:40:15 +0000 |
commit | 447a51cad97fe5413535c28dae5265ee1ad3c9cc (patch) | |
tree | a0914e5f83908a2290f7bae3d7c1f280682627ec /webkit/glue/webframe_impl.cc | |
parent | fec7dc520f31a2234bffe060a33c4356fe4a5d4c (diff) | |
download | chromium_src-447a51cad97fe5413535c28dae5265ee1ad3c9cc.zip chromium_src-447a51cad97fe5413535c28dae5265ee1ad3c9cc.tar.gz chromium_src-447a51cad97fe5413535c28dae5265ee1ad3c9cc.tar.bz2 |
ExtensionShelf now uses the BookmarkExtensionBackground, just like the BookmarkBarView.
Changed the WebKit API to add an optional |id| parameter to the insertStyleText, which is needed to be able to replace style sheets that have been previously added.
Added an interface that both BookmarkBarView and ExtensionShelf implement.
This new interface tells us whether we are located at the top or at the bottom and whether we are detached from the frame or not.
Factored out some of the duplicate painting-related code to a namespace of its own. Not happy with the name (welcome suggestions).
Moved the check for whether extensions are on top to new class and now cache the value for the lifetime of the process.
Toolstrip text color values are no longer hard-coded but use the color specified in the theme.
Decreased the timeouts for showing and hiding the toolstrip handle.
Replaced the pressed background image and the hover background image for the toolstrip to match what the bookmark bar uses.
Known issues:
Some themes expose the fact that:
- The background for the extension shelf when in detached mode (and located on the bottom) does not seamlessly blend in with background of new tab page. Still works surprisingly well when it breaks, though.
- Didn't spend much time theming the shelf handle (just used the solid color from the theme).
BUG=18452, 21272, 21273
TEST=Install a theme for Chrome and make sure everything looks correct and is updated on a theme change. Also make sure painting problems in bugs 21272 and 21273 are fixed.
Review URL: http://codereview.chromium.org/203034
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@26178 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/glue/webframe_impl.cc')
-rw-r--r-- | webkit/glue/webframe_impl.cc | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/webkit/glue/webframe_impl.cc b/webkit/glue/webframe_impl.cc index 36affe7..dfdb7b3 100644 --- a/webkit/glue/webframe_impl.cc +++ b/webkit/glue/webframe_impl.cc @@ -701,7 +701,8 @@ v8::Local<v8::Context> WebFrameImpl::mainWorldScriptContext() const { } #endif -bool WebFrameImpl::insertStyleText(const WebString& css) { +bool WebFrameImpl::insertStyleText( + const WebString& css, const WebString& id) { Document* document = frame()->document(); if (!document) return false; @@ -709,9 +710,24 @@ bool WebFrameImpl::insertStyleText(const WebString& css) { if (!document_element) return false; + ExceptionCode err = 0; + + if (!id.isEmpty()) { + WebCore::Element* old_element = + document->getElementById(webkit_glue::WebStringToString(id)); + if (old_element) { + Node* parent = old_element->parent(); + if (!parent) + return false; + parent->removeChild(old_element, err); + } + } + RefPtr<WebCore::Element> stylesheet = document->createElement( WebCore::HTMLNames::styleTag, false); - ExceptionCode err = 0; + if (!id.isEmpty()) + stylesheet->setAttribute(WebCore::HTMLNames::idAttr, + webkit_glue::WebStringToString(id)); stylesheet->setTextContent(webkit_glue::WebStringToString(css), err); DCHECK(!err) << "Failed to set style element content"; WebCore::Node* first = document_element->firstChild(); |