2024-03-11 13:35:23 +00:00
|
|
|
import { useEffect } from 'react';
|
2023-05-23 15:15:17 +00:00
|
|
|
|
2024-01-08 10:57:40 +00:00
|
|
|
import { createSelector } from '@reduxjs/toolkit';
|
2024-03-11 13:35:23 +00:00
|
|
|
import { useDispatch, useSelector } from 'react-redux';
|
2023-05-23 15:15:17 +00:00
|
|
|
|
2024-03-11 13:35:23 +00:00
|
|
|
import ListAltActiveIcon from '@/material-icons/400-24px/list_alt-fill.svg?react';
|
2024-01-16 10:27:26 +00:00
|
|
|
import ListAltIcon from '@/material-icons/400-24px/list_alt.svg?react';
|
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
|
|
|
});
|
|
|
|
|
2024-03-11 13:35:23 +00:00
|
|
|
export const ListPanel = () => {
|
|
|
|
const dispatch = useDispatch();
|
|
|
|
const lists = useSelector(state => getOrderedLists(state));
|
2019-05-25 19:27:00 +00:00
|
|
|
|
2024-03-11 13:35:23 +00:00
|
|
|
useEffect(() => {
|
2019-05-25 19:27:00 +00:00
|
|
|
dispatch(fetchLists());
|
2024-03-11 13:35:23 +00:00
|
|
|
}, [dispatch]);
|
2019-05-25 19:27:00 +00:00
|
|
|
|
2024-03-11 13:35:23 +00:00
|
|
|
if (!lists || lists.isEmpty()) {
|
|
|
|
return null;
|
2019-05-25 19:27:00 +00:00
|
|
|
}
|
|
|
|
|
2024-03-11 13:35:23 +00:00
|
|
|
return (
|
|
|
|
<div className='list-panel'>
|
|
|
|
<hr />
|
2023-03-24 02:17:53 +00:00
|
|
|
|
2024-03-11 13:35:23 +00:00
|
|
|
{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>
|
|
|
|
);
|
|
|
|
};
|