catstodon/app/javascript/mastodon/features/public_timeline/index.js

97 lines
2.7 KiB
JavaScript
Raw Normal View History

import React from 'react';
import { connect } from 'react-redux';
import PropTypes from 'prop-types';
import StatusListContainer from '../ui/containers/status_list_container';
import Column from '../ui/components/column';
2016-10-07 16:00:11 +02: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 15:36:16 +01:00
const messages = defineMessages({
title: { id: 'column.public', defaultMessage: 'Federated timeline' }
2016-11-18 15:36:16 +01:00
});
2016-10-07 16:00:11 +02:00
const mapStateToProps = state => ({
2017-02-23 02:14:35 +01:00
hasUnread: state.getIn(['timelines', 'public', 'unread']) > 0,
streamingAPIBaseURL: state.getIn(['meta', 'streaming_api_base_url']),
accessToken: state.getIn(['meta', 'access_token'])
});
let subscription;
class PublicTimeline extends React.PureComponent {
2016-10-07 16:00:11 +02:00
static propTypes = {
dispatch: PropTypes.func.isRequired,
intl: PropTypes.object.isRequired,
streamingAPIBaseURL: PropTypes.string.isRequired,
accessToken: PropTypes.string.isRequired,
hasUnread: PropTypes.bool
};
componentDidMount () {
const { dispatch, streamingAPIBaseURL, accessToken } = this.props;
2016-10-07 16:00:11 +02:00
dispatch(refreshTimeline('public'));
if (typeof subscription !== 'undefined') {
return;
}
subscription = createStream(streamingAPIBaseURL, accessToken, 'public', {
2016-10-07 16:00:11 +02: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 16:00:11 +02:00
}
}
2016-10-07 16:00:11 +02:00
});
}
2016-10-07 16:00:11 +02:00
componentWillUnmount () {
// if (typeof subscription !== 'undefined') {
// subscription.close();
// subscription = null;
// }
}
2016-10-07 16:00:11 +02:00
render () {
2017-02-23 02:14:35 +01:00
const { intl, hasUnread } = this.props;
2016-10-07 16:00:11 +02:00
return (
2017-02-23 02:14:35 +01:00
<Column icon='globe' active={hasUnread} heading={intl.formatMessage(messages.title)}>
<ColumnBackButtonSlim />
<StatusListContainer {...this.props} type='public' scrollKey='public_timeline' 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 16:00:11 +02:00
</Column>
);
}
2016-10-07 16:00:11 +02:00
}
export default connect(mapStateToProps)(injectIntl(PublicTimeline));