UNPKG

web-vitals

Version:

Easily measure performance metrics in JavaScript

59 lines (54 loc) 2.03 kB
/* * Copyright 2020 Google LLC * * 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 * * https://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 {FirstInputPolyfillEntry, NavigationTimingPolyfillEntry} from '../types.js'; interface PerformanceEntryMap { 'event': PerformanceEventTiming[]; 'paint': PerformancePaintTiming[]; 'layout-shift': LayoutShift[]; 'largest-contentful-paint': LargestContentfulPaint[]; 'first-input': PerformanceEventTiming[] | FirstInputPolyfillEntry[]; 'navigation': PerformanceNavigationTiming[] | NavigationTimingPolyfillEntry[]; 'resource': PerformanceResourceTiming[]; } /** * Takes a performance entry type and a callback function, and creates a * `PerformanceObserver` instance that will observe the specified entry type * with buffering enabled and call the callback _for each entry_. * * This function also feature-detects entry support and wraps the logic in a * try/catch to avoid errors in unsupporting browsers. */ export const observe = <K extends keyof PerformanceEntryMap>( type: K, callback: (entries: PerformanceEntryMap[K]) => void, opts?: PerformanceObserverInit, ): PerformanceObserver | undefined => { try { if (PerformanceObserver.supportedEntryTypes.includes(type)) { const po = new PerformanceObserver((list) => { callback(list.getEntries() as PerformanceEntryMap[K]); }); po.observe(Object.assign({ type, buffered: true, }, opts || {}) as PerformanceObserverInit); return po; } } catch (e) { // Do nothing. } return; };