import { PlayerEventType, THEOplayer } from 'react-native-theoplayer'; import { RefObject, useEffect, useRef } from 'react'; import { AnalyticsConfig, BitmovinConnector } from '@theoplayer/react-native-analytics-bitmovin'; import { DefaultMetadata } from '../DefaultMetadata'; export type InitBitmovin = (player: THEOplayer | undefined, defaultMetadata?: DefaultMetadata) => void; export function useBitmovin(config: AnalyticsConfig): [RefObject, InitBitmovin] { const connector = useRef(undefined); const theoPlayer = useRef(undefined); const initialize: InitBitmovin = (player: THEOplayer | undefined, defaultMetadata?: DefaultMetadata) => { // Optionally destroy existent connector onDestroy(); theoPlayer.current = player; if (player) { connector.current = new BitmovinConnector(player, config, defaultMetadata); player.addEventListener(PlayerEventType.DESTROY, onDestroy); } else { throw new Error('Invalid THEOplayer instance'); } }; const onDestroy = () => { if (connector.current) { if (!theoPlayer.current) { throw new Error('Invalid THEOplayer instance'); } theoPlayer.current.removeEventListener(PlayerEventType.DESTROY, onDestroy); connector.current.destroy(); connector.current = undefined; } }; useEffect(() => { return onDestroy; }, []); return [connector, initialize]; }