// Copyright 2018 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. import * as i18n from '../../core/i18n/i18n.js'; import {html, render} from '../lit/lit.js'; import targetCrashedScreenStyles from './targetCrashedScreen.css.js'; import {VBox} from './Widget.js'; const UIStrings = { /** * @description Text in dialog box when the target page crashed */ devtoolsWasDisconnectedFromThe: 'DevTools was disconnected from the page.', /** * @description Text content of content element */ oncePageIsReloadedDevtoolsWill: 'Once page is reloaded, DevTools will automatically reconnect.', } as const; const str_ = i18n.i18n.registerUIStrings('ui/legacy/TargetCrashedScreen.ts', UIStrings); const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_); type View = (input: object, output: object, target: HTMLElement) => void; export const DEFAULT_VIEW: View = (input, _output, target) => { // clang-format off render(html`
${i18nString(UIStrings.devtoolsWasDisconnectedFromThe)}
${i18nString(UIStrings.oncePageIsReloadedDevtoolsWill)}
`, target); // clang-format on }; export class TargetCrashedScreen extends VBox { private readonly hideCallback: () => void; constructor(hideCallback: () => void, view = DEFAULT_VIEW) { super({useShadowDom: true}); view({}, {}, this.contentElement); this.hideCallback = hideCallback; } override willHide(): void { super.willHide(); this.hideCallback.call(null); } }