// @flow import React, { useEffect, useState } from 'react' import GoogleAnalytics from 'react-ga' import { getGoogleAnalyticsTrackingID } from '~/config' import { COOKIES_KEY } from '~/logic/cookies/model/cookie' import type { CookiesProps } from '~/logic/cookies/model/cookie' import { loadFromCookie } from '~/logic/cookies/utils' import type { RouterProps } from '~/routes/safe/store/selectors' let analyticsLoaded = false export const loadGoogleAnalytics = () => { if (analyticsLoaded) { return } // eslint-disable-next-line no-console console.log('Loading google analytics...') const trackingID = getGoogleAnalyticsTrackingID() if (!trackingID) { console.error('[GoogleAnalytics] - In order to use google analytics you need to add an trackingID') } else { GoogleAnalytics.initialize(trackingID) GoogleAnalytics.set({ anonymizeIp: true }) analyticsLoaded = true } } export const withTracker = (WrappedComponent, options = {}) => { const [useAnalytics, setUseAnalytics] = useState(false) useEffect(() => { async function fetchCookiesFromStorage() { const cookiesState: CookiesProps = await loadFromCookie(COOKIES_KEY) if (cookiesState) { const { acceptedAnalytics } = cookiesState setUseAnalytics(acceptedAnalytics) } } fetchCookiesFromStorage() }, []) const trackPage = (page) => { if (!useAnalytics || !analyticsLoaded) { return } GoogleAnalytics.set({ page, ...options, }) GoogleAnalytics.pageview(page) } const HOC = (props: RouterProps) => { // eslint-disable-next-line react/prop-types const { location } = props useEffect(() => { const page = location.pathname + location.search trackPage(page) }, [location.pathname]) return } return HOC }