Skip to content

Commit

Permalink
Adds Declarative Shadow DOM polyfill.
Browse files Browse the repository at this point in the history
Refs #38.

TODO
  • Loading branch information
dgp1130 committed Jul 26, 2021
1 parent 60689d9 commit 0718b33
Show file tree
Hide file tree
Showing 6 changed files with 95 additions and 1 deletion.
32 changes: 32 additions & 0 deletions packages/rules_prerender/BUILD.bazel
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
load("@bazel_skylib//:bzl_library.bzl", "bzl_library")
load("@npm//@bazel/typescript:index.bzl", "ts_library")
load("//:index.bzl", "prerender_component")
load("//tools:jasmine.bzl", "jasmine_node_test")
load("//tools:publish.bzl", "publish_files")

Expand All @@ -24,6 +25,8 @@ publish_files(
name = "publish_files",
files = glob(["**/*.bzl"]) + [
"rollup-default.config.js",
"declarative_shadow_dom.ts",
"declarative_shadow_dom_polyfill.ts",
],
visibility = ["//:__pkg__"],
)
Expand Down Expand Up @@ -165,3 +168,32 @@ jasmine_node_test(
name = "styles_test",
deps = [":styles_test_lib"],
)


prerender_component(
name = "declarative_shadow_dom",
srcs = ["declarative_shadow_dom.ts"],
scripts = [":declarative_shadow_dom_polyfill"],
lib_deps = [":rules_prerender"],
visibility = ["//visibility:public"],
)

ts_library(
name = "declarative_shadow_dom_test_lib",
srcs = ["declarative_shadow_dom_test.ts"],
testonly = True,
deps = [
":declarative_shadow_dom_prerender_for_test",
"@npm//@types/jasmine",
],
)

jasmine_node_test(
name = "declarative_shadow_dom_test",
deps = [":declarative_shadow_dom_test_lib"],
)

ts_library(
name = "declarative_shadow_dom_polyfill",
srcs = ["declarative_shadow_dom_polyfill.ts"],
)
18 changes: 18 additions & 0 deletions packages/rules_prerender/BUILD.publish
Original file line number Diff line number Diff line change
@@ -1,4 +1,22 @@
load(":prerender_component.bzl", "prerender_component")
load("@npm//@bazel/typescript:index.bzl", "ts_library")

exports_files(
["rollup-default.config.js"],
visibility = ["//visibility:public"],
)

# TESTME
# TODO(#39): Don't ship TypeScript code to NPM and compile it on the user's cpu.
prerender_component(
name = "declarative_shadow_dom",
srcs = ["declarative_shadow_dom.ts"],
scripts = [":declarative_shadow_dom_polyfill"],
lib_deps = ["@npm//rules_prerender"],
visibility = ["//visibility:public"],
)

ts_library(
name = "declarative_shadow_dom_polyfill",
srcs = ["declarative_shadow_dom_polyfill.ts"],
)
10 changes: 10 additions & 0 deletions packages/rules_prerender/declarative_shadow_dom.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
import { includeScript } from 'rules_prerender';

/**
* Returns a prerender annotation used by the bundler to inject the declarative
* shadow DOM polyfill into the document.
*/
export function polyfillDeclarativeShadowDom(): string {
return includeScript(
'rules_prerender/packages/rules_prerender/declarative_shadow_dom_polyfill');
}
23 changes: 23 additions & 0 deletions packages/rules_prerender/declarative_shadow_dom_polyfill.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
/**
* @fileoverview Polyfills declarative shadow DOM by searching for templates
* which match its attributes and attaching them as real shadow roots.
*
* Shamelessly stolen from: https://web.dev/declarative-shadow-dom/#polyfill and
* adapted for TypeScript.
*/

const templates = document.querySelectorAll('template[shadowroot]') as
NodeListOf<HTMLTemplateElement>;
for (const template of Array.from(templates)) {
const mode = template.getAttribute('shadowroot')!;
if (mode !== 'open' && mode !== 'closed') {
console.error(
`Found declarative shadow root with invalid mode: ${mode}.`);
continue;
}

const parent = template.parentNode as Element;
const shadowRoot = parent.attachShadow({ mode });
shadowRoot.appendChild(template.content);
template.remove();
}
11 changes: 11 additions & 0 deletions packages/rules_prerender/declarative_shadow_dom_test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import 'jasmine';
import { polyfillDeclarativeShadowDom } from 'rules_prerender/packages/rules_prerender/declarative_shadow_dom';

describe('declarative_shadow_dom', () => {
describe('polyfillDeclarativeShadowDom()', () => {
it('returns an annotation to include the declarative shadow DOM polyfill', () => {
expect(polyfillDeclarativeShadowDom())
.toBe('<!-- bazel:rules_prerender:PRIVATE_DO_NOT_DEPEND_OR_ELSE - {"type":"script","path":"rules_prerender/packages/rules_prerender/declarative_shadow_dom_polyfill"} -->');
});
});
});
2 changes: 1 addition & 1 deletion packages/rules_prerender/prerender_component.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ def prerender_component(
name = prerender_lib,
srcs = srcs,
tsconfig = tsconfig,
data = data,
data = data + styles,
deps = lib_deps + ["%s_prerender" % absolute(dep) for dep in deps],
testonly = testonly,
visibility = visibility,
Expand Down

0 comments on commit 0718b33

Please sign in to comment.