"use strict";
|
const HTMLElementImpl = require("./HTMLElement-impl").implementation;
|
const { removeStylesheet, createStylesheet } = require("../helpers/stylesheets");
|
const { documentBaseURL } = require("../helpers/document-base-url");
|
const { childTextContent } = require("../helpers/text");
|
const { asciiCaseInsensitiveMatch } = require("../helpers/strings");
|
|
class HTMLStyleElementImpl extends HTMLElementImpl {
|
constructor(args, privateData) {
|
super(args, privateData);
|
|
this.sheet = null;
|
this._isOnStackOfOpenElements = false;
|
}
|
|
_attach() {
|
super._attach();
|
if (!this._isOnStackOfOpenElements) {
|
this._updateAStyleBlock();
|
}
|
}
|
|
_detach() {
|
super._detach();
|
if (!this._isOnStackOfOpenElements) {
|
this._updateAStyleBlock();
|
}
|
}
|
|
_childTextContentChangeSteps() {
|
super._childTextContentChangeSteps();
|
|
// This guard is not required by the spec, but should be unobservable (since you can't run script during the middle
|
// of parsing a <style> element) and saves a bunch of unnecessary work.
|
if (!this._isOnStackOfOpenElements) {
|
this._updateAStyleBlock();
|
}
|
}
|
|
_poppedOffStackOfOpenElements() {
|
this._isOnStackOfOpenElements = false;
|
this._updateAStyleBlock();
|
}
|
|
_pushedOnStackOfOpenElements() {
|
this._isOnStackOfOpenElements = true;
|
}
|
|
_updateAStyleBlock() {
|
if (this.sheet) {
|
removeStylesheet(this.sheet, this);
|
}
|
|
if (!this._attached) {
|
return;
|
}
|
|
const type = this.getAttribute("type");
|
if (type !== null && type !== "" && !asciiCaseInsensitiveMatch(type, "text/css")) {
|
return;
|
}
|
|
// Not implemented: CSP
|
|
const content = childTextContent(this);
|
// Not implemented: a bunch of other state, e.g. title/media attributes
|
createStylesheet(content, this, documentBaseURL(this._ownerDocument));
|
}
|
}
|
|
module.exports = {
|
implementation: HTMLStyleElementImpl
|
};
|