chrome-devtools-frontend
Version:
Chrome DevTools UI
184 lines (166 loc) • 7.73 kB
text/typescript
// Copyright 2019 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 * as Root from '../../core/root/root.js';
import * as Trace from '../../models/trace/trace.js';
const UIStrings = {
/**
* @description Text in Timeline UIUtils of the Performance panel
*/
frameStart: 'Frame start',
/**
* @description Text in Timeline UIUtils of the Performance panel
*/
drawFrame: 'Draw frame',
/**
* @description Text in Timeline UIUtils of the Performance panel
*/
layout: 'Layout',
/**
* @description Text in UIDevtools Utils of the Performance panel
*/
rasterizing: 'Rasterizing',
/**
* @description Text in UIDevtools Utils of the Performance panel
*/
drawing: 'Drawing',
/**
* @description Text in Timeline UIUtils of the Performance panel
*/
painting: 'Painting',
/**
* @description Text in Timeline UIUtils of the Performance panel
*/
system: 'System',
/**
* @description Text in Timeline UIUtils of the Performance panel
*/
idle: 'Idle',
/**
* @description Category in the Summary view of the Performance panel to indicate time spent to load resources
*/
loading: 'Loading',
/**
* @description Text in Timeline for the Experience title
*/
experience: 'Experience',
/**
* @description Category in the Summary view of the Performance panel to indicate time spent in script execution
*/
scripting: 'Scripting',
/**
* @description Category in the Summary view of the Performance panel to indicate time spent in rendering the web page
*/
rendering: 'Rendering',
/**
* @description Event category in the Performance panel for time spent in the GPU
*/
gpu: 'GPU',
/**
* @description Text in Timeline UIUtils of the Performance panel
*/
async: 'Async',
/**
* @description Text in Timeline UIUtils of the Performance panel
*/
messaging: 'Messaging',
} as const;
const str_ = i18n.i18n.registerUIStrings('panels/timeline/UIDevtoolsUtils.ts', UIStrings);
const i18nString = i18n.i18n.getLocalizedString.bind(undefined, str_);
let eventStylesMap: Record<string, Trace.Styles.TimelineRecordStyle>|null = null;
let categories: Trace.Styles.CategoryPalette|null = null;
export class UIDevtoolsUtils {
static isUiDevTools(): boolean {
return Root.Runtime.Runtime.queryParam('uiDevTools') === 'true';
}
static categorizeEvents(): Record<string, Trace.Styles.TimelineRecordStyle> {
if (eventStylesMap) {
return eventStylesMap;
}
const type = RecordType;
const categories = UIDevtoolsUtils.categories();
const drawing = categories['drawing'];
const rasterizing = categories['rasterizing'];
const layout = categories['layout'];
const painting = categories['painting'];
const other = categories['other'];
const eventStyles: Record<string, Trace.Styles.TimelineRecordStyle> = {};
const {TimelineRecordStyle} = Trace.Styles;
// Paint Categories
eventStyles[type.ViewPaint] = new TimelineRecordStyle('View::Paint', painting);
eventStyles[type.ViewOnPaint] = new TimelineRecordStyle('View::OnPaint', painting);
eventStyles[type.ViewPaintChildren] = new TimelineRecordStyle('View::PaintChildren', painting);
eventStyles[type.ViewOnPaintBackground] = new TimelineRecordStyle('View::OnPaintBackground', painting);
eventStyles[type.ViewOnPaintBorder] = new TimelineRecordStyle('View::OnPaintBorder', painting);
eventStyles[type.LayerPaintContentsToDisplayList] =
new TimelineRecordStyle('Layer::PaintContentsToDisplayList', painting);
// Layout Categories
eventStyles[type.ViewLayout] = new TimelineRecordStyle('View::Layout', layout);
eventStyles[type.ViewLayoutBoundsChanged] = new TimelineRecordStyle('View::Layout(bounds_changed)', layout);
// Raster Categories
eventStyles[type.RasterTask] = new TimelineRecordStyle('RasterTask', rasterizing);
eventStyles[type.RasterizerTaskImplRunOnWorkerThread] =
new TimelineRecordStyle('RasterizerTaskImpl::RunOnWorkerThread', rasterizing);
// Draw Categories
eventStyles[type.DirectRendererDrawFrame] = new TimelineRecordStyle('DirectRenderer::DrawFrame', drawing);
eventStyles[type.BeginFrame] = new TimelineRecordStyle(i18nString(UIStrings.frameStart), drawing, true);
eventStyles[type.DrawFrame] = new TimelineRecordStyle(i18nString(UIStrings.drawFrame), drawing, true);
eventStyles[type.NeedsBeginFrameChanged] = new TimelineRecordStyle('NeedsBeginFrameChanged', drawing, true);
// Other Categories
eventStyles[type.ThreadControllerImplRunTask] = new TimelineRecordStyle('ThreadControllerImpl::RunTask', other);
eventStylesMap = eventStyles;
return eventStyles;
}
static categories(): Trace.Styles.CategoryPalette {
if (categories) {
return categories;
}
const {TimelineCategory, EventCategory} = Trace.Styles;
categories = {
layout: new TimelineCategory(EventCategory.LAYOUT, i18nString(UIStrings.layout), true, '--app-color-loading'),
rasterizing: new TimelineCategory(
EventCategory.RASTERIZING, i18nString(UIStrings.rasterizing), true, '--app-color-scripting'),
drawing:
new TimelineCategory(EventCategory.DRAWING, i18nString(UIStrings.drawing), true, '--app-color-rendering'),
painting:
new TimelineCategory(EventCategory.PAINTING, i18nString(UIStrings.painting), true, '--app-color-painting'),
other: new TimelineCategory(EventCategory.OTHER, i18nString(UIStrings.system), false, '--app-color-system'),
idle: new TimelineCategory(EventCategory.IDLE, i18nString(UIStrings.idle), false, '--app-color-idle'),
loading: new TimelineCategory(EventCategory.LOADING, i18nString(UIStrings.loading), false, '--app-color-loading'),
experience: new TimelineCategory(
EventCategory.EXPERIENCE, i18nString(UIStrings.experience), false, '--app-color-rendering'),
messaging: new TimelineCategory(
EventCategory.MESSAGING, i18nString(UIStrings.messaging), false, '--app-color-messaging'),
scripting: new TimelineCategory(
EventCategory.SCRIPTING, i18nString(UIStrings.scripting), false, '--app-color-scripting'),
rendering: new TimelineCategory(
EventCategory.RENDERING, i18nString(UIStrings.rendering), false, '--app-color-rendering'),
gpu: new TimelineCategory(EventCategory.GPU, i18nString(UIStrings.gpu), false, '--app-color-painting'),
async: new TimelineCategory(EventCategory.ASYNC, i18nString(UIStrings.async), false, '--app-color-async'),
};
return categories;
}
static getMainCategoriesList(): string[] {
return ['idle', 'drawing', 'painting', 'rasterizing', 'layout', 'other'];
}
}
export enum RecordType {
/* eslint-disable @typescript-eslint/naming-convention -- Used by web_tests. */
ViewPaint = 'View::Paint',
ViewOnPaint = 'View::OnPaint',
ViewPaintChildren = 'View::PaintChildren',
ViewOnPaintBackground = 'View::OnPaintBackground',
ViewOnPaintBorder = 'View::OnPaintBorder',
ViewLayout = 'View::Layout',
ViewLayoutBoundsChanged = 'View::Layout(bounds_changed)',
LayerPaintContentsToDisplayList = 'Layer::PaintContentsToDisplayList',
DirectRendererDrawFrame = 'DirectRenderer::DrawFrame',
RasterTask = 'RasterTask',
RasterizerTaskImplRunOnWorkerThread = 'RasterizerTaskImpl::RunOnWorkerThread',
BeginFrame = 'BeginFrame',
DrawFrame = 'DrawFrame',
NeedsBeginFrameChanged = 'NeedsBeginFrameChanged',
ThreadControllerImplRunTask = 'ThreadControllerImpl::RunTask',
/* eslint-enable @typescript-eslint/naming-convention */
}