Skip to content

Commit

Permalink
Added .form property for legend tag
Browse files Browse the repository at this point in the history
  • Loading branch information
autrilla committed Apr 6, 2016
1 parent 88d29e5 commit a8f9887
Show file tree
Hide file tree
Showing 5 changed files with 73 additions and 24 deletions.
70 changes: 60 additions & 10 deletions components/script/dom/htmllegendelement.rs
@@ -1,12 +1,20 @@
/* 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/. */
// 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::Bindings::ElementBinding::ElementMethods;
use dom::bindings::codegen::Bindings::HTMLLegendElementBinding;
use dom::bindings::codegen::Bindings::HTMLLegendElementBinding::HTMLLegendElementMethods;
use dom::bindings::codegen::Bindings::NodeBinding::NodeMethods;
use dom::bindings::inheritance::Castable;
use dom::bindings::js::Root;
use dom::document::Document;
use dom::element::Element;
use dom::htmlelement::HTMLElement;
use dom::node::Node;
use dom::htmlfieldsetelement::HTMLFieldSetElement;
use dom::htmlformelement::{HTMLFormElement, FormControl};
use dom::node::{ChildrenMutation, Node, NodeDamage, UnbindContext};
use dom::virtualmethods::VirtualMethods;
use string_cache::Atom;
use util::str::DOMString;

Expand All @@ -18,18 +26,60 @@ pub struct HTMLLegendElement {
impl HTMLLegendElement {
fn new_inherited(localName: Atom,
prefix: Option<DOMString>,
document: &Document) -> HTMLLegendElement {
HTMLLegendElement {
htmlelement:
HTMLElement::new_inherited(localName, prefix, document)
}
document: &Document)
-> HTMLLegendElement {
HTMLLegendElement { htmlelement: HTMLElement::new_inherited(localName, prefix, document) }
}

#[allow(unrooted_must_root)]
pub fn new(localName: Atom,
prefix: Option<DOMString>,
document: &Document) -> Root<HTMLLegendElement> {
document: &Document)
-> Root<HTMLLegendElement> {
let element = HTMLLegendElement::new_inherited(localName, prefix, document);
Node::reflect_node(box element, document, HTMLLegendElementBinding::Wrap)
}
}

impl VirtualMethods for HTMLLegendElement {
fn super_type(&self) -> Option<&VirtualMethods> {
Some(self.upcast::<HTMLElement>() as &VirtualMethods)
}

fn bind_to_tree(&self, tree_in_doc: bool) {
if let Some(ref s) = self.super_type() {
s.bind_to_tree(tree_in_doc);
}

self.upcast::<Element>().check_ancestors_disabled_state_for_form_control();
}

fn unbind_from_tree(&self, context: &UnbindContext) {
self.super_type().unwrap().unbind_from_tree(context);

let node = self.upcast::<Node>();
let el = self.upcast::<Element>();
if node.ancestors().any(|ancestor| ancestor.is::<HTMLFieldSetElement>()) {
el.check_ancestors_disabled_state_for_form_control();
} else {
el.check_disabled_attribute();
}
}
}


impl HTMLLegendElementMethods for HTMLLegendElement {
// https://html.spec.whatwg.org/multipage/#dom-legend-form
fn GetForm(&self) -> Option<Root<HTMLFormElement>> {
let parent = match self.upcast::<Node>().GetParentElement() {
Some(parent) => parent,
None => return None,
};
if parent.is::<HTMLFieldSetElement>() {
return self.form_owner();
}
None
}
}

impl FormControl for HTMLLegendElement {}
2 changes: 1 addition & 1 deletion components/script/dom/webidls/HTMLLegendElement.webidl
Expand Up @@ -5,7 +5,7 @@

// https://html.spec.whatwg.org/multipage/#htmllegendelement
interface HTMLLegendElement : HTMLElement {
//readonly attribute HTMLFormElement? form;
readonly attribute HTMLFormElement? form;

// also has obsolete members
};
Expand Down
6 changes: 0 additions & 6 deletions tests/wpt/metadata/html/dom/interfaces.html.ini
Expand Up @@ -5319,15 +5319,9 @@
[HTMLFieldSetElement interface: operation setCustomValidity(DOMString)]
expected: FAIL
[HTMLLegendElement interface: attribute form]
expected: FAIL
[HTMLLegendElement interface: attribute align]
expected: FAIL
[HTMLLegendElement interface: document.createElement("legend") must inherit property "form" with the proper type (0)]
expected: FAIL
[HTMLLegendElement interface: document.createElement("legend") must inherit property "align" with the proper type (1)]
expected: FAIL
Expand Down

This file was deleted.

Expand Up @@ -13,11 +13,21 @@
</form>
</div>

<div style="display:none">
<form id="testformWithFieldSet">
<fieldset>
<legend id="legendWithFieldSet">radio</legend>
</fieldset>
</form>
</div>
<script>

test(function () {
var legendEle = document.getElementById("legendWithFieldSet");
assert_not_equals(legendEle.form, null);
assert_equals(legendEle.form, document.getElementById("testformWithFieldSet"));
}, "Check if legend.form returns its parent when it's inside a fieldset");
test(function () {
var legendEle = document.getElementById("testlegend");
assert_equals(legendEle.form, null);
}, "Check if legend.form return null when legend has no fieldset element as its parent");

</script>

0 comments on commit a8f9887

Please sign in to comment.