ca0cd2ca75
- selectMyChannelClaims depends on `byId`, which currently is always invalidated per update, so it is not memoized. - Most of the use-cases just needs the ID or the length of the array anyways, so avoid generating a Claim array (in selectMyChannelClaims) unnecessarily -- the client need to reduce it back down to IDs again :/ - The simpler boolean also removes the need to memoize the selector, which saves a bit of memory. Co-authored-by: infinite-persistence <inf.persistence@gmail.com>
49 lines
2.1 KiB
JavaScript
49 lines
2.1 KiB
JavaScript
import { connect } from 'react-redux';
|
|
import {
|
|
selectTotalStakedAmountForChannelUri,
|
|
makeSelectClaimForUri,
|
|
selectThumbnailForUri,
|
|
selectHasChannels,
|
|
} from 'redux/selectors/claims';
|
|
import { doCommentUpdate, doCommentList } from 'redux/actions/comments';
|
|
import { makeSelectChannelIsMuted } from 'redux/selectors/blocked';
|
|
import { doToast } from 'redux/actions/notifications';
|
|
import { doSetPlayingUri } from 'redux/actions/content';
|
|
import {
|
|
selectLinkedCommentAncestors,
|
|
selectOthersReactsForComment,
|
|
makeSelectTotalReplyPagesForParentId,
|
|
} from 'redux/selectors/comments';
|
|
import { selectActiveChannelClaim } from 'redux/selectors/app';
|
|
import { selectPlayingUri } from 'redux/selectors/content';
|
|
import Comment from './view';
|
|
|
|
const select = (state, props) => {
|
|
const activeChannelClaim = selectActiveChannelClaim(state);
|
|
const activeChannelId = activeChannelClaim && activeChannelClaim.claim_id;
|
|
const reactionKey = activeChannelId ? `${props.commentId}:${activeChannelId}` : props.commentId;
|
|
|
|
return {
|
|
claim: makeSelectClaimForUri(props.uri)(state),
|
|
thumbnail: props.authorUri && selectThumbnailForUri(state, props.authorUri),
|
|
channelIsBlocked: props.authorUri && makeSelectChannelIsMuted(props.authorUri)(state),
|
|
commentingEnabled: true,
|
|
othersReacts: selectOthersReactsForComment(state, reactionKey),
|
|
activeChannelClaim,
|
|
hasChannels: selectHasChannels(state),
|
|
playingUri: selectPlayingUri(state),
|
|
stakedLevel: selectTotalStakedAmountForChannelUri(state, props.authorUri),
|
|
linkedCommentAncestors: selectLinkedCommentAncestors(state),
|
|
totalReplyPages: makeSelectTotalReplyPagesForParentId(props.commentId)(state),
|
|
};
|
|
};
|
|
|
|
const perform = (dispatch) => ({
|
|
clearPlayingUri: () => dispatch(doSetPlayingUri({ uri: null })),
|
|
updateComment: (commentId, comment) => dispatch(doCommentUpdate(commentId, comment)),
|
|
fetchReplies: (uri, parentId, page, pageSize, sortBy) =>
|
|
dispatch(doCommentList(uri, parentId, page, pageSize, sortBy)),
|
|
doToast: (options) => dispatch(doToast(options)),
|
|
});
|
|
|
|
export default connect(select, perform)(Comment);
|