/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ use dom::bindings::codegen::BindingDeclarations::HTMLStyleElementBinding; use dom::bindings::codegen::InheritTypes::{HTMLElementCast, HTMLStyleElementDerived, NodeCast}; use dom::bindings::js::JS; use dom::bindings::error::ErrorResult; use dom::document::Document; use dom::element::HTMLStyleElementTypeId; use dom::eventtarget::{EventTarget, NodeTargetTypeId}; use dom::htmlelement::HTMLElement; use dom::node::{Node, ElementNodeTypeId, window_from_node}; use dom::virtualmethods::VirtualMethods; use html::cssparse::parse_inline_css; use layout_interface::{AddStylesheetMsg, LayoutChan}; use servo_util::str::DOMString; #[deriving(Encodable)] pub struct HTMLStyleElement { pub htmlelement: HTMLElement, } impl HTMLStyleElementDerived for EventTarget { fn is_htmlstyleelement(&self) -> bool { match self.type_id { NodeTargetTypeId(ElementNodeTypeId(HTMLStyleElementTypeId)) => true, _ => false } } } impl HTMLStyleElement { pub fn new_inherited(localName: DOMString, document: JS) -> HTMLStyleElement { HTMLStyleElement { htmlelement: HTMLElement::new_inherited(HTMLStyleElementTypeId, localName, document) } } pub fn new(localName: DOMString, document: &JS) -> JS { let element = HTMLStyleElement::new_inherited(localName, document.clone()); Node::reflect_node(~element, document, HTMLStyleElementBinding::Wrap) } } impl HTMLStyleElement { pub fn Disabled(&self) -> bool { false } pub fn SetDisabled(&self, _disabled: bool) { } pub fn Media(&self) -> DOMString { ~"" } pub fn SetMedia(&mut self, _media: DOMString) -> ErrorResult { Ok(()) } pub fn Type(&self) -> DOMString { ~"" } pub fn SetType(&mut self, _type: DOMString) -> ErrorResult { Ok(()) } pub fn Scoped(&self) -> bool { false } pub fn SetScoped(&self, _scoped: bool) -> ErrorResult { Ok(()) } } pub trait StyleElementHelpers { fn parse_own_css(&self); } impl StyleElementHelpers for JS { fn parse_own_css(&self) { let node: JS = NodeCast::from(self); let win = window_from_node(&node); let url = win.get().page().get_url(); let data = node.get().GetTextContent(&node).expect("Element.textContent must be a string"); let sheet = parse_inline_css(url, data); let LayoutChan(ref layout_chan) = *win.get().page().layout_chan; layout_chan.send(AddStylesheetMsg(sheet)); } } impl VirtualMethods for JS { fn super_type(&self) -> Option<~VirtualMethods:> { let htmlelement: JS = HTMLElementCast::from(self); Some(~htmlelement as ~VirtualMethods:) } fn child_inserted(&mut self, child: &JS) { match self.super_type() { Some(ref mut s) => s.child_inserted(child), _ => (), } self.parse_own_css(); } }