import CSSRule from '../CSSRule.js'; import * as PropertySymbol from '../../PropertySymbol.js'; import CSSStyleDeclaration from '../declaration/CSSStyleDeclaration.js'; import CSSRuleTypeEnum from '../CSSRuleTypeEnum.js'; /** * CSSFontFaceRule interface. * * @see https://developer.mozilla.org/en-US/docs/Web/API/CSSFontFaceRule */ export default class CSSFontFaceRule extends CSSRule { public [PropertySymbol.cssText] = ''; #style: CSSStyleDeclaration | null = null; /** * @override */ public override get type(): CSSRuleTypeEnum { return CSSRuleTypeEnum.fontFaceRule; } /** * @override */ public get cssText(): string { return `@font-face { ${this.style.cssText} }`; } /** * Returns style. * * @returns Style. */ public get style(): CSSStyleDeclaration { if (!this.#style) { this.#style = new CSSStyleDeclaration( PropertySymbol.illegalConstructor, this[PropertySymbol.window] ); (this.#style.parentRule) = this; this.#style.cssText = this[PropertySymbol.cssText]; } return this.#style; } }