42 lines
1.2 KiB
JavaScript
42 lines
1.2 KiB
JavaScript
import { useEffect } from 'react';
|
|
|
|
import { createSelector } from '@reduxjs/toolkit';
|
|
import { useDispatch, useSelector } from 'react-redux';
|
|
|
|
import ListAltActiveIcon from '@/material-icons/400-24px/list_alt-fill.svg?react';
|
|
import ListAltIcon from '@/material-icons/400-24px/list_alt.svg?react';
|
|
import { fetchLists } from 'mastodon/actions/lists';
|
|
|
|
import ColumnLink from './column_link';
|
|
|
|
const getOrderedLists = createSelector([state => state.get('lists')], lists => {
|
|
if (!lists) {
|
|
return lists;
|
|
}
|
|
|
|
return lists.toList().filter(item => !!item).sort((a, b) => a.get('title').localeCompare(b.get('title'))).take(4);
|
|
});
|
|
|
|
export const ListPanel = () => {
|
|
const dispatch = useDispatch();
|
|
const lists = useSelector(state => getOrderedLists(state));
|
|
|
|
useEffect(() => {
|
|
dispatch(fetchLists());
|
|
}, [dispatch]);
|
|
|
|
if (!lists || lists.isEmpty()) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<div className='list-panel'>
|
|
<hr />
|
|
|
|
{lists.map(list => (
|
|
<ColumnLink icon='list-ul' key={list.get('id')} iconComponent={ListAltIcon} activeIconComponent={ListAltActiveIcon} text={list.get('title')} to={`/lists/${list.get('id')}`} transparent />
|
|
))}
|
|
</div>
|
|
);
|
|
};
|