bigbuffet-rw/app/soapbox/features/notifications/containers/notification_container.js

75 lines
1.8 KiB
JavaScript
Raw Normal View History

2020-03-27 13:59:38 -07:00
import { connect } from 'react-redux';
import { mentionCompose } from 'soapbox/actions/compose';
2020-03-27 13:59:38 -07:00
import {
reblog,
favourite,
unreblog,
unfavourite,
} from 'soapbox/actions/interactions';
import { openModal } from 'soapbox/actions/modals';
import { getSettings } from 'soapbox/actions/settings';
2020-03-27 13:59:38 -07:00
import {
hideStatus,
revealStatus,
} from 'soapbox/actions/statuses';
import { makeGetNotification } from 'soapbox/selectors';
import Notification from '../components/notification';
2020-03-27 13:59:38 -07:00
const makeMapStateToProps = () => {
const getNotification = makeGetNotification();
const mapStateToProps = (state, props) => {
return {
2022-03-21 11:09:01 -07:00
siteTitle: state.getIn(['instance', 'title']),
notification: getNotification(state, props.notification),
2020-03-27 13:59:38 -07:00
};
};
return mapStateToProps;
};
const mapDispatchToProps = dispatch => ({
onMention: (account) => {
dispatch(mentionCompose(account));
2020-03-27 13:59:38 -07:00
},
onModalReblog(status) {
2020-03-27 13:59:38 -07:00
dispatch(reblog(status));
},
onReblog(status, e) {
2020-04-21 12:41:13 -07:00
dispatch((_, getState) => {
const boostModal = getSettings(getState()).get('boostModal');
2020-04-21 12:41:13 -07:00
if (status.get('reblogged')) {
dispatch(unreblog(status));
2020-03-27 13:59:38 -07:00
} else {
2020-04-21 12:41:13 -07:00
if (e.shiftKey || !boostModal) {
this.onModalReblog(status);
} else {
dispatch(openModal('BOOST', { status, onReblog: this.onModalReblog }));
}
2020-03-27 13:59:38 -07:00
}
2020-04-21 12:41:13 -07:00
});
2020-03-27 13:59:38 -07:00
},
onFavourite(status) {
2020-03-27 13:59:38 -07:00
if (status.get('favourited')) {
dispatch(unfavourite(status));
} else {
dispatch(favourite(status));
}
},
onToggleHidden(status) {
2020-03-27 13:59:38 -07:00
if (status.get('hidden')) {
dispatch(revealStatus(status.get('id')));
} else {
dispatch(hideStatus(status.get('id')));
}
},
});
export default connect(makeMapStateToProps, mapDispatchToProps)(Notification);