UNPKG

ce-decorators

Version:

Custom Element decorators for typescript

57 lines (53 loc) 2.42 kB
/** * Copyright (c) 2018 Mathis Zeiher * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ import { getComponentProperties } from '../componentproperties'; import { makeTemplateString, supportsAdoptingStyleSheets } from '../utils'; import { render } from '../lit-html'; /** * Renders the subtree to a lightdom element * @param this * @param elementToRender */ export function renderToLightDOM(elementToRender) { if (this._templateCache === null) { const { cssStyles, tag, shadyCSSStyleSheetAdopted, templateCache } = getComponentProperties(this.constructor); if (!shadyCSSStyleSheetAdopted) { const styleSheet = document.createElement('style'); styleSheet.setAttribute('scope', tag); const styleString = cssStyles.map(value => { return !supportsAdoptingStyleSheets ? value.cssText : Array.from(value.rules).reduce((prev, current) => prev + current.cssText, ''); }).reduce((prevValue, currentValue) => prevValue + currentValue); styleSheet.textContent = styleString.replace(/(};?|,)\s*((\.?|#?)[a-z\-A-Z]+)/g, (_token, ...args) => { return `${args[0]} :host ${args[1]}`; }).replace(/((:host\(([^\(]*)\))|(:host))/g, (_token, ...args) => { return `${tag}${args[2] ? args[2] : ''}`; }); document.querySelector('head').appendChild(styleSheet); getComponentProperties(this.constructor).shadyCSSStyleSheetAdopted = true; } this._templateCache = templateCache || makeTemplateString(['', ''], ['', '']); getComponentProperties(this.constructor).templateCache = this._templateCache; } render(this.render(), elementToRender, { eventContext: this }); } //# sourceMappingURL=lightDOMRenderer.js.map