1
0
Fork 0
forked from fedi/mastodon
mastodon/app/assets/javascripts/components/features/public_timeline/index.jsx

98 lines
2.7 KiB
React
Raw Normal View History

import { connect } from 'react-redux';
import PureRenderMixin from 'react-addons-pure-render-mixin';
import StatusListContainer from '../ui/containers/status_list_container';
import Column from '../ui/components/column';
2016-10-07 14:00:11 +00:00
import {
refreshTimeline,
updateTimeline,
deleteFromTimelines,
connectTimeline,
disconnectTimeline
} from '../../actions/timelines';
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
import ColumnBackButtonSlim from '../../components/column_back_button_slim';
import createStream from '../../stream';
2016-11-18 14:36:16 +00:00
const messages = defineMessages({
title: { id: 'column.public', defaultMessage: 'Federated timeline' }
2016-11-18 14:36:16 +00:00
});
2016-10-07 14:00:11 +00:00
const mapStateToProps = state => ({
2017-02-23 01:14:35 +00:00
hasUnread: state.getIn(['timelines', 'public', 'unread']) > 0,
streamingAPIBaseURL: state.getIn(['meta', 'streaming_api_base_url']),
accessToken: state.getIn(['meta', 'access_token'])
});
let subscription;
2016-10-07 14:00:11 +00:00
const PublicTimeline = React.createClass({
propTypes: {
dispatch: React.PropTypes.func.isRequired,
intl: React.PropTypes.object.isRequired,
streamingAPIBaseURL: React.PropTypes.string.isRequired,
2017-02-23 01:14:35 +00:00
accessToken: React.PropTypes.string.isRequired,
hasUnread: React.PropTypes.bool
},
2016-10-07 14:00:11 +00:00
mixins: [PureRenderMixin],
componentDidMount () {
const { dispatch, streamingAPIBaseURL, accessToken } = this.props;
2016-10-07 14:00:11 +00:00
dispatch(refreshTimeline('public'));
if (typeof subscription !== 'undefined') {
return;
}
subscription = createStream(streamingAPIBaseURL, accessToken, 'public', {
2016-10-07 14:00:11 +00:00
connected () {
dispatch(connectTimeline('public'));
},
reconnected () {
dispatch(connectTimeline('public'));
},
disconnected () {
dispatch(disconnectTimeline('public'));
},
received (data) {
switch(data.event) {
case 'update':
dispatch(updateTimeline('public', JSON.parse(data.payload)));
break;
case 'delete':
dispatch(deleteFromTimelines(data.payload));
break;
2016-10-07 14:00:11 +00:00
}
}
2016-10-07 14:00:11 +00:00
});
2016-10-07 14:00:11 +00:00
},
componentWillUnmount () {
// if (typeof subscription !== 'undefined') {
// subscription.close();
// subscription = null;
// }
2016-10-07 14:00:11 +00:00
},
render () {
2017-02-23 01:14:35 +00:00
const { intl, hasUnread } = this.props;
2016-10-07 14:00:11 +00:00
return (
2017-02-23 01:14:35 +00:00
<Column icon='globe' active={hasUnread} heading={intl.formatMessage(messages.title)}>
<ColumnBackButtonSlim />
<StatusListContainer type='public' emptyMessage={<FormattedMessage id='empty_column.public' defaultMessage='There is nothing here! Write something publicly, or manually follow users from other instances to fill it up' />} />
2016-10-07 14:00:11 +00:00
</Column>
);
},
});
export default connect(mapStateToProps)(injectIntl(PublicTimeline));