Skip to content

Commit

Permalink
fix(css-shim): replaced innerHTML with textContent (#1892)
Browse files Browse the repository at this point in the history
  • Loading branch information
sj0x55 authored and manucorporat committed Sep 26, 2019
1 parent b3ed8de commit 613c797
Show file tree
Hide file tree
Showing 5 changed files with 24 additions and 23 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ log.txt

.idea/
.vscode/
.history/
.sass-cache/
.versions/
node_modules/
Expand Down
8 changes: 4 additions & 4 deletions src/client/polyfills/css-shim/custom-style.ts
Original file line number Diff line number Diff line change
Expand Up @@ -51,12 +51,12 @@ export class CustomStyle {

if (!baseScope.usesCssVars) {
// This component does not use (read) css variables
styleEl.innerHTML = cssText;
styleEl.textContent = cssText;

} else if (isScoped) {
// This component is dynamic: uses css var and is scoped
(styleEl as any)['s-sc'] = cssScopeId = `${baseScope.scopeId}-${this.count}`;
styleEl.innerHTML = '/*needs update*/';
styleEl.textContent = '/*needs update*/';
this.hostStyleMap.set(hostEl, styleEl);
this.hostScopeMap.set(hostEl, reScope(baseScope, cssScopeId));
this.count++;
Expand All @@ -65,7 +65,7 @@ export class CustomStyle {
// This component uses css vars, but it's no-encapsulation (global static)
baseScope.styleEl = styleEl;
if (!baseScope.usesCssVars) {
styleEl.innerHTML = executeTemplate(baseScope.template, {});
styleEl.textContent = executeTemplate(baseScope.template, {});
}
this.globalScopes.push(baseScope);
this.updateGlobal();
Expand All @@ -90,7 +90,7 @@ export class CustomStyle {
if (styleEl) {
const selectors = getActiveSelectors(hostEl, this.hostScopeMap, this.globalScopes);
const props = resolveValues(selectors);
styleEl.innerHTML = executeTemplate(scope.template, props);
styleEl.textContent = executeTemplate(scope.template, props);
}
}
}
Expand Down
2 changes: 1 addition & 1 deletion src/client/polyfills/css-shim/load-link-styles.ts
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ export function addGlobalLink(doc: Document, globalScopes: CSSScope[], linkElm:
}
const styleEl = doc.createElement('style');
styleEl.setAttribute('data-styles', '');
styleEl.innerHTML = text;
styleEl.textContent = text;

addGlobalStyle(globalScopes, styleEl);
linkElm.parentNode.insertBefore(styleEl, linkElm);
Expand Down
4 changes: 2 additions & 2 deletions src/client/polyfills/css-shim/scope.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ export function parseCSS(original: string): CSSScope {
}

export function addGlobalStyle(globalScopes: CSSScope[], styleEl: HTMLStyleElement) {
const css = parseCSS(styleEl.innerHTML);
const css = parseCSS(styleEl.textContent);
css.styleEl = styleEl;
globalScopes.push(css);
}
Expand All @@ -27,7 +27,7 @@ export function updateGlobalScopes(scopes: CSSScope[]) {
const props = resolveValues(selectors);
scopes.forEach(scope => {
if (scope.usesCssVars) {
scope.styleEl.innerHTML = executeTemplate(scope.template, props);
scope.styleEl.textContent = executeTemplate(scope.template, props);
}
});
}
Expand Down
32 changes: 16 additions & 16 deletions src/client/polyfills/css-shim/test/css-shim.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ describe('css-shim', () => {
`);
await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
p {
color: red;
Expand All @@ -47,7 +47,7 @@ describe('css-shim', () => {
`);
await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
p {
color: red;
Expand All @@ -70,7 +70,7 @@ describe('css-shim', () => {
`);
await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
html {
background: yellow;
Expand All @@ -94,7 +94,7 @@ describe('css-shim', () => {

await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
html {
color: green;
Expand All @@ -115,7 +115,7 @@ describe('css-shim', () => {

await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
html {
background-image: url('');
Expand All @@ -138,7 +138,7 @@ describe('css-shim', () => {
`);
await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
html {
background: yellow;
Expand All @@ -162,7 +162,7 @@ describe('css-shim', () => {

await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
html {
background-image: url('');
Expand All @@ -182,7 +182,7 @@ describe('css-shim', () => {

await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(

css(`
html {
Expand All @@ -204,7 +204,7 @@ describe('css-shim', () => {

await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(

css(`
html {
Expand All @@ -229,7 +229,7 @@ describe('css-shim', () => {

await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
html{}
p {
Expand All @@ -252,7 +252,7 @@ describe('css-shim', () => {

await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
html {
color: red;
Expand All @@ -275,7 +275,7 @@ describe('css-shim', () => {

await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
html{}
.transform {
Expand All @@ -301,7 +301,7 @@ describe('css-shim', () => {

await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
html{}
@keyframes animation {
Expand All @@ -328,7 +328,7 @@ describe('css-shim', () => {

await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
html{}
@media only screen {
Expand Down Expand Up @@ -360,7 +360,7 @@ describe('css-shim', () => {

await customStyle.addGlobalStyle(styleElm);

expect(css(styleElm.innerHTML)).toBe(
expect(css(styleElm.textContent)).toBe(
css(`
html{}
div {
Expand All @@ -376,7 +376,7 @@ describe('css-shim', () => {

function style(text: string) {
const elm = document.createElement('style');
elm.innerHTML = text;
elm.textContent = text;
return elm;
}

Expand Down

0 comments on commit 613c797

Please sign in to comment.