import { getActiveTransaction, spanToJSON } from '@sentry/core'; import { logger } from '@sentry/utils'; import { DEBUG_BUILD } from '../common/debug-build.js'; import { WINDOW } from './types.js'; /** * Add a listener that cancels and finishes a transaction when the global * document is hidden. */ function registerBackgroundTabDetection() { if (WINDOW && WINDOW.document) { WINDOW.document.addEventListener('visibilitychange', () => { // eslint-disable-next-line deprecation/deprecation const activeTransaction = getActiveTransaction() ; if (WINDOW.document.hidden && activeTransaction) { const statusType = 'cancelled'; const { op, status } = spanToJSON(activeTransaction); DEBUG_BUILD && logger.log(`[Tracing] Transaction: ${statusType} -> since tab moved to the background, op: ${op}`); // We should not set status if it is already set, this prevent important statuses like // error or data loss from being overwritten on transaction. if (!status) { activeTransaction.setStatus(statusType); } // TODO: Can we rewrite this to an attribute? // eslint-disable-next-line deprecation/deprecation activeTransaction.setTag('visibilitychange', 'document.hidden'); activeTransaction.end(); } }); } else { DEBUG_BUILD && logger.warn('[Tracing] Could not set up background tab detection due to lack of global document'); } } export { registerBackgroundTabDetection }; //# sourceMappingURL=backgroundtab.js.map