happy-dom
Version:
Happy DOM is a JavaScript implementation of a web browser without its graphical user interface. It includes many web standards from WHATWG DOM and HTML.
41 lines (37 loc) • 997 B
text/typescript
import CSSRule from '../CSSRule.js';
import * as PropertySymbol from '../../PropertySymbol.js';
import CSSStyleDeclaration from '../declaration/CSSStyleDeclaration.js';
import CSSRuleTypeEnum from '../CSSRuleTypeEnum.js';
/**
* CSSRule interface.
*/
export default class CSSKeyframeRule extends CSSRule {
public readonly type = CSSRuleTypeEnum.keyframeRule;
public readonly keyText: string;
public [PropertySymbol.cssText] = '';
#style: CSSStyleDeclaration | null = null;
/**
* Returns style.
*
* @returns Style.
*/
public get style(): CSSStyleDeclaration {
if (!this.#style) {
this.#style = new CSSStyleDeclaration(
PropertySymbol.illegalConstructor,
this[PropertySymbol.window]
);
(<CSSRule>this.#style.parentRule) = this;
this.#style.cssText = this[PropertySymbol.cssText];
}
return this.#style;
}
/**
* Returns css text.
*
* @returns CSS text.
*/
public get cssText(): string {
return `${this.keyText} { ${this.style.cssText} }`;
}
}