2020-10-02 15:18:53 -04:00
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import {
|
|
|
|
makeSelectMyReactionForUri,
|
|
|
|
makeSelectLikeCountForUri,
|
|
|
|
makeSelectDislikeCountForUri,
|
|
|
|
} from 'redux/selectors/reactions';
|
|
|
|
import { doFetchReactions, doReactionLike, doReactionDislike } from 'redux/actions/reactions';
|
|
|
|
import FileViewCount from './view';
|
2022-02-01 17:07:08 -03:00
|
|
|
import { selectClaimForUri, selectIsStreamPlaceholderForUri } from 'redux/selectors/claims';
|
2020-10-02 15:18:53 -04:00
|
|
|
|
2022-02-01 17:07:08 -03:00
|
|
|
const select = (state, props) => {
|
|
|
|
const { uri } = props;
|
2020-10-02 15:18:53 -04:00
|
|
|
|
2022-02-01 17:07:08 -03:00
|
|
|
const claim = selectClaimForUri(state, uri);
|
|
|
|
const { claim_id: claimId, signing_channel, value_type } = claim || {};
|
|
|
|
|
|
|
|
const channelName = signing_channel && signing_channel.name;
|
|
|
|
const isCollection = value_type && value_type === 'collection'; // hack because nudge gets cut off by card on cols.
|
|
|
|
|
|
|
|
return {
|
|
|
|
myReaction: makeSelectMyReactionForUri(uri)(state),
|
|
|
|
likeCount: makeSelectLikeCountForUri(uri)(state),
|
|
|
|
dislikeCount: makeSelectDislikeCountForUri(uri)(state),
|
|
|
|
isLivestreamClaim: selectIsStreamPlaceholderForUri(state, uri),
|
|
|
|
claimId,
|
|
|
|
channelName,
|
|
|
|
isCollection,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const perform = {
|
2020-10-02 15:18:53 -04:00
|
|
|
doFetchReactions,
|
|
|
|
doReactionLike,
|
|
|
|
doReactionDislike,
|
2022-02-01 17:07:08 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
export default connect(select, perform)(FileViewCount);
|