chrome-devtools-frontend
Version:
Chrome DevTools UI
110 lines (95 loc) • 3.38 kB
text/typescript
// Copyright 2022 The Chromium Authors. All rights reserved.
// 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 * as DataGrid from '../../../../ui/components/data_grid/data_grid.js';
import * as ComponentHelpers from '../../../../ui/components/helpers/helpers.js';
import * as LitHtml from '../../../../ui/lit-html/lit-html.js';
import preloadingGridStyles from './preloadingGrid.css.js';
const UIStrings = {
/**
*@description Column header: Action of preloading (prefetch/prerender)
*/
action: 'Action',
/**
*@description Column header: Status of preloading attempt
*/
status: 'Status',
};
const str_ = i18n.i18n.registerUIStrings('panels/application/preloading/components/PreloadingGrid.ts', UIStrings);
export const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
const {render, html} = LitHtml;
export interface PreloadingGridRow {
id: string;
action: string;
url: string;
status: string;
}
// Grid component to show prerendering attempts.
export class PreloadingGrid extends HTMLElement {
static readonly litTagName = LitHtml.literal`devtools-resources-preloading-grid`;
readonly #shadow = this.attachShadow({mode: 'open'});
#rows: PreloadingGridRow[] = [];
connectedCallback(): void {
this.#shadow.adoptedStyleSheets = [preloadingGridStyles];
this.#render();
}
update(rows: PreloadingGridRow[]): void {
this.#rows = rows;
this.#render();
}
#render(): void {
const reportsGridData: DataGrid.DataGridController.DataGridControllerData = {
columns: [
{
id: 'url',
title: i18n.i18n.lockedString('URL'),
widthWeighting: 40,
hideable: false,
visible: true,
},
{
id: 'action',
title: i18nString(UIStrings.action),
widthWeighting: 15,
hideable: false,
visible: true,
},
{
id: 'status',
title: i18nString(UIStrings.status),
widthWeighting: 15,
hideable: false,
visible: true,
},
],
rows: this.#buildReportRows(),
};
// Disabled until https://crbug.com/1079231 is fixed.
// clang-format off
render(html`
<div class="preloading-container">
<${DataGrid.DataGridController.DataGridController.litTagName} .data=${
reportsGridData as DataGrid.DataGridController.DataGridControllerData}>
</${DataGrid.DataGridController.DataGridController.litTagName}>
</div>
`, this.#shadow, {host: this});
// clang-format on
}
#buildReportRows(): DataGrid.DataGridUtils.Row[] {
return this.#rows.map(row => ({
cells: [
{columnId: 'id', value: row.id},
{columnId: 'url', value: row.url},
{columnId: 'action', value: row.action},
{columnId: 'status', value: row.status},
],
}));
}
}
ComponentHelpers.CustomElements.defineComponent('devtools-resources-preloading-grid', PreloadingGrid);
declare global {
interface HTMLElementTagNameMap {
'devtools-resources-preloading-grid': PreloadingGrid;
}
}