| // Copyright 2021 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| import 'chrome://resources/cr_elements/cr_button/cr_button.js'; |
| import 'chrome://resources/cr_elements/cr_dialog/cr_dialog.js'; |
| |
| import type {CrDialogElement} from 'chrome://resources/cr_elements/cr_dialog/cr_dialog.js'; |
| import {CrLitElement} from 'chrome://resources/lit/v3_0/lit.rollup.js'; |
| |
| import {getCss} from './info_dialog.css.js'; |
| import {getHtml} from './info_dialog.html.js'; |
| |
| export interface InfoDialogElement { |
| $: { |
| closeButton: HTMLElement, |
| dialog: CrDialogElement, |
| }; |
| } |
| |
| /** Info dialog that can be populated with custom text via slotting. */ |
| export class InfoDialogElement extends CrLitElement { |
| static get is() { |
| return 'ntp-info-dialog'; |
| } |
| |
| static override get styles() { |
| return getCss(); |
| } |
| |
| override render() { |
| return getHtml.bind(this)(); |
| } |
| |
| static override get properties() { |
| return { |
| showOnAttach: {type: Boolean}, |
| }; |
| } |
| |
| accessor showOnAttach: boolean = false; |
| |
| showModal() { |
| this.$.dialog.showModal(); |
| } |
| |
| protected onCloseClick_() { |
| this.$.dialog.close(); |
| } |
| } |
| |
| customElements.define(InfoDialogElement.is, InfoDialogElement); |