add sketch list, with links

This commit is contained in:
catarak 2016-07-05 16:04:14 -04:00
parent b2369704a2
commit 6563d9d90b
9 changed files with 49 additions and 6 deletions

View file

@ -1,6 +1,8 @@
import React, { PropTypes } from 'react'; import React, { PropTypes } from 'react';
import { connect } from 'react-redux'; import { connect } from 'react-redux';
import { bindActionCreators } from 'redux'; import { bindActionCreators } from 'redux';
import moment from 'moment';
import { Link } from 'react-router';
import Nav from '../../../components/Nav'; import Nav from '../../../components/Nav';
import * as SketchActions from '../actions'; import * as SketchActions from '../actions';
import * as ProjectActions from '../../IDE/actions/project'; import * as ProjectActions from '../../IDE/actions/project';
@ -18,11 +20,22 @@ class SketchListView extends React.Component {
createProject={this.props.createProject} createProject={this.props.createProject}
saveProject={this.props.saveProject} saveProject={this.props.saveProject}
/> />
<ul className="sketch-list__items"> <table className="sketches-table">
{this.props.sketches.map(sketch => <thead>
<li>{sketch.name}</li> <th>Name</th>
)} <th>Created</th>
</ul> <th>Last Updated</th>
</thead>
<tbody>
{this.props.sketches.map(sketch =>
<tr className="sketches-table__row">
<td><Link to={`/projects/${sketch._id}`}>{sketch.name}</Link></td>
<td>{moment(sketch.createdAt).format('MMM D, YYYY')}</td>
<td>{moment(sketch.updatedAt).format('MMM D, YYYY')}</td>
</tr>
)}
</tbody>
</table>
</div> </div>
); );
} }

View file

@ -45,4 +45,8 @@ h2 {
h3 { h3 {
font-weight: normal; font-weight: normal;
}
thead {
text-align: left;
} }

View file

@ -14,4 +14,8 @@ ul, p {
h2, h3 { h2, h3 {
margin: 0; margin: 0;
}
ul {
list-style: none;
} }

View file

@ -0,0 +1,9 @@
.sketches-table {
width: 100%;
padding: #{10 / $base-font-size}rem 0;
padding-left: #{170 / $base-font-size}rem;
}
.sketches-table__row {
margin: #{10 / $base-font-size}rem;
}

View file

@ -0,0 +1,6 @@
.sketch-list {
display: flex;
flex-wrap: wrap;
height: 100%;
flex-flow: column;
}

View file

@ -13,5 +13,7 @@
@import 'components/preferences'; @import 'components/preferences';
@import 'components/signup'; @import 'components/signup';
@import 'components/login'; @import 'components/login';
@import 'components/sketch-list';
@import 'layout/ide'; @import 'layout/ide';
@import 'layout/sketch-list';

View file

@ -68,6 +68,7 @@
"eslint-loader": "^1.3.0", "eslint-loader": "^1.3.0",
"express": "^4.13.4", "express": "^4.13.4",
"express-session": "^1.13.0", "express-session": "^1.13.0",
"moment": "^2.14.1",
"mongoose": "^4.4.16", "mongoose": "^4.4.16",
"passport": "^0.3.2", "passport": "^0.3.2",
"passport-github": "^1.1.0", "passport-github": "^1.1.0",

View file

@ -59,7 +59,7 @@ export function getProjects(req, res) {
if (req.user) { if (req.user) {
Project.find({user: req.user._id}) // eslint-disable-line no-underscore-dangle Project.find({user: req.user._id}) // eslint-disable-line no-underscore-dangle
.sort('-createdAt') .sort('-createdAt')
.select('name file _id') .select('name file _id createdAt updatedAt')
.exec((err, projects) => { .exec((err, projects) => {
res.json(projects); res.json(projects);
}); });

View file

@ -21,4 +21,8 @@ router.route('/login').get((req, res) => {
res.sendFile(path.resolve(`${__dirname}/../../index.html`)); res.sendFile(path.resolve(`${__dirname}/../../index.html`));
}); });
router.route('/sketches').get((req, res) => {
res.sendFile(path.resolve(`${__dirname}/../../index.html`));
});
export default router; export default router;