(trackingData, options)
| 4 | import useTrackingImpl from './useTrackingImpl'; |
| 5 | |
| 6 | export default function useTracking(trackingData, options) { |
| 7 | const contextValue = useTrackingImpl(trackingData, options); |
| 8 | |
| 9 | const Track = useCallback( |
| 10 | ({ children }) => ( |
| 11 | <ReactTrackingContext.Provider value={contextValue}> |
| 12 | {children} |
| 13 | </ReactTrackingContext.Provider> |
| 14 | ), |
| 15 | [contextValue] |
| 16 | ); |
| 17 | |
| 18 | useDebugValue(contextValue.tracking.getTrackingData, getTrackingData => |
| 19 | getTrackingData() |
| 20 | ); |
| 21 | |
| 22 | return useMemo( |
| 23 | () => ({ |
| 24 | Track, |
| 25 | getTrackingData: contextValue.tracking.getTrackingData, |
| 26 | trackEvent: contextValue.tracking.dispatch, |
| 27 | }), |
| 28 | [contextValue, Track] |
| 29 | ); |
| 30 | } |
searching dependent graphs…