UNPKG

chrome-devtools-frontend

Version:
61 lines (49 loc) 1.79 kB
// Copyright 2011 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. import type * as TextUtils from '../../models/text_utils/text_utils.js'; import * as UI from '../../ui/legacy/legacy.js'; import {html, nothing, render} from '../../ui/lit/lit.js'; import requestHTMLViewStyles from './requestHTMLView.css.js'; interface ViewInput { dataURL: string|null; } type View = (input: ViewInput, output: object, target: HTMLElement) => void; export const DEFAULT_VIEW: View = (input, _output, target) => { // Forbid to run JavaScript and set unique origin. // clang-format off render(html` <style>${requestHTMLViewStyles}</style> <div class="html request-view widget vbox"> ${input.dataURL ? html` <!-- @ts-ignore --> <iframe class="html-preview-frame" sandbox csp="default-src 'none';img-src data:;style-src 'unsafe-inline'" src=${input.dataURL} tabindex="-1" role="presentation"></iframe>` : nothing} </div>`, target); // clang-format on }; export class RequestHTMLView extends UI.Widget.VBox { readonly #dataURL: string; readonly #view: View; private constructor(dataURL: string, view = DEFAULT_VIEW) { super({useShadowDom: true}); this.#dataURL = dataURL; this.#view = view; } static create(contentData: TextUtils.ContentData.ContentData): RequestHTMLView|null { const dataURL = contentData.asDataUrl(); return dataURL ? new RequestHTMLView(dataURL) : null; } override wasShown(): void { super.wasShown(); this.requestUpdate(); } override willHide(): void { this.requestUpdate(); } override performUpdate(): void { this.#view({dataURL: this.#dataURL}, {}, this.contentElement); } }