mirror of
https://github.com/status-im/liquid-funding.git
synced 2025-01-12 04:24:23 +00:00
feat: design project cards
This commit is contained in:
parent
fd438bb922
commit
718d14edf0
@ -1,5 +1,5 @@
|
||||
import React, {Fragment, useState} from 'react'
|
||||
import { withStyles } from '@material-ui/core/styles'
|
||||
import {withStyles} from '@material-ui/core/styles'
|
||||
import {withDatabase} from "@nozbe/watermelondb/DatabaseProvider";
|
||||
import withObservables from "@nozbe/with-observables";
|
||||
import {Q} from "@nozbe/watermelondb";
|
||||
@ -7,12 +7,21 @@ import PropTypes from 'prop-types'
|
||||
import {useProjectData} from "./hooks";
|
||||
import Loading from "../base/Loading";
|
||||
import Grid from '@material-ui/core/Grid';
|
||||
import {Link} from "react-router-dom";
|
||||
import Radio from '@material-ui/core/Radio';
|
||||
import RadioGroup from '@material-ui/core/RadioGroup';
|
||||
import FormControlLabel from '@material-ui/core/FormControlLabel';
|
||||
import FormControl from '@material-ui/core/FormControl';
|
||||
import FormLabel from '@material-ui/core/FormLabel';
|
||||
import Typography from "@material-ui/core/Typography";
|
||||
import Card from '@material-ui/core/Card';
|
||||
import CardActions from '@material-ui/core/CardActions';
|
||||
import CardContent from '@material-ui/core/CardContent';
|
||||
import CardMedia from '@material-ui/core/CardMedia';
|
||||
import Button from '@material-ui/core/Button';
|
||||
import CardActionArea from '@material-ui/core/CardActionArea';
|
||||
import LinearProgress from '@material-ui/core/LinearProgress';
|
||||
|
||||
import defaultProjectImage from '../../images/default-project-img.png';
|
||||
|
||||
const SORT_TYPES = {
|
||||
date: 'date',
|
||||
@ -24,13 +33,31 @@ const styles = theme => ({
|
||||
margin: '1.75rem 4.5rem',
|
||||
...theme.typography.body1
|
||||
},
|
||||
link: {
|
||||
textDecoration: 'none',
|
||||
...theme.typography.body1,
|
||||
'&:hover': {
|
||||
textDecoration: 'underline',
|
||||
cursor: 'pointer'
|
||||
}
|
||||
title: {
|
||||
fontSize: '20px',
|
||||
textAlign: 'center',
|
||||
fontWeight: 500
|
||||
},
|
||||
media: {
|
||||
height: 235,
|
||||
position: 'relative'
|
||||
},
|
||||
avatar: {
|
||||
position: 'absolute',
|
||||
top: 26,
|
||||
left: 26
|
||||
},
|
||||
'card-title': {
|
||||
fontSize: '20px'
|
||||
},
|
||||
'card-content': {
|
||||
fontSize: '16px'
|
||||
},
|
||||
'card-actions': {
|
||||
float: 'right'
|
||||
},
|
||||
progress: {
|
||||
height: 10
|
||||
}
|
||||
})
|
||||
|
||||
@ -49,6 +76,38 @@ function sortByDate(a, b) {
|
||||
return 1;
|
||||
}
|
||||
|
||||
function ProjectCard({classes, project}) {
|
||||
return (<Card className={classes.card}>
|
||||
<CardActionArea href={`/#/project/${project.projectId}`}>
|
||||
<CardMedia
|
||||
className={classes.media}
|
||||
image={defaultProjectImage}
|
||||
title="Project image"
|
||||
/>
|
||||
<LinearProgress className={classes.progress} variant="determinate" value={75} /> {/*TODO get actual percentage*/}
|
||||
<CardContent>
|
||||
<Typography align="right" className={classes['card-content']}>75% of 2.055 ETH</Typography> {/*TODO get actual percentage*/}
|
||||
<Typography align="right" className={classes['card-content']}>3 funders</Typography> {/*TODO get actual funders*/}
|
||||
<Typography gutterBottom variant="h5" component="h2" className={classes['card-title']} noWrap>
|
||||
{project.manifest.title}
|
||||
</Typography>
|
||||
<Typography component="p" className={classes['card-content']} noWrap>
|
||||
{project.manifest.description}
|
||||
</Typography>
|
||||
<Typography component="p" className={classes['card-content']} color="textSecondary">
|
||||
Delegate: {project.manifest.creator} {/*TODO check if that really is the delegate*/}
|
||||
</Typography>
|
||||
{project.manifest.avatar && <img className={classes.avatar} alt="avatar" src={project.manifest.avatar} width={40} height={40}/>}
|
||||
</CardContent>
|
||||
</CardActionArea>
|
||||
<CardActions className={classes['card-actions']}>
|
||||
<Button size="small" color="primary" href={`/#/project/${project.projectId}`}>
|
||||
Read more
|
||||
</Button>
|
||||
</CardActions>
|
||||
</Card>)
|
||||
}
|
||||
|
||||
function Projects({projectAddedEvents, classes}) {
|
||||
const [sortType, setSortType] = useState(SORT_TYPES.date);
|
||||
|
||||
@ -59,8 +118,9 @@ function Projects({projectAddedEvents, classes}) {
|
||||
let sortFunction = (sortType === SORT_TYPES.name) ? sortByTitle : sortByDate;
|
||||
projects.sort(sortFunction);
|
||||
|
||||
console.log(projects);
|
||||
return (<div className={classes.root}>
|
||||
<h2>Projects</h2>
|
||||
<Typography className={classes.title} component="h2" gutterBottom>All projects</Typography>
|
||||
{projects.length === 0 && <Loading/>}
|
||||
{projects.length > 0 &&
|
||||
<Fragment>
|
||||
@ -73,8 +133,8 @@ function Projects({projectAddedEvents, classes}) {
|
||||
value={sortType}
|
||||
onChange={(e, value) => setSortType(value)}
|
||||
>
|
||||
<FormControlLabel value={SORT_TYPES.date} control={<Radio />} label="Date" />
|
||||
<FormControlLabel value={SORT_TYPES.name} control={<Radio />} label="Name" />
|
||||
<FormControlLabel value={SORT_TYPES.date} control={<Radio color="default"/>} label="Date"/>
|
||||
<FormControlLabel value={SORT_TYPES.name} control={<Radio color="default"/>} label="Name"/>
|
||||
</RadioGroup>
|
||||
</FormControl>
|
||||
<Grid container spacing={40}>
|
||||
@ -82,17 +142,9 @@ function Projects({projectAddedEvents, classes}) {
|
||||
if (!project.manifest) {
|
||||
return ''
|
||||
}
|
||||
return (
|
||||
<Grid key={'project-' + index} item xs={12} sm={6} md={4} className="project-list-item">
|
||||
<Link to={`/project/${project.projectId}`} className={classes.link}>
|
||||
<h3>{project.manifest.title}</h3>
|
||||
<p>{project.manifest.subtitle}</p>
|
||||
<p>{project.manifest.description}</p>
|
||||
<p>{project.manifest.avatar &&
|
||||
<img alt="avatar" src={project.manifest.avatar} width={20} height={20}/>}{project.manifest.creator}</p>
|
||||
</Link>
|
||||
</Grid>
|
||||
)
|
||||
return (<Grid key={'project-' + index} item xs={12} sm={6} md={4} lg={3} className="project-list-item">
|
||||
<ProjectCard project={project} classes={classes}/>
|
||||
</Grid>);
|
||||
})}
|
||||
</Grid>
|
||||
</Fragment>
|
||||
@ -106,7 +158,7 @@ Projects.propTypes = {
|
||||
}
|
||||
|
||||
const StyledProject = withStyles(styles)(Projects)
|
||||
export default withDatabase(withObservables([], ({ database }) => ({
|
||||
export default withDatabase(withObservables([], ({database}) => ({
|
||||
projectAddedEvents: database.collections.get('lp_events').query(
|
||||
Q.where('event', 'ProjectAdded')
|
||||
).observe()
|
||||
|
BIN
src/images/default-project-img.png
Normal file
BIN
src/images/default-project-img.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 128 KiB |
@ -9,7 +9,7 @@ import './css/fonts/Inter/inter.css'
|
||||
|
||||
const theme = createMuiTheme({
|
||||
typography: {
|
||||
// Use the system font instead of the default Roboto font.
|
||||
useNextVariants: true,
|
||||
fontFamily: ['Inter', '-apple-system', 'BlinkMacSystemFont', "Segoe UI", 'Roboto', "Helvetica Neue", 'Arial', "Noto Sans", 'sans-serif', "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"].join(','),
|
||||
},
|
||||
});
|
||||
|
Loading…
x
Reference in New Issue
Block a user