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.
64 lines (58 loc) • 1.69 kB
text/typescript
import IBrowserFrame from '../types/IBrowserFrame.js';
import IBrowserPage from '../types/IBrowserPage.js';
import IVirtualConsolePrinter from '../../console/IVirtualConsolePrinter.js';
import IBrowserContext from '../types/IBrowserContext.js';
import BrowserFrameFactory from './BrowserFrameFactory.js';
/**
* Browser page utility.
*/
export default class BrowserPageUtility {
/**
* Returns frames for a page.
*
* @param page Page.
* @returns Frames.
*/
public static getFrames(page: IBrowserPage): IBrowserFrame[] {
return this.findFrames(page.mainFrame);
}
/**
* Aborts all ongoing operations and destroys the page.
*
* @param page Page.
*/
public static closePage(page: IBrowserPage): Promise<void> {
// Using Promise instead of async/await to prevent microtask
return new Promise((resolve, reject) => {
if (!page.mainFrame) {
resolve();
return;
}
const index = page.context.pages.indexOf(page);
if (index !== -1) {
page.context.pages.splice(index, 1);
}
BrowserFrameFactory.destroyFrame(page.mainFrame)
.then(() => {
(<IVirtualConsolePrinter | null>page.virtualConsolePrinter) = null;
(<IBrowserFrame | null>page.mainFrame) = null;
(<IBrowserContext | null>page.context) = null;
resolve();
})
.catch((error) => reject(error));
});
}
/**
* Returns all frames.
*
* @param parentFrame Parent frame.
* @returns Frames, including the parent.
*/
private static findFrames(parentFrame: IBrowserFrame): IBrowserFrame[] {
let frames = [parentFrame];
for (const frame of parentFrame.childFrames) {
frames = frames.concat(this.findFrames(frame));
}
return frames;
}
}