42 lines
1.2 KiB
TypeScript
42 lines
1.2 KiB
TypeScript
|
import React from 'react';
|
||
|
|
||
|
import { useAppSelector } from 'soapbox/hooks';
|
||
|
|
||
|
import { HStack, Icon, Stack, Text } from './ui';
|
||
|
|
||
|
const buildingCommunityIcon = require('@tabler/icons/building-community.svg');
|
||
|
const homeIcon = require('@tabler/icons/home-2.svg');
|
||
|
const mapPinIcon = require('@tabler/icons/map-pin.svg');
|
||
|
const roadIcon = require('@tabler/icons/road.svg');
|
||
|
|
||
|
export const ADDRESS_ICONS: Record<string, string> = {
|
||
|
house: homeIcon,
|
||
|
street: roadIcon,
|
||
|
secondary: roadIcon,
|
||
|
zone: buildingCommunityIcon,
|
||
|
city: buildingCommunityIcon,
|
||
|
administrative: buildingCommunityIcon,
|
||
|
};
|
||
|
|
||
|
interface IAutosuggestLocation {
|
||
|
id: string,
|
||
|
}
|
||
|
|
||
|
const AutosuggestLocation: React.FC<IAutosuggestLocation> = ({ id }) => {
|
||
|
const location = useAppSelector((state) => state.locations.get(id));
|
||
|
|
||
|
if (!location) return null;
|
||
|
|
||
|
return (
|
||
|
<HStack alignItems='center' space={2}>
|
||
|
<Icon src={ADDRESS_ICONS[location.type] || mapPinIcon} />
|
||
|
<Stack>
|
||
|
<Text>{location.description}</Text>
|
||
|
<Text size='xs' theme='muted'>{[location.street, location.locality, location.country].filter(val => val.trim()).join(' · ')}</Text>
|
||
|
</Stack>
|
||
|
</HStack>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default AutosuggestLocation;
|