pleroma/app/soapbox/features/groups/components/discover/search/recent-searches.tsx

90 lines
3.2 KiB
TypeScript
Raw Normal View History

2023-02-28 07:26:27 -08:00
import React, { useState } from 'react';
import { FormattedMessage } from 'react-intl';
import { Virtuoso } from 'react-virtuoso';
import { HStack, Icon, Stack, Text } from 'soapbox/components/ui';
import { useOwnAccount } from 'soapbox/hooks';
import { groupSearchHistory } from 'soapbox/settings';
import { clearRecentGroupSearches } from 'soapbox/utils/groups';
interface Props {
onSelect(value: string): void
}
export default (props: Props) => {
const { onSelect } = props;
2023-06-25 10:35:09 -07:00
const { account: me } = useOwnAccount();
2023-02-28 07:26:27 -08:00
const [recentSearches, setRecentSearches] = useState<string[]>(groupSearchHistory.get(me?.id as string) || []);
const onClearRecentSearches = () => {
clearRecentGroupSearches(me?.id as string);
setRecentSearches([]);
};
return (
2023-02-28 12:03:03 -08:00
<Stack space={2} data-testid='recent-searches'>
2023-02-28 07:26:27 -08:00
{recentSearches.length > 0 ? (
<>
<HStack
alignItems='center'
justifyContent='between'
className='bg-white dark:bg-gray-900'
>
<Text theme='muted' weight='semibold' size='sm'>
2023-03-01 07:39:33 -08:00
<FormattedMessage
id='groups.discover.search.recent_searches.title'
defaultMessage='Recent searches'
/>
2023-02-28 07:26:27 -08:00
</Text>
2023-03-01 06:43:30 -08:00
<button onClick={onClearRecentSearches} data-testid='clear-recent-searches'>
2023-02-28 07:26:27 -08:00
<Text theme='primary' size='sm' className='hover:underline'>
2023-03-01 07:39:33 -08:00
<FormattedMessage
id='groups.discover.search.recent_searches.clear_all'
defaultMessage='Clear all'
/>
2023-02-28 07:26:27 -08:00
</Text>
</button>
</HStack>
<Virtuoso
useWindowScroll
data={recentSearches}
itemContent={(_index, recentSearch) => (
2023-03-01 06:43:30 -08:00
<div key={recentSearch} data-testid='recent-search'>
2023-02-28 07:26:27 -08:00
<button
onClick={() => onSelect(recentSearch)}
className='group flex w-full flex-col rounded-lg p-2 hover:bg-gray-100 dark:hover:bg-gray-800'
2023-03-01 06:43:30 -08:00
data-testid='recent-search-result'
2023-02-28 07:26:27 -08:00
>
<HStack alignItems='center' space={2}>
<div className='flex h-10 w-10 items-center justify-center rounded-full bg-gray-200 p-2 dark:bg-gray-800 dark:group-hover:bg-gray-700/20'>
<Icon
2023-04-03 13:19:19 -07:00
src={require('@tabler/icons/search.svg')}
2023-02-28 07:26:27 -08:00
className='h-5 w-5 text-gray-600'
/>
</div>
<Text weight='bold' size='sm' align='left'>{recentSearch}</Text>
</HStack>
</button>
</div>
)}
/>
</>
) : (
2023-03-01 06:43:30 -08:00
<Stack space={2} data-testid='recent-searches-blankslate'>
2023-02-28 12:03:03 -08:00
<Text weight='bold' size='lg'>
2023-03-01 07:39:33 -08:00
<FormattedMessage id='groups.discover.search.recent_searches.blankslate.title' defaultMessage='No recent searches' />
2023-02-28 07:26:27 -08:00
</Text>
<Text theme='muted'>
2023-03-01 07:39:33 -08:00
<FormattedMessage id='groups.discover.search.recent_searches.blankslate.subtitle' defaultMessage='Search group names, topics or keywords' />
2023-02-28 07:26:27 -08:00
</Text>
</Stack>
)}
</Stack>
);
};