Vulcan/packages/nova-base-components/lib/posts/PostsList.jsx

45 lines
1.3 KiB
React
Raw Normal View History

2016-04-14 10:12:35 +09:00
import React from 'react';
const PostsList = ({results, currentUser, hasMore, ready, count, totalCount, loadMore, showHeader = true}) => {
// console.log(results);
// console.log(ready);
2016-04-14 16:22:57 +09:00
// console.log(hasMore);
// console.log(totalCount);
// console.log(count);
2016-04-14 10:12:35 +09:00
({PostsItem, PostsLoadMore, PostsLoading, PostsNoResults, PostsNoMore, PostsListHeader} = Telescope.components);
if (!!results.length) {
return (
<div className="posts-list">
2016-04-14 10:12:35 +09:00
{showHeader ? <PostsListHeader /> : null}
<div className="posts-list-content">
2016-04-14 10:12:35 +09:00
{results.map(post => <PostsItem post={post} currentUser={currentUser} key={post._id}/>)}
</div>
{hasMore ? (ready ? <PostsLoadMore loadMore={loadMore} count={count} totalCount={totalCount} /> : <PostsLoading/>) : <PostsNoMore/>}
</div>
)
} else if (!ready) {
return (
<div className="posts-list">
2016-04-14 10:12:35 +09:00
{showHeader ? <PostsListHeader /> : null}
<div className="posts-list-content">
2016-04-14 10:12:35 +09:00
<PostsLoading/>
</div>
</div>
)
} else {
return (
<div className="posts-list">
2016-04-14 10:12:35 +09:00
{showHeader ? <PostsListHeader /> : null}
<div className="posts-list-content">
2016-04-14 10:12:35 +09:00
<PostsNoResults/>
</div>
</div>
)
}
};
module.exports = PostsList;