packages/relay-runtime/util/withDuration.js (16 lines of code) (raw):
/**
* 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
* @format
*/
// flowlint ambiguous-object-type:error
'use strict';
const isPerformanceNowAvailable =
typeof window !== 'undefined' &&
typeof window?.performance?.now === 'function';
function currentTimestamp(): number {
if (isPerformanceNowAvailable) {
return window.performance.now();
}
return Date.now();
}
function withDuration<T>(cb: () => T): [number, T] {
const startTime = currentTimestamp();
const result = cb();
return [currentTimestamp() - startTime, result];
}
module.exports = withDuration;