1
0
mirror of https://github.com/mastodon/mastodon synced 2025-01-19 00:02:58 +09:00
mastodon/app/assets/javascripts/components/containers/status_container.jsx

84 lines
1.8 KiB
React
Raw Normal View History

import { connect } from 'react-redux';
import Status from '../components/status';
import { makeGetStatus } from '../selectors';
import {
replyCompose,
mentionCompose
} from '../actions/compose';
import {
reblog,
favourite,
unreblog,
unfavourite
} from '../actions/interactions';
import {
blockAccount,
muteAccount
} from '../actions/accounts';
import { deleteStatus } from '../actions/statuses';
import { initReport } from '../actions/reports';
2017-04-02 05:11:28 +09:00
import { openModal } from '../actions/modal';
import { createSelector } from 'reselect'
import { isMobile } from '../is_mobile'
const makeMapStateToProps = () => {
const getStatus = makeGetStatus();
const mapStateToProps = (state, props) => ({
status: getStatus(state, props.id),
me: state.getIn(['meta', 'me'])
});
return mapStateToProps;
};
const mapDispatchToProps = (dispatch) => ({
onReply (status, router) {
dispatch(replyCompose(status, router));
},
onReblog (status) {
if (status.get('reblogged')) {
dispatch(unreblog(status));
} else {
dispatch(reblog(status));
}
},
onFavourite (status) {
if (status.get('favourited')) {
dispatch(unfavourite(status));
} else {
dispatch(favourite(status));
}
},
onDelete (status) {
dispatch(deleteStatus(status.get('id')));
},
onMention (account, router) {
dispatch(mentionCompose(account, router));
2016-10-25 01:07:40 +09:00
},
onOpenMedia (media, index) {
2017-04-02 05:11:28 +09:00
dispatch(openModal('MEDIA', { media, index }));
},
onBlock (account) {
dispatch(blockAccount(account.get('id')));
},
onReport (status) {
dispatch(initReport(status.get('account'), status));
},
onMute (account) {
dispatch(muteAccount(account.get('id')));
},
});
export default connect(makeMapStateToProps, mapDispatchToProps)(Status);