Set up react-router, bring out Home

This commit is contained in:
2020-01-09 07:38:49 +00:00
parent 1bf5dd182c
commit 381a5c99f3
4 changed files with 208 additions and 72 deletions

View File

@@ -1,7 +1,8 @@
import React, { useState, useEffect } from 'react';
import { BrowserRouter as Router, Switch, Route, Link } from 'react-router-dom';
import './light.css';
import Logo from './logo.svg';
import { Container, Divider, Form, Grid, Header, Icon, Image, Menu, Message, Segment, Table } from 'semantic-ui-react';
import { Container, Divider, Dropdown, Form, Grid, Header, Icon, Image, Menu, Message, Segment, Table } from 'semantic-ui-react';
import { requester } from './utils.js';
function LoginForm(props) {
@@ -53,7 +54,7 @@ function LoginForm(props) {
</Form.Button>
</Form>
);
}
};
function SignupForm(props) {
const [input, setInput] = useState({});
@@ -160,7 +161,7 @@ function SignupForm(props) {
</Form.Button>
</Form>
);
}
};
function DetailsForm(props) {
const member = props.user.member;
@@ -233,7 +234,7 @@ function DetailsForm(props) {
</Form.Button>
</Form>
);
}
};
function MemberInfo(props) {
const user = props.user;
@@ -311,7 +312,59 @@ function MemberInfo(props) {
</Table>
</div>
);
}
};
function Home(props) {
const token = props.token;
const setTokenCache = props.setTokenCache;
const user = props.user;
const setUserCache = props.setUserCache;
return (
<Container>
<Grid stackable padded columns={2}>
<Grid.Column>
{user ?
user.member.set_details ?
<MemberInfo user={user} />
:
<DetailsForm token={token} user={user} setUserCache={setUserCache} />
:
<div>
<LoginForm setTokenCache={setTokenCache} />
<Divider section horizontal>Or</Divider>
<SignupForm setTokenCache={setTokenCache} />
</div>
}
</Grid.Column>
<Grid.Column>
<Segment>
<Header size='medium'>Portal</Header>
<p>Welcome to the Protospace member portal! Here you can view member info, join classes, and manage your membership.</p>
<Header size='medium'>Quick Links</Header>
<p><a href='http://protospace.ca/' target='_blank' rel='noopener noreferrer'>Main Website</a></p>
<p><a href='http://wiki.protospace.ca/Welcome_to_Protospace' target='_blank' rel='noopener noreferrer'>Protospace Wiki</a></p>
<p><a href='https://groups.google.com/forum/#!forum/protospace-discuss' target='_blank' rel='noopener noreferrer'>Discussion Google Group</a></p>
<p><a href='https://drive.google.com/open?id=0By-vvp6fxFekfmU1cmdxaVRlaldiYXVyTE9rRnNVNjhkc3FjdkFIbjBwQkZ3MVVQX2Ezc3M' target='_blank' rel='noopener noreferrer'>Google Drive</a></p>
<Header size='medium'>Protospace Stats</Header>
<p>Next member meeting: Jan 01, 2099</p>
<p>Next monthly clean: Jan 01, 2099</p>
<p>Current member count: 200</p>
<p>Due members: 20</p>
<p>Expired members: 100</p>
<p>Bay 108 temperature: 21 C</p>
<p>Bay 110 temperature: 22 C</p>
</Segment>
</Grid.Column>
</Grid>
</Container>
);
};
function App() {
const [token, setToken] = useState(localStorage.getItem('token', ''));
@@ -344,10 +397,11 @@ function App() {
setUserCache(false);
}
const menuName = user && user.member && user.member.preferred_name || 'Me';
let menuName = user && user.member && user.member.preferred_name || 'Profile';
menuName = menuName.length > 7 ? 'Profile' : menuName;
return (
<div>
<Router>
<Container>
<div className='header'>
<img src={Logo} className='logo' />
@@ -355,72 +409,52 @@ function App() {
</Container>
<Menu>
<Container>
<Menu.Item
content='Home'
/>
<Menu.Item
content={menuName}
/>
<Menu.Item
content='Space'
/>
{user && <Menu.Menu position='right'>
<Container>
<Menu.Item
content='Logout'
onClick={logout}
icon='cancel'
content='Home'
as={Link}
to='/'
/>
<Menu.Item fitted content='' />
</Menu.Menu>}
</Container>
<Dropdown item text={menuName} id='ps-menu'>
<Dropdown.Menu>
<Dropdown.Item
content='Transactions'
/>
<Dropdown.Item
content='Cards'
/>
</Dropdown.Menu>
</Dropdown>
<Dropdown item text='Space' id='ps-menu'>
<Dropdown.Menu>
<Dropdown.Item
content='Members'
/>
<Dropdown.Item
content='Courses'
/>
</Dropdown.Menu>
</Dropdown>
{user && <Menu.Menu position='right'>
<Menu.Item
content='Logout'
onClick={logout}
icon='cancel'
/>
<Menu.Item fitted content='' />
</Menu.Menu>}
</Container>
</Menu>
<Container>
<Grid stackable padded columns={2}>
<Grid.Column>
{user ?
user.member.set_details ?
<MemberInfo user={user} />
:
<DetailsForm token={token} user={user} setUserCache={setUserCache} />
:
<div>
<LoginForm setTokenCache={setTokenCache} />
<Route exact path='/'>
<Home token={token} setTokenCache={setTokenCache} user={user} setUserCache={setUserCache} />
</Route>
<Divider section horizontal>Or</Divider>
<SignupForm setTokenCache={setTokenCache} />
</div>
}
</Grid.Column>
<Grid.Column>
<Segment>
<Header size='medium'>Portal</Header>
<p>Welcome to the Protospace member portal! Here you can view member info, join classes, and manage your membership.</p>
<Header size='medium'>Quick Links</Header>
<p><a href='http://protospace.ca/' target='_blank' rel='noopener noreferrer'>Main Website</a></p>
<p><a href='http://wiki.protospace.ca/Welcome_to_Protospace' target='_blank' rel='noopener noreferrer'>Protospace Wiki</a></p>
<p><a href='https://groups.google.com/forum/#!forum/protospace-discuss' target='_blank' rel='noopener noreferrer'>Discussion Google Group</a></p>
<p><a href='https://drive.google.com/open?id=0By-vvp6fxFekfmU1cmdxaVRlaldiYXVyTE9rRnNVNjhkc3FjdkFIbjBwQkZ3MVVQX2Ezc3M' target='_blank' rel='noopener noreferrer'>Google Drive</a></p>
<Header size='medium'>Protospace Stats</Header>
<p>Next member meeting: Jan 01, 2099</p>
<p>Next monthly clean: Jan 01, 2099</p>
<p>Current member count: 200</p>
<p>Due members: 20</p>
<p>Expired members: 100</p>
<p>Bay 108 temperature: 21 C</p>
<p>Bay 110 temperature: 22 C</p>
</Segment>
</Grid.Column>
</Grid>
</Container>
</div>
);
}
</Router>
)
};
export default App;

View File

@@ -1,3 +1,7 @@
html, body {
font-size: 16px;
}
.header {
padding-top: 1.5rem;
margin-bottom: 1.5rem;
@@ -9,3 +13,11 @@
display: block;
margin: auto;
}
#ps-menu .menu .item {
padding: 1.25rem 1rem !important;
}
#ps-menu .dropdown.icon {
display: none;
}