summaryrefslogtreecommitdiffstats
path: root/testing/web-platform/tests/resources/declarative-shadow-dom-polyfill.js
blob: 99a3e911eb633625c5f82365e41aa5ca5ef85de0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
/*
 * Polyfill for attaching shadow trees for declarative Shadow DOM for
 * implementations that do not support declarative Shadow DOM.
 *
 * Note: this polyfill will feature-detect the native feature, and do nothing
 *       if supported.
 *
 * See: https://github.com/whatwg/html/pull/5465
 *
 * root: The root of the subtree in which to upgrade shadow roots
 *
 */

function polyfill_declarative_shadow_dom(root) {
  if (HTMLTemplateElement.prototype.hasOwnProperty('shadowRootMode'))
    return;
  root.querySelectorAll("template[shadowrootmode]").forEach(template => {
    const mode = template.getAttribute("shadowrootmode");
    const delegatesFocus = template.hasAttribute("shadowrootdelegatesfocus");
    const shadowRoot = template.parentNode.attachShadow({ mode, delegatesFocus });
    shadowRoot.appendChild(template.content);
    template.remove();
    polyfill_declarative_shadow_dom(shadowRoot);
  });
}