OLD | NEW |
(Empty) | |
| 1 <!doctype html> |
| 2 <title>Tabindex on svg elements tests</title> |
| 3 <script src=../../resources/testharness.js></script> |
| 4 <script src=../../resources/testharnessreport.js></script> |
| 5 <body> |
| 6 <div id="testcontainer"><svg id="testroot" width="1" height="1"/></div> |
| 7 <div id=log></div> |
| 8 <script> |
| 9 var svg = document.getElementById("testroot"); |
| 10 function isFocusable(elm) { |
| 11 switch (elm.nodeName) { |
| 12 case "a": |
| 13 return elm.hasAttributeNS("http://www.w3.org/1999/xlink"
, "href"); |
| 14 default: |
| 15 return false; |
| 16 } |
| 17 } |
| 18 function isFocusableWithTabindex(elm) { |
| 19 switch (elm.nodeName) { |
| 20 case "a": |
| 21 case "circle": |
| 22 case "ellipse": |
| 23 case "foreignObject": |
| 24 case "g": |
| 25 case "image": |
| 26 case "line": |
| 27 case "path": |
| 28 case "polygon": |
| 29 case "polyline": |
| 30 case "rect": |
| 31 case "svg": |
| 32 case "switch": |
| 33 case "text": |
| 34 return true; |
| 35 case "textPath": |
| 36 //case "tref": /* not supported */ |
| 37 case "tspan": |
| 38 // only if inside a <text> element |
| 39 return elm.parentNode.nodeName == "text"; |
| 40 case "use": |
| 41 return true; |
| 42 default: |
| 43 return false; |
| 44 } |
| 45 } |
| 46 function createSvg() { |
| 47 var svgelements = [ |
| 48 "a", |
| 49 "altGlyph", |
| 50 "altGlyphDef", |
| 51 "altGlyphItem", |
| 52 "animate", |
| 53 "animateColor", |
| 54 "animateMotion", |
| 55 "animateTransform", |
| 56 "circle", |
| 57 "clipPath", |
| 58 "color-profile", |
| 59 "cursor", |
| 60 "definition-src", |
| 61 "defs", |
| 62 "desc", |
| 63 "ellipse", |
| 64 "feBlend", |
| 65 "feColorMatrix", |
| 66 "feComponentTransfer", |
| 67 "feComposite", |
| 68 "feConvolveMatrix", |
| 69 "feDiffuseLighting", |
| 70 "feDisplacementMap", |
| 71 "feDistantLight", |
| 72 "feFlood", |
| 73 "feFuncA", |
| 74 "feFuncB", |
| 75 "feFuncG", |
| 76 "feFuncR", |
| 77 "feGaussianBlur", |
| 78 "feImage", |
| 79 "feMerge", |
| 80 "feMergeNode", |
| 81 "feMorphology", |
| 82 "feOffset", |
| 83 "fePointLight", |
| 84 "feSpecularLighting", |
| 85 "feSpotLight", |
| 86 "feTile", |
| 87 "feTurbulence", |
| 88 "filter", |
| 89 "font", |
| 90 "font-face", |
| 91 "font-face-format", |
| 92 "font-face-name", |
| 93 "font-face-src", |
| 94 "font-face-uri", |
| 95 "foreignObject", |
| 96 "g", |
| 97 "glyph", |
| 98 "glyphRef", |
| 99 "hkern", |
| 100 "image", |
| 101 "line", |
| 102 "linearGradient", |
| 103 "marker", |
| 104 "mask", |
| 105 "metadata", |
| 106 "missing-glyph", |
| 107 "mpath", |
| 108 "path", |
| 109 "pattern", |
| 110 "polygon", |
| 111 "polyline", |
| 112 "radialGradient", |
| 113 "rect", |
| 114 "script", |
| 115 "set", |
| 116 "stop", |
| 117 "style", |
| 118 "svg", |
| 119 "switch", |
| 120 "symbol", |
| 121 "text", |
| 122 "textPath", |
| 123 "title", |
| 124 "tref", |
| 125 "tspan", |
| 126 "use", |
| 127 "view", |
| 128 "vkern"]; |
| 129 for (var i = 0; i < svgelements.length; i++) { |
| 130 svg.appendChild(document.createElementNS("http://www.w3.org/2000/svg", s
vgelements[i])); |
| 131 } |
| 132 } |
| 133 |
| 134 function setupTextContentElements() { |
| 135 // specialcases for the text content elements |
| 136 |
| 137 // cleanup any old content |
| 138 while(svg.firstChild) |
| 139 svg.removeChild(svg.firstChild); |
| 140 |
| 141 var textContentChildElements = ["textPath", "tref", "tspan"]; |
| 142 for (var i = 0; i < textContentChildElements.length; i++) { |
| 143 var text = document.createElementNS("http://www.w3.org/2000/svg", "text"
); |
| 144 text.appendChild(document.createElementNS("http://www.w3.org/2000/svg",
textContentChildElements[i])); |
| 145 svg.appendChild(text); |
| 146 } |
| 147 } |
| 148 |
| 149 setup(createSvg); |
| 150 var element = svg.firstElementChild; |
| 151 while(element) { |
| 152 test(function() { |
| 153 try { |
| 154 element.focus(); |
| 155 assert_equals(document.activeElement, isFocusable(elemen
t) ? element : document.body); |
| 156 } |
| 157 finally { |
| 158 document.body.focus(); |
| 159 } |
| 160 }, element.nodeName + ".focus() without tabindex set."); |
| 161 test(function() { |
| 162 try { |
| 163 element.setAttribute("tabindex", "1"); |
| 164 element.focus(); |
| 165 assert_equals(document.activeElement, isFocusableWithTab
index(element) ? element : document.body); |
| 166 element.removeAttribute("tabindex"); |
| 167 } |
| 168 finally { |
| 169 document.body.focus(); |
| 170 } |
| 171 }, element.nodeName + ".focus() with tabindex set."); |
| 172 |
| 173 element.parentNode.removeChild(element); |
| 174 element = svg.firstElementChild; |
| 175 } |
| 176 |
| 177 setupTextContentElements(); |
| 178 var element = svg.firstElementChild; |
| 179 while(element) { |
| 180 test(function() { |
| 181 try { |
| 182 element.firstElementChild.focus(); |
| 183 assert_equals(document.activeElement, isFocusable(elemen
t.firstElementChild) ? element.firstElementChild : document.body); |
| 184 } |
| 185 finally { |
| 186 document.body.focus(); |
| 187 } |
| 188 }, element.firstElementChild.nodeName + ".focus() without tabindex set."
); |
| 189 test(function() { |
| 190 try { |
| 191 element.firstElementChild.setAttribute("tabindex", "1"); |
| 192 element.firstElementChild.focus(); |
| 193 assert_equals(document.activeElement, isFocusableWithTab
index(element.firstElementChild) ? element.firstElementChild : document.body); |
| 194 element.firstElementChild.removeAttribute("tabindex"); |
| 195 } |
| 196 finally { |
| 197 document.body.focus(); |
| 198 } |
| 199 }, element.firstElementChild.nodeName + ".focus() with tabindex set."); |
| 200 |
| 201 element.parentNode.removeChild(element); |
| 202 element = svg.firstElementChild; |
| 203 } |
| 204 </script> |
| 205 </body> |
OLD | NEW |