Files
mattermost-mobile/app/screens/reaction_list/index.js
Saturnino Abril ce47c23100 [MM-9490] Add reaction list (#2125)
* add reaction list

* update styles and add tests

* update styles

* update per comment
2018-09-27 21:54:17 +08:00

43 lines
1.5 KiB
JavaScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import {bindActionCreators} from 'redux';
import {connect} from 'react-redux';
import {getMissingProfilesByIds} from 'mattermost-redux/actions/users';
import {makeGetReactionsForPost} from 'mattermost-redux/selectors/entities/posts';
import {getCurrentUserId, makeGetProfilesByIdsAndUsernames} from 'mattermost-redux/selectors/entities/users';
import {getTeammateNameDisplaySetting, getTheme} from 'mattermost-redux/selectors/entities/preferences';
import {getUniqueUserIds} from 'app/utils/reaction';
import ReactionList from './reaction_list';
function makeMapStateToProps() {
const getReactionsForPostSelector = makeGetReactionsForPost();
const getProfilesByIdsAndUsernames = makeGetProfilesByIdsAndUsernames();
return function mapStateToProps(state, ownProps) {
const reactions = getReactionsForPostSelector(state, ownProps.postId);
const allUserIds = getUniqueUserIds(reactions);
return {
currentUserId: getCurrentUserId(state),
reactions,
teammateNameDisplay: getTeammateNameDisplaySetting(state),
theme: getTheme(state),
userProfiles: getProfilesByIdsAndUsernames(state, {allUserIds}) || [],
};
};
}
function mapDispatchToProps(dispatch) {
return {
actions: bindActionCreators({
getMissingProfilesByIds,
}, dispatch),
};
}
export default connect(makeMapStateToProps, mapDispatchToProps)(ReactionList);