(event: LoggerEvent)
| 27 | | (() => Promise<LoggerContext>), |
| 28 | ): void { |
| 29 | async function logEvent(event: LoggerEvent) { |
| 30 | if (enableLogger) { |
| 31 | if (currentLoggingIFrame != null && currentSessionId != null) { |
| 32 | const {metadata, ...eventWithoutMetadata} = event; |
| 33 | const additionalContext: LoggerContext | {} = |
| 34 | fetchAdditionalContext != null ? await fetchAdditionalContext() : {}; |
| 35 | |
| 36 | currentLoggingIFrame?.contentWindow?.postMessage( |
| 37 | { |
| 38 | source: 'react-devtools-logging', |
| 39 | event: eventWithoutMetadata, |
| 40 | context: { |
| 41 | ...additionalContext, |
| 42 | metadata: metadata != null ? JSON.stringify(metadata) : '', |
| 43 | session_id: currentSessionId, |
| 44 | surface, |
| 45 | version: process.env.DEVTOOLS_VERSION, |
| 46 | }, |
| 47 | }, |
| 48 | '*', |
| 49 | ); |
| 50 | } else { |
| 51 | missedEvents.push(event); |
| 52 | } |
| 53 | } |
| 54 | } |
| 55 | |
| 56 | function handleLoggingIFrameLoaded(iframe: HTMLIFrameElement) { |
| 57 | currentLoggingIFrame = iframe; |
no test coverage detected