source list UI done

This commit is contained in:
Aria Moradi 2020-12-25 06:36:34 +03:30
parent 7baca45d52
commit a01ef75822
4 changed files with 111 additions and 6 deletions

View File

@ -7,6 +7,7 @@ import {
import Button from '@material-ui/core/Button'; import Button from '@material-ui/core/Button';
import NavBar from './components/NavBar'; import NavBar from './components/NavBar';
import ExtensionCard from './components/ExtensionCard'; import ExtensionCard from './components/ExtensionCard';
import SourceCard from './components/SourceCard';
function Extensions() { function Extensions() {
let mapped; let mapped;
@ -24,6 +25,22 @@ function Extensions() {
return <h2>{mapped}</h2>; return <h2>{mapped}</h2>;
} }
function Sources() {
let mapped;
const [sources, setSources] = useState<ISource[]>([]);
if (sources.length === 0) {
mapped = <h3>wait</h3>;
fetch('http://127.0.0.1:4567/api/v1/sources')
.then((response) => response.json())
.then((data) => setSources(data));
} else {
mapped = sources.map((it) => <SourceCard source={it} />);
}
return <h2>{mapped}</h2>;
}
function Home() { function Home() {
return ( return (
<Button variant="contained" color="primary"> <Button variant="contained" color="primary">
@ -32,10 +49,6 @@ function Home() {
); );
} }
function Users() {
return <h2>Users</h2>;
}
export default function App() { export default function App() {
return ( return (
<Router> <Router>
@ -46,8 +59,8 @@ export default function App() {
<Route path="/extensions"> <Route path="/extensions">
<Extensions /> <Extensions />
</Route> </Route>
<Route path="/users"> <Route path="/sources">
<Users /> <Sources />
</Route> </Route>
<Route path="/"> <Route path="/">
<Home /> <Home />

View File

@ -0,0 +1,75 @@
import React from 'react';
import { makeStyles } from '@material-ui/core/styles';
import Card from '@material-ui/core/Card';
import CardContent from '@material-ui/core/CardContent';
import Button from '@material-ui/core/Button';
import Avatar from '@material-ui/core/Avatar';
import Typography from '@material-ui/core/Typography';
const useStyles = makeStyles((theme) => ({
root: {
display: 'flex',
justifyContent: 'space-between',
alignItems: 'center',
padding: 16,
},
bullet: {
display: 'inline-block',
margin: '0 2px',
transform: 'scale(0.8)',
},
title: {
fontSize: 14,
},
pos: {
marginBottom: 12,
},
icon: {
width: theme.spacing(7),
height: theme.spacing(7),
flex: '0 0 auto',
marginRight: 16,
},
}));
interface IProps {
source: ISource
}
export default function SourceCard(props: IProps) {
const {
source: {
name, lang, iconUrl, supportsLatest,
},
} = props;
const classes = useStyles();
const langPress = lang === 'all' ? 'All' : lang.toUpperCase();
return (
<Card>
<CardContent className={classes.root}>
<div style={{ display: 'flex' }}>
<Avatar
variant="rounded"
className={classes.icon}
alt={name}
src={iconUrl}
/>
<div style={{ display: 'flex', flexDirection: 'column' }}>
<Typography variant="h5" component="h2">
{name}
</Typography>
<Typography variant="caption" display="block" gutterBottom>
{langPress}
</Typography>
</div>
</div>
<div style={{ display: 'flex' }}>
{supportsLatest && <Button variant="outlined">Latest</Button>}
<Button variant="outlined" style={{ marginLeft: 20 }}>Browse</Button>
</div>
</CardContent>
</Card>
);
}

View File

@ -16,6 +16,7 @@ const useStyles = makeStyles({
interface IProps { interface IProps {
drawerOpen: boolean drawerOpen: boolean
setDrawerOpen(state: boolean): void setDrawerOpen(state: boolean): void
} }
@ -39,6 +40,14 @@ export default function TemporaryDrawer({ drawerOpen, setDrawerOpen }: IProps) {
<ListItemText primary="Extensions" /> <ListItemText primary="Extensions" />
</ListItem> </ListItem>
</Link> </Link>
<Link to="/sources" style={{ color: 'inherit', textDecoration: 'none' }}>
<ListItem button key="Sources">
<ListItemIcon>
<InboxIcon />
</ListItemIcon>
<ListItemText primary="Sources" />
</ListItem>
</Link>
</List> </List>
</div> </div>
); );

View File

@ -6,3 +6,11 @@ interface IExtension {
installed: boolean installed: boolean
apkName: string apkName: string
} }
interface ISource {
id: number
name: string
lang: string
iconUrl: string
supportsLatest: boolean
}