pleroma/app/soapbox/features/pinned_statuses/index.js

69 lines
2 KiB
JavaScript
Raw Normal View History

2020-03-27 13:59:38 -07:00
import PropTypes from 'prop-types';
import React from 'react';
2020-03-27 13:59:38 -07:00
import ImmutablePropTypes from 'react-immutable-proptypes';
import ImmutablePureComponent from 'react-immutable-pure-component';
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
import { connect } from 'react-redux';
2020-05-28 15:52:07 -07:00
import MissingIndicator from 'soapbox/components/missing_indicator';
2022-01-10 14:01:24 -08:00
import { fetchPinnedStatuses } from '../../actions/pin_statuses';
import StatusList from '../../components/status_list';
import Column from '../ui/components/column';
2020-03-27 13:59:38 -07:00
const messages = defineMessages({
heading: { id: 'column.pins', defaultMessage: 'Pinned posts' },
});
const mapStateToProps = (state, { params }) => {
const username = params.username || '';
2020-04-17 15:14:04 -07:00
const me = state.get('me');
const meUsername = state.getIn(['accounts', me, 'username'], '');
2020-03-27 13:59:38 -07:00
return {
isMyAccount: (username.toLowerCase() === meUsername.toLowerCase()),
statusIds: state.getIn(['status_lists', 'pins', 'items']),
hasMore: !!state.getIn(['status_lists', 'pins', 'next']),
};
2021-08-03 12:22:51 -07:00
};
2020-03-27 13:59:38 -07:00
export default @connect(mapStateToProps)
@injectIntl
class PinnedStatuses extends ImmutablePureComponent {
static propTypes = {
dispatch: PropTypes.func.isRequired,
statusIds: ImmutablePropTypes.orderedSet.isRequired,
2020-03-27 13:59:38 -07:00
intl: PropTypes.object.isRequired,
hasMore: PropTypes.bool.isRequired,
isMyAccount: PropTypes.bool.isRequired,
};
componentDidMount() {
2020-03-27 13:59:38 -07:00
this.props.dispatch(fetchPinnedStatuses());
}
render() {
const { intl, statusIds, hasMore, isMyAccount } = this.props;
2020-03-27 13:59:38 -07:00
if (!isMyAccount) {
return (
<Column>
<MissingIndicator />
</Column>
);
}
return (
<Column heading={intl.formatMessage(messages.heading)}>
2020-03-27 13:59:38 -07:00
<StatusList
statusIds={statusIds}
scrollKey='pinned_statuses'
hasMore={hasMore}
2020-04-14 11:44:40 -07:00
emptyMessage={<FormattedMessage id='pinned_statuses.none' defaultMessage='No pins to show.' />}
2020-03-27 13:59:38 -07:00
/>
</Column>
);
}
}