| // Copyright (C) 2023 The Android Open Source Project |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| |
| import {v4 as uuidv4} from 'uuid'; |
| |
| import {Actions} from '../../common/actions'; |
| import {SCROLLING_TRACK_GROUP} from '../../common/state'; |
| import {globals} from '../../frontend/globals'; |
| import {NamedSliceTrackTypes} from '../../frontend/named_slice_track'; |
| import {NewTrackArgs, TrackBase} from '../../frontend/track'; |
| import { |
| Plugin, |
| PluginContext, |
| PluginContextTrace, |
| PluginDescriptor, |
| PrimaryTrackSortKey, |
| } from '../../public'; |
| import { |
| CustomSqlDetailsPanelConfig, |
| CustomSqlImportConfig, |
| CustomSqlTableDefConfig, |
| CustomSqlTableSliceTrack, |
| } from '../custom_sql_table_slices'; |
| |
| import {CriticalUserInteractionDetailsPanel} from './details_panel'; |
| |
| export const CRITICAL_USER_INTERACTIONS_KIND = |
| 'org.chromium.TopLevelScrolls.scrolls'; |
| |
| export class CriticalUserInteractionTrack extends |
| CustomSqlTableSliceTrack<NamedSliceTrackTypes> { |
| static readonly kind = CRITICAL_USER_INTERACTIONS_KIND; |
| |
| static create(args: NewTrackArgs): TrackBase { |
| return new CriticalUserInteractionTrack(args); |
| } |
| |
| getSqlDataSource(): CustomSqlTableDefConfig { |
| return { |
| columns: ['scoped_id AS id', 'name', 'ts', 'dur', 'type'], |
| sqlTableName: 'chrome_interactions', |
| }; |
| } |
| |
| getDetailsPanel(): CustomSqlDetailsPanelConfig { |
| return { |
| kind: CriticalUserInteractionDetailsPanel.kind, |
| config: { |
| sqlTableName: this.tableName, |
| title: 'Chrome Critical User Interaction', |
| }, |
| }; |
| } |
| |
| getSqlImports(): CustomSqlImportConfig { |
| return { |
| modules: ['chrome.interactions'], |
| }; |
| } |
| } |
| |
| export function addCriticalUserInteractionTrack() { |
| const trackId = uuidv4(); |
| globals.dispatchMultiple([ |
| Actions.addTrack({ |
| id: trackId, |
| uri: CriticalUserInteractionTrack.kind, |
| name: `Chrome Interactions`, |
| trackSortKey: PrimaryTrackSortKey.DEBUG_TRACK, |
| trackGroup: SCROLLING_TRACK_GROUP, |
| }), |
| Actions.toggleTrackPinned({trackId}), |
| ]); |
| } |
| |
| class CriticalUserInteractionPlugin implements Plugin { |
| async onTraceLoad(ctx: PluginContextTrace): Promise<void> { |
| ctx.addTrack({ |
| uri: CriticalUserInteractionTrack.kind, |
| kind: CriticalUserInteractionTrack.kind, |
| displayName: 'Chrome Interactions', |
| track: (trackCtx) => new CriticalUserInteractionTrack( |
| {engine: ctx.engine, trackId: trackCtx.trackInstanceId}), |
| }); |
| } |
| |
| onActivate(ctx: PluginContext): void { |
| ctx.addCommand({ |
| id: 'perfetto.CriticalUserInteraction.AddInteractionTrack', |
| name: 'Add Chrome Interactions track', |
| callback: () => addCriticalUserInteractionTrack(), |
| }); |
| } |
| } |
| |
| export const plugin: PluginDescriptor = { |
| pluginId: 'perfetto.CriticalUserInteraction', |
| plugin: CriticalUserInteractionPlugin, |
| }; |