Files
2025-10-12 13:42:02 +02:00

83 lines
2.5 KiB
JavaScript

import PropTypes from "prop-types";
import { defineMessages, injectIntl, FormattedMessage } from "react-intl";
import ImmutablePropTypes from "react-immutable-proptypes";
import ImmutablePureComponent from "react-immutable-pure-component";
import { connect } from "react-redux";
import { debounce } from "lodash";
import { fetchBlocks, expandBlocks } from "../../actions/blocks";
import ColumnBackButtonSlim from "../../components/column_back_button_slim";
import { LoadingIndicator } from "../../components/loading_indicator";
import ScrollableList from "../../components/scrollable_list";
import AccountContainer from "../../containers/account_container";
import Column from "../ui/components/column";
const messages = defineMessages({
heading: { id: "column.blocks", defaultMessage: "Blocked users" },
});
const mapStateToProps = state => ({
accountIds: state.getIn(["user_lists", "blocks", "items"]),
hasMore: !!state.getIn(["user_lists", "blocks", "next"]),
isLoading: state.getIn(["user_lists", "blocks", "isLoading"], true),
});
class Blocks extends ImmutablePureComponent {
static propTypes = {
params: PropTypes.object.isRequired,
dispatch: PropTypes.func.isRequired,
accountIds: ImmutablePropTypes.list,
hasMore: PropTypes.bool,
isLoading: PropTypes.bool,
intl: PropTypes.object.isRequired,
multiColumn: PropTypes.bool,
};
UNSAFE_componentWillMount () {
this.props.dispatch(fetchBlocks());
}
handleLoadMore = debounce(() => {
this.props.dispatch(expandBlocks());
}, 300, { leading: true });
render () {
const { intl, accountIds, hasMore, multiColumn, isLoading } = this.props;
if (!accountIds) {
return (
<Column>
<LoadingIndicator />
</Column>
);
}
const emptyMessage = <FormattedMessage id='empty_column.blocks' defaultMessage="You haven't blocked any users yet." />;
return (
<Column bindToDocument={!multiColumn} icon='ban' heading={intl.formatMessage(messages.heading)}>
<ColumnBackButtonSlim />
<ScrollableList
scrollKey='blocks'
onLoadMore={this.handleLoadMore}
hasMore={hasMore}
isLoading={isLoading}
emptyMessage={emptyMessage}
bindToDocument={!multiColumn}
>
{accountIds.map(id =>
<AccountContainer key={id} id={id} defaultAction='block' />,
)}
</ScrollableList>
</Column>
);
}
}
export default connect(mapStateToProps)(injectIntl(Blocks));