You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
71 lines
1.9 KiB
71 lines
1.9 KiB
4 years ago
|
import listToStyles from './listToStyles'
|
||
|
|
||
|
export default function addStylesToShadowDOM (parentId, list, shadowRoot) {
|
||
|
var styles = listToStyles(parentId, list)
|
||
|
addStyles(styles, shadowRoot)
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
type StyleObject = {
|
||
|
id: number;
|
||
|
parts: Array<StyleObjectPart>
|
||
|
}
|
||
|
|
||
|
type StyleObjectPart = {
|
||
|
css: string;
|
||
|
media: string;
|
||
|
sourceMap: ?string
|
||
|
}
|
||
|
*/
|
||
|
|
||
|
function addStyles (styles /* Array<StyleObject> */, shadowRoot) {
|
||
|
const injectedStyles =
|
||
|
shadowRoot._injectedStyles ||
|
||
|
(shadowRoot._injectedStyles = {})
|
||
|
for (var i = 0; i < styles.length; i++) {
|
||
|
var item = styles[i]
|
||
|
var style = injectedStyles[item.id]
|
||
|
if (!style) {
|
||
|
for (var j = 0; j < item.parts.length; j++) {
|
||
|
addStyle(item.parts[j], shadowRoot)
|
||
|
}
|
||
|
injectedStyles[item.id] = true
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function createStyleElement (shadowRoot) {
|
||
|
var styleElement = document.createElement('style')
|
||
|
styleElement.type = 'text/css'
|
||
|
shadowRoot.appendChild(styleElement)
|
||
|
return styleElement
|
||
|
}
|
||
|
|
||
|
function addStyle (obj /* StyleObjectPart */, shadowRoot) {
|
||
|
var styleElement = createStyleElement(shadowRoot)
|
||
|
var css = obj.css
|
||
|
var media = obj.media
|
||
|
var sourceMap = obj.sourceMap
|
||
|
|
||
|
if (media) {
|
||
|
styleElement.setAttribute('media', media)
|
||
|
}
|
||
|
|
||
|
if (sourceMap) {
|
||
|
// https://developer.chrome.com/devtools/docs/javascript-debugging
|
||
|
// this makes source maps inside style tags work properly in Chrome
|
||
|
css += '\n/*# sourceURL=' + sourceMap.sources[0] + ' */'
|
||
|
// http://stackoverflow.com/a/26603875
|
||
|
css += '\n/*# sourceMappingURL=data:application/json;base64,' + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + ' */'
|
||
|
}
|
||
|
|
||
|
if (styleElement.styleSheet) {
|
||
|
styleElement.styleSheet.cssText = css
|
||
|
} else {
|
||
|
while (styleElement.firstChild) {
|
||
|
styleElement.removeChild(styleElement.firstChild)
|
||
|
}
|
||
|
styleElement.appendChild(document.createTextNode(css))
|
||
|
}
|
||
|
}
|