mirror of
https://github.com/angular/angular
synced 2026-05-24 09:28:37 +00:00
47 lines
1.6 KiB
TypeScript
47 lines
1.6 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright Google LLC All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.dev/license
|
|
*/
|
|
|
|
import {ChangeDetectorRef, Component, inject, OnInit} from '@angular/core';
|
|
import {DevToolsComponent} from '../../../ng-devtools';
|
|
import {Events, MessageBus} from '../../../protocol';
|
|
|
|
@Component({
|
|
selector: 'app-root',
|
|
templateUrl: './app.component.html',
|
|
styleUrls: ['./app.component.scss'],
|
|
imports: [DevToolsComponent],
|
|
})
|
|
export class AppComponent implements OnInit {
|
|
private _cd = inject(ChangeDetectorRef);
|
|
private readonly _messageBus = inject<MessageBus<Events>>(MessageBus);
|
|
private onProfilingStartedListener = () => {
|
|
this._messageBus.emit('enableTimingAPI');
|
|
};
|
|
private onProfilingStoppedListener = () => {
|
|
this._messageBus.emit('disableTimingAPI');
|
|
};
|
|
ngOnInit(): void {
|
|
chrome.devtools.network.onNavigated.addListener(() => {
|
|
window.location.reload();
|
|
});
|
|
const chromeDevToolsPerformance = chrome.devtools.performance;
|
|
chromeDevToolsPerformance?.onProfilingStarted?.addListener?.(this.onProfilingStartedListener);
|
|
chromeDevToolsPerformance?.onProfilingStopped?.addListener?.(this.onProfilingStoppedListener);
|
|
|
|
this._cd.detectChanges();
|
|
}
|
|
ngOnDestroy(): void {
|
|
const chromeDevToolsPerformance = chrome.devtools.performance;
|
|
chromeDevToolsPerformance?.onProfilingStarted?.removeListener?.(
|
|
this.onProfilingStartedListener,
|
|
);
|
|
chromeDevToolsPerformance?.onProfilingStopped?.removeListener?.(
|
|
this.onProfilingStoppedListener,
|
|
);
|
|
}
|
|
}
|