mirror of
https://github.com/vale981/Vulcan
synced 2025-03-06 10:01:40 -05:00
69 lines
1.7 KiB
React
69 lines
1.7 KiB
React
![]() |
MoviesList = React.createClass({
|
|||
|
|
|||
|
renderNew() {
|
|||
|
|
|||
|
({ModalButton, NewDocContainer} = Telescope.components);
|
|||
|
|
|||
|
const component = (
|
|||
|
<ModalButton label="Add Movie" className="button button--primary">
|
|||
|
<NewDocContainer collection={Movies} label="Add Movie" methodName="movies.create"/>
|
|||
|
</ModalButton>
|
|||
|
)
|
|||
|
|
|||
|
return !!this.props.currentUser ? component : "";
|
|||
|
},
|
|||
|
|
|||
|
render() {
|
|||
|
({LoadMore} = Telescope.components);
|
|||
|
|
|||
|
return (
|
|||
|
<div className="movies">
|
|||
|
{this.renderNew()}
|
|||
|
{this.props.results.map(movie => <Movie key={movie._id} {...movie} currentUser={this.props.currentUser}/>)}
|
|||
|
{this.props.hasMore ? (this.props.ready ? <LoadMore {...this.props}/> : <p>Loading…</p>) : <p>No more movies</p>}
|
|||
|
</div>
|
|||
|
)
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
Movie = React.createClass({
|
|||
|
|
|||
|
|
|||
|
renderEdit() {
|
|||
|
|
|||
|
({ModalButton, ItemContainer, EditDocContainer} = Telescope.components);
|
|||
|
|
|||
|
const movie = this.props;
|
|||
|
|
|||
|
const component = (
|
|||
|
<ModalButton label="Edit" className="button button--secondary">
|
|||
|
<ItemContainer
|
|||
|
collection={Movies}
|
|||
|
terms={{_id: movie._id}}
|
|||
|
>
|
|||
|
<EditDocContainer label="Edit Movie" methodName="movies.edit"/>
|
|||
|
</ItemContainer>
|
|||
|
</ModalButton>
|
|||
|
);
|
|||
|
|
|||
|
return (
|
|||
|
<div className="post-actions">
|
|||
|
{this.props.currentUser._id === movie.userId ? component : ""}
|
|||
|
</div>
|
|||
|
)
|
|||
|
},
|
|||
|
|
|||
|
render() {
|
|||
|
|
|||
|
const movie = this.props;
|
|||
|
|
|||
|
return (
|
|||
|
<div key={movie.name} style={{marginBottom: "15px"}}>
|
|||
|
<h2>{movie.name} ({movie.year})</h2>
|
|||
|
<p>{movie.review} – by <strong>{movie.user.username}</strong></p>
|
|||
|
{this.renderEdit()}
|
|||
|
</div>
|
|||
|
)
|
|||
|
}
|
|||
|
|
|||
|
});
|