2019-05-25 19:27:00 +00:00
|
|
|
import PropTypes from 'prop-types';
|
2023-05-23 15:15:17 +00:00
|
|
|
|
|
|
|
import { withRouter } from 'react-router-dom';
|
|
|
|
|
2019-05-25 19:27:00 +00:00
|
|
|
import ImmutablePropTypes from 'react-immutable-proptypes';
|
|
|
|
import ImmutablePureComponent from 'react-immutable-pure-component';
|
|
|
|
import { connect } from 'react-redux';
|
2023-05-23 15:15:17 +00:00
|
|
|
import { createSelector } from 'reselect';
|
|
|
|
|
2022-10-10 19:41:25 +00:00
|
|
|
import { fetchLists } from 'mastodon/actions/lists';
|
2023-05-23 15:15:17 +00:00
|
|
|
|
2022-10-10 19:41:25 +00:00
|
|
|
import ColumnLink from './column_link';
|
2019-05-25 19:27:00 +00:00
|
|
|
|
|
|
|
const getOrderedLists = createSelector([state => state.get('lists')], lists => {
|
|
|
|
if (!lists) {
|
|
|
|
return lists;
|
|
|
|
}
|
|
|
|
|
2019-05-26 00:55:37 +00:00
|
|
|
return lists.toList().filter(item => !!item).sort((a, b) => a.get('title').localeCompare(b.get('title'))).take(4);
|
2019-05-25 19:27:00 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
const mapStateToProps = state => ({
|
|
|
|
lists: getOrderedLists(state),
|
|
|
|
});
|
|
|
|
|
|
|
|
class ListPanel extends ImmutablePureComponent {
|
|
|
|
|
|
|
|
static propTypes = {
|
|
|
|
dispatch: PropTypes.func.isRequired,
|
|
|
|
lists: ImmutablePropTypes.list,
|
|
|
|
};
|
|
|
|
|
|
|
|
componentDidMount () {
|
|
|
|
const { dispatch } = this.props;
|
|
|
|
dispatch(fetchLists());
|
|
|
|
}
|
|
|
|
|
|
|
|
render () {
|
|
|
|
const { lists } = this.props;
|
|
|
|
|
2019-05-26 00:55:37 +00:00
|
|
|
if (!lists || lists.isEmpty()) {
|
2019-05-25 19:27:00 +00:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2022-10-10 19:41:25 +00:00
|
|
|
<div className='list-panel'>
|
2019-05-25 19:27:00 +00:00
|
|
|
<hr />
|
|
|
|
|
|
|
|
{lists.map(list => (
|
2022-10-10 19:41:25 +00:00
|
|
|
<ColumnLink icon='list-ul' key={list.get('id')} strict text={list.get('title')} to={`/lists/${list.get('id')}`} transparent />
|
2019-05-25 19:27:00 +00:00
|
|
|
))}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2023-03-24 02:17:53 +00:00
|
|
|
|
|
|
|
export default withRouter(connect(mapStateToProps)(ListPanel));
|