diff --git a/content/html/document/src/VideoDocument.cpp b/content/html/document/src/VideoDocument.cpp
index 1dd034b0b73..8a480d74c44 100644
--- a/content/html/document/src/VideoDocument.cpp
+++ b/content/html/document/src/VideoDocument.cpp
@@ -134,7 +134,23 @@ VideoDocument::CreateSyntheticVideoDocument(nsIChannel* aChannel,
NS_LITERAL_STRING("position:absolute; top:0; left:0; width:100%; height:100%"),
true);
} else {
+ Element* head = GetHeadElement();
+ NS_ENSURE_TRUE(head, NS_ERROR_FAILURE);
+
LinkStylesheet(NS_LITERAL_STRING("resource://gre/res/TopLevelVideoDocument.css"));
+
+ nodeInfo = mNodeInfoManager->GetNodeInfo(nsGkAtoms::style, nsnull,
+ kNameSpaceID_XHTML,
+ nsIDOMNode::ELEMENT_NODE);
+ NS_ENSURE_TRUE(nodeInfo, NS_ERROR_OUT_OF_MEMORY);
+ nsRefPtr styleContent = NS_NewHTMLStyleElement(nodeInfo.forget());
+ NS_ENSURE_TRUE(styleContent, NS_ERROR_OUT_OF_MEMORY);
+
+ styleContent->SetTextContent(
+ NS_LITERAL_STRING("body { background: url(chrome://global/skin/icons/tabprompts-bgtexture.png) #333; height: 100%; width: 100%; margin: 0; padding: 0; } ") +
+ NS_LITERAL_STRING("video { position: absolute; top: 0; right: 0; bottom: 0; left: 0; margin: auto; box-shadow: 0 0 15px #000; } ") +
+ NS_LITERAL_STRING("video:focus { outline-width: 0; } "));
+ head->AppendChildTo(styleContent, false);
}
return body->AppendChildTo(element, false);
@@ -158,7 +174,9 @@ nsresult
NS_NewVideoDocument(nsIDocument** aResult)
{
mozilla::dom::VideoDocument* doc = new mozilla::dom::VideoDocument();
- NS_ENSURE_TRUE(doc, NS_ERROR_OUT_OF_MEMORY);
+ if (!doc) {
+ return NS_ERROR_OUT_OF_MEMORY;
+ }
NS_ADDREF(doc);
nsresult rv = doc->Init();
diff --git a/layout/style/TopLevelImageDocument.css b/layout/style/TopLevelImageDocument.css
index ea8c4cfc38f..54151c22e8c 100644
--- a/layout/style/TopLevelImageDocument.css
+++ b/layout/style/TopLevelImageDocument.css
@@ -36,13 +36,3 @@
This CSS stylesheet defines the rules to be applied to ImageDocuments that
are top level (e.g. not iframes).
*/
-
-/* We must declare the image as a block element. If we stay as
-an inline element, our parent LineBox will be inline too and
-ignore the available height during reflow.
-This is bad during printing, it means tall image frames won't know
-the size of the paper and cannot break into continuations along
-multiple pages. */
-img {
- display: block;
-}
diff --git a/layout/style/TopLevelVideoDocument.css b/layout/style/TopLevelVideoDocument.css
index 3d00d069468..ebf0ba3310c 100644
--- a/layout/style/TopLevelVideoDocument.css
+++ b/layout/style/TopLevelVideoDocument.css
@@ -36,25 +36,3 @@
This CSS stylesheet defines the rules to be applied to VideoDocuments that
are top level (e.g. not iframes).
*/
-
-body {
- background: url() #333;
- height: 100%;
- width: 100%;
- margin: 0;
- padding: 0;
-}
-
-video {
- position: absolute;
- top: 0;
- right: 0;
- bottom: 0;
- left: 0;
- margin: auto;
- box-shadow: 0 0 15px #000;
-}
-
-video:focus {
- outline-width: 0;
-}