lbry-desktop/ui/component/commentsList/view.jsx

56 lines
1.5 KiB
React
Raw Normal View History

2019-05-17 14:21:07 -04:00
// @flow
2019-06-26 19:59:27 -04:00
import React, { useEffect } from 'react';
import Comment from 'component/comment';
2019-05-17 14:21:07 -04:00
2019-06-26 19:59:27 -04:00
type Props = {
2019-06-12 10:53:27 -04:00
comments: Array<any>,
2019-06-26 19:59:27 -04:00
fetchComments: string => void,
2019-05-17 14:21:07 -04:00
uri: string,
claimIsMine: boolean,
myChannels: ?Array<ChannelClaim>,
2019-05-17 14:21:07 -04:00
};
2019-06-26 19:59:27 -04:00
function CommentList(props: Props) {
const { fetchComments, uri, comments, claimIsMine, myChannels } = props;
// todo: implement comment_list --mine in SDK so redux can grab with selectCommentIsMine
const isMyComment = (channelId: string) => {
if (myChannels != null && channelId != null) {
for (let i = 0; i < myChannels.length; i++) {
if (myChannels[i].claim_id === channelId) {
return true;
}
}
}
return false;
};
2019-06-26 19:59:27 -04:00
useEffect(() => {
fetchComments(uri);
}, [fetchComments, uri]);
return (
<ul className="comments">
{comments &&
comments.map(comment => {
return (
<Comment
authorUri={comment.channel_url}
2019-06-26 19:59:27 -04:00
author={comment.channel_name}
claimId={comment.claim_id}
2019-06-26 19:59:27 -04:00
commentId={comment.comment_id}
key={comment.channel_id + comment.comment_id}
message={comment.comment}
parentId={comment.parent_id || null}
timePosted={comment.timestamp * 1000}
claimIsMine={claimIsMine}
commentIsMine={comment.channel_id && isMyComment(comment.channel_id)}
2019-06-26 19:59:27 -04:00
/>
);
})}
</ul>
);
2019-05-17 14:21:07 -04:00
}
export default CommentList;