mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
afd954efbb
Summary: Changelog: [Internal] This adds definition of `PerformanceEventTiming` interface, according to the W3C standard, so that [event timing](https://www.w3.org/TR/event-timing) data can be reported from native (the C++ part is in the next diff). See here: https://www.w3.org/TR/event-timing/#performanceeventtiming Reviewed By: christophpurrer Differential Revision: D42279486 fbshipit-source-id: 0dfbcd6e5a08fc1b89651bd35b24fb4e731f8b05
40 lines
1.1 KiB
JavaScript
40 lines
1.1 KiB
JavaScript
/**
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @format
|
|
* @flow strict
|
|
*/
|
|
|
|
import type {HighResTimeStamp} from './PerformanceEntry';
|
|
|
|
import {PerformanceEntry} from './PerformanceEntry';
|
|
|
|
export class PerformanceEventTiming extends PerformanceEntry {
|
|
processingStart: HighResTimeStamp;
|
|
processingEnd: HighResTimeStamp;
|
|
interactionId: number;
|
|
|
|
constructor(init: {
|
|
name: string,
|
|
startTime?: HighResTimeStamp,
|
|
duration?: HighResTimeStamp,
|
|
processingStart?: HighResTimeStamp,
|
|
processingEnd?: HighResTimeStamp,
|
|
interactionId?: number,
|
|
isFirstInput?: boolean,
|
|
}) {
|
|
super({
|
|
name: init.name,
|
|
entryType: init.isFirstInput === true ? 'first-input' : 'measure',
|
|
startTime: init.startTime ?? 0,
|
|
duration: init.duration ?? 0,
|
|
});
|
|
this.processingStart = init.processingStart ?? 0;
|
|
this.processingEnd = init.processingEnd ?? 0;
|
|
this.interactionId = init.interactionId ?? 0;
|
|
}
|
|
}
|