Setting up router and home view (ongoing)
This commit is contained in:
parent
9c6ab2f585
commit
b5d2cbc3c2
5 changed files with 12206 additions and 0 deletions
57
src/components/Router.jsx
Normal file
57
src/components/Router.jsx
Normal file
|
@ -0,0 +1,57 @@
|
|||
import React from 'react'
|
||||
import { Router as ReactRouter, Route, Switch } from 'react-router-dom'
|
||||
import { createBrowserHistory as createHistory } from 'history'
|
||||
|
||||
/* Site */
|
||||
import Home from 'views/Home'
|
||||
import Team from 'views/Team'
|
||||
import Member from 'views/Member'
|
||||
|
||||
const history = createHistory()
|
||||
history.listen(location => {
|
||||
window.scrollTo(0,0)
|
||||
})
|
||||
|
||||
export function Router(props) {
|
||||
return (
|
||||
<ReactRouter history = { history }>
|
||||
<Switch>
|
||||
<Route exact path='/' component={Home} />
|
||||
<Route exact path='/team' render={(props) => <Team {...props} />} />
|
||||
<Route exact path='/member' render={(props) => <Member {...props} />} />
|
||||
</Switch>
|
||||
</ReactRouter>
|
||||
)
|
||||
}
|
||||
|
||||
// class Router extends React.Component {
|
||||
// constructor(props) {
|
||||
// super(props)
|
||||
// }
|
||||
|
||||
// componentDidMount() {
|
||||
// ReactGA.pageview(window.location.pathname)
|
||||
// }
|
||||
|
||||
// render() {
|
||||
// return (
|
||||
// <ReactRouter history = { history }>
|
||||
// <Switch>
|
||||
// <Route exact path='/' component={Home} />
|
||||
// <Route exact path='/featured' component={Featured} />
|
||||
// <Route
|
||||
// path="/blog"
|
||||
// render={({ match: { path } }) => (
|
||||
// <div>
|
||||
// <Route exact path={path} render={(props) => <Blog {...props} />} />
|
||||
// <Route path={`${path}/why-we-need-to-do-more-to-protect-our-children`} render={PostDoMore} />
|
||||
// </div>
|
||||
// )}
|
||||
// />
|
||||
// </Switch>
|
||||
// </ReactRouter>
|
||||
// )
|
||||
// }
|
||||
// }
|
||||
|
||||
// export default Router
|
3
src/config.json
Normal file
3
src/config.json
Normal file
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"api": "http://tempo-test.herokuapp.com/7d1d085e-dbee-4483-aa29-ca033ccae1e4/1"
|
||||
}
|
34
src/views/Home.jsx
Normal file
34
src/views/Home.jsx
Normal file
|
@ -0,0 +1,34 @@
|
|||
import React, { useState, useEffect } from 'react'
|
||||
import axios from 'axios'
|
||||
import config from '../config.json'
|
||||
|
||||
export default function Home() {
|
||||
// MARK: State
|
||||
let [loading, setLoading] = useState(true)
|
||||
let [teams, setTeams] = useState([])
|
||||
let [members, setMembers] = useState([])
|
||||
let [teamDetails, setTeamDetails] = useState([])
|
||||
|
||||
// MARK: Effects
|
||||
// MAKR: - Load data from Tempo backend on initialization
|
||||
useEffect(() => {
|
||||
let fetchData = async() => {
|
||||
setLoading(true)
|
||||
try {
|
||||
let result = await axios(config.api + '/team/')
|
||||
if (result.data) {
|
||||
setTeams(result.data)
|
||||
console.log('Backend ok')
|
||||
}
|
||||
setLoading(false)
|
||||
}
|
||||
catch(err) {
|
||||
setLoading(false)
|
||||
console.log('Fetch data error: ' + err)
|
||||
}
|
||||
}
|
||||
|
||||
fetchData()
|
||||
}, [])
|
||||
}
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue