UNPKG

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.

239 lines (211 loc) 5.15 kB
import Event from '../../event/Event.js'; import * as PropertySymbol from '../../PropertySymbol.js'; import BrowserWindow from '../../window/BrowserWindow.js'; import Document from '../document/Document.js'; import HTMLElement from '../html-element/HTMLElement.js'; import Node from '../node/Node.js'; import NamedNodeMap from '../../named-node-map/NamedNodeMap.js'; import HTMLIFrameElementNamedNodeMap from './HTMLIFrameElementNamedNodeMap.js'; import CrossOriginBrowserWindow from '../../window/CrossOriginBrowserWindow.js'; import IBrowserFrame from '../../browser/types/IBrowserFrame.js'; import HTMLIFrameElementPageLoader from './HTMLIFrameElementPageLoader.js'; import DOMTokenList from '../../dom-token-list/DOMTokenList.js'; /** * HTML Iframe Element. * * Reference: * https://developer.mozilla.org/en-US/docs/Web/API/HTMLIFrameElement. */ export default class HTMLIFrameElement extends HTMLElement { // Public properties public cloneNode: (deep?: boolean) => HTMLIFrameElement; // Events public onload: (event: Event) => void | null = null; public onerror: (event: Event) => void | null = null; // Internal properties public override [PropertySymbol.attributes]: NamedNodeMap; public [PropertySymbol.sandbox]: DOMTokenList = null; // Private properties #contentWindowContainer: { window: BrowserWindow | CrossOriginBrowserWindow | null } = { window: null }; #pageLoader: HTMLIFrameElementPageLoader; /** * Constructor. * * @param browserFrame Browser frame. */ constructor(browserFrame: IBrowserFrame) { super(); this.#pageLoader = new HTMLIFrameElementPageLoader({ element: this, contentWindowContainer: this.#contentWindowContainer, browserParentFrame: browserFrame }); this[PropertySymbol.attributes] = new HTMLIFrameElementNamedNodeMap(this, this.#pageLoader); } /** * Returns source. * * @returns Source. */ public get src(): string { return this.getAttribute('src') || ''; } /** * Sets source. * * @param src Source. */ public set src(src: string) { this.setAttribute('src', src); } /** * Returns allow. * * @returns Allow. */ public get allow(): string { return this.getAttribute('allow') || ''; } /** * Sets allow. * * @param allow Allow. */ public set allow(allow: string) { this.setAttribute('allow', allow); } /** * Returns height. * * @returns Height. */ public get height(): string { return this.getAttribute('height') || ''; } /** * Sets height. * * @param height Height. */ public set height(height: string) { this.setAttribute('height', height); } /** * Returns width. * * @returns Width. */ public get width(): string { return this.getAttribute('width') || ''; } /** * Sets width. * * @param width Width. */ public set width(width: string) { this.setAttribute('width', width); } /** * Returns name. * * @returns Name. */ public get name(): string { return this.getAttribute('name') || ''; } /** * Sets name. * * @param name Name. */ public set name(name: string) { this.setAttribute('name', name); } /** * Returns sandbox. * * @returns Sandbox. */ public get sandbox(): DOMTokenList { if (!this[PropertySymbol.sandbox]) { this[PropertySymbol.sandbox] = new DOMTokenList(this, 'sandbox'); } return <DOMTokenList>this[PropertySymbol.sandbox]; } /** * Sets sandbox. */ public set sandbox(sandbox: string) { this.setAttribute('sandbox', sandbox); } /** * Returns srcdoc. * * @returns Srcdoc. */ public get srcdoc(): string { return this.getAttribute('srcdoc') || ''; } /** * Sets srcdoc. * * @param srcdoc Srcdoc. */ public set srcdoc(srcdoc: string) { this.setAttribute('srcdoc', srcdoc); } /** * Returns referrer policy. */ public get referrerPolicy(): string { return this.getAttribute('referrerpolicy') || ''; } /** * Sets referrer policy. * * @param referrerPolicy Referrer policy. */ public set referrerPolicy(referrerPolicy: string) { this.setAttribute('referrerpolicy', referrerPolicy); } /** * Returns content document. * * @returns Content document. */ public get contentDocument(): Document | null { return (<BrowserWindow>this.#contentWindowContainer.window)?.document ?? null; } /** * Returns content window. * * @returns Content window. */ public get contentWindow(): BrowserWindow | CrossOriginBrowserWindow | null { return this.#contentWindowContainer.window; } /** * @override */ public override [PropertySymbol.connectToNode](parentNode: Node = null): void { const isConnected = this[PropertySymbol.isConnected]; const isParentConnected = parentNode ? parentNode[PropertySymbol.isConnected] : false; super[PropertySymbol.connectToNode](parentNode); if (isConnected !== isParentConnected) { if (isParentConnected) { this.#pageLoader.loadPage(); } else { this.#pageLoader.unloadPage(); } } } /** * @override */ public override [PropertySymbol.cloneNode](deep = false): HTMLIFrameElement { return <HTMLIFrameElement>super[PropertySymbol.cloneNode](deep); } }