pleroma/app/soapbox/features/ui/components/trends-panel.tsx

60 lines
1.6 KiB
TypeScript
Raw Normal View History

import React from 'react';
2022-10-13 09:00:44 -07:00
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
import { Link } from 'react-router-dom';
2022-03-21 11:09:01 -07:00
2022-10-13 09:00:44 -07:00
import { setFilter } from 'soapbox/actions/search';
import Hashtag from 'soapbox/components/hashtag';
2022-10-13 09:00:44 -07:00
import { Text, Widget } from 'soapbox/components/ui';
import PlaceholderSidebarTrends from 'soapbox/features/placeholder/components/placeholder-sidebar-trends';
import { useAppDispatch } from 'soapbox/hooks';
2022-08-10 06:35:07 -07:00
import useTrends from 'soapbox/queries/trends';
2022-03-21 11:09:01 -07:00
interface ITrendsPanel {
limit: number
}
2022-10-13 09:00:44 -07:00
const messages = defineMessages({
viewAll: {
id: 'trendsPanel.viewAll',
defaultMessage: 'View all',
},
});
2022-03-21 11:09:01 -07:00
const TrendsPanel = ({ limit }: ITrendsPanel) => {
2022-10-13 09:00:44 -07:00
const dispatch = useAppDispatch();
const intl = useIntl();
2022-08-10 06:35:07 -07:00
const { data: trends, isFetching } = useTrends();
2022-03-21 11:09:01 -07:00
2022-10-13 09:00:44 -07:00
const setHashtagsFilter = () => {
dispatch(setFilter('hashtags'));
};
if (!isFetching && !trends?.length) {
2022-03-21 11:09:01 -07:00
return null;
}
return (
2022-10-13 09:00:44 -07:00
<Widget
title={<FormattedMessage id='trends.title' defaultMessage='Trends' />}
action={
<Link className='text-right' to='/search' onClick={setHashtagsFilter}>
2022-10-13 09:00:44 -07:00
<Text tag='span' theme='primary' size='sm' className='hover:underline'>
{intl.formatMessage(messages.viewAll)}
</Text>
</Link>
}
>
{isFetching ? (
<PlaceholderSidebarTrends limit={limit} />
) : (
trends?.slice(0, limit).map((hashtag) => (
<Hashtag key={hashtag.name} hashtag={hashtag} />
))
)}
</Widget>
2022-03-21 11:09:01 -07:00
);
};
export default TrendsPanel;