You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
33 lines
1.0 KiB
33 lines
1.0 KiB
/**
|
|
* 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.
|
|
*
|
|
* @flow strict
|
|
* @format
|
|
*/
|
|
|
|
import * as React from 'react';
|
|
import {useContext} from 'react';
|
|
import GlobalPerformanceLogger from './GlobalPerformanceLogger';
|
|
import type {IPerformanceLogger} from './createPerformanceLogger';
|
|
|
|
/**
|
|
* This is a React Context that provides a scoped instance of IPerformanceLogger.
|
|
* We wrap every <AppContainer /> with a Provider for this context so the logger
|
|
* should be available in every component.
|
|
* See React docs about using Context: https://reactjs.org/docs/context.html
|
|
*/
|
|
const PerformanceLoggerContext: React.Context<IPerformanceLogger> =
|
|
React.createContext(GlobalPerformanceLogger);
|
|
if (__DEV__) {
|
|
PerformanceLoggerContext.displayName = 'PerformanceLoggerContext';
|
|
}
|
|
|
|
export function usePerformanceLogger(): IPerformanceLogger {
|
|
return useContext(PerformanceLoggerContext);
|
|
}
|
|
|
|
export default PerformanceLoggerContext;
|