1
0
mirror of https://github.com/oceanprotocol/commons.git synced 2023-03-15 18:03:00 +01:00

cleanup, refactor withTracker HOC

This commit is contained in:
Matthias Kretschmann 2019-04-15 15:44:02 +02:00
parent 7203b88b5e
commit 4aaa92f66a
Signed by: m
GPG Key ID: 606EEEF3C479A91F
4 changed files with 38 additions and 54 deletions

View File

@ -1,6 +1,6 @@
import React from 'react' import React from 'react'
import { Route, Switch } from 'react-router-dom' import { Route, Switch } from 'react-router-dom'
import withTracker from './withTracker' import withTracker from './hoc/withTracker'
import About from './routes/About' import About from './routes/About'
import Details from './routes/Details/' import Details from './routes/Details/'

View File

@ -130,18 +130,15 @@ export default class UserProvider extends PureComponent<{}, UserProviderState> {
this.setState({ message: 'Connecting to Ocean...' }) this.setState({ message: 'Connecting to Ocean...' })
const { ocean } = await provideOcean(web3) const { ocean } = await provideOcean(web3)
this.setState({ ocean }) this.setState({ ocean, message: 'Getting accounts...' })
// Get accounts // Get accounts
await this.fetchAccounts() await this.fetchAccounts()
this.setState({
isLoading: false,
requestFromFaucet: () =>
requestFromFaucet(this.state.account)
})
// Set proper network names now that we have Ocean // Set proper network names now that we have Ocean
this.fetchNetwork() await this.fetchNetwork()
this.setState({ isLoading: false })
} }
// Non-dapp browsers // Non-dapp browsers
else { else {

View File

@ -0,0 +1,33 @@
import React, { useEffect } from 'react'
import ReactGA, { FieldsObject } from 'react-ga'
import { RouteComponentProps } from 'react-router-dom'
import { analyticsId } from '../config/config'
const withTracker = <P extends RouteComponentProps>(
WrappedComponent: any,
options: FieldsObject = {}
) => {
ReactGA.initialize(analyticsId, {
testMode: process.env.NODE_ENV === 'development',
debug: process.env.NODE_ENV === 'development'
})
const trackPage = (page: string) => {
options.isWeb3 = window.web3 !== undefined
ReactGA.set({ page, ...options })
ReactGA.pageview(page)
}
const HOC = (props: P) => {
useEffect(() => trackPage(props.location.pathname), [
props.location.pathname
])
return <WrappedComponent {...props} />
}
return HOC
}
export default withTracker

View File

@ -1,46 +0,0 @@
import React, { PureComponent } from 'react'
import ReactGA from 'react-ga'
import { analyticsId } from './config/config'
interface TrackerProps {
location: Location
}
export default function withTracker(WrappedComponent: any, options: any = {}) {
ReactGA.initialize(analyticsId, {
testMode: process.env.NODE_ENV === 'test'
})
const trackPage = (page: string) => {
options.isWeb3 = window.web3 !== undefined
ReactGA.set({
page,
...options
})
ReactGA.pageview(page)
}
return class HOC extends PureComponent<TrackerProps, {}> {
public componentDidMount() {
const page =
this.props.location.pathname + this.props.location.search
trackPage(page)
}
public componentWillReceiveProps(nextProps: any) {
const currentPage = this.props.location.pathname
const nextPage = nextProps.location.pathname
if (currentPage !== nextPage) {
trackPage(
nextProps.location.pathname + nextProps.location.search
)
}
}
public render() {
return <WrappedComponent {...this.props} />
}
}
}