RocketChat/Rocket.Chat

View on GitHub
apps/meteor/client/components/message/content/location/MapView.tsx

Summary

Maintainability
A
0 mins
Test Coverage
import { useSetting } from '@rocket.chat/ui-contexts';
import React, { memo } from 'react';

import MapViewFallback from './MapViewFallback';
import MapViewImage from './MapViewImage';
import { useAsyncImage } from './hooks/useAsyncImage';

type MapViewProps = {
    latitude: number;
    longitude: number;
};

const MapView = ({ latitude, longitude }: MapViewProps) => {
    const googleMapsApiKey = useSetting<string>('MapView_GMapsAPIKey');

    const linkUrl = `https://maps.google.com/maps?daddr=${latitude},${longitude}`;

    const imageUrl = useAsyncImage(
        googleMapsApiKey
            ? `https://maps.googleapis.com/maps/api/staticmap?zoom=14&size=250x250&markers=color:gray%7Clabel:%7C${latitude},${longitude}&key=${googleMapsApiKey}`
            : undefined,
    );

    if (!linkUrl) {
        return null;
    }

    if (!imageUrl) {
        return <MapViewFallback linkUrl={linkUrl} />;
    }

    return <MapViewImage linkUrl={linkUrl} imageUrl={imageUrl} />;
};

export default memo(MapView);