import { css } from '@emotion/css'; import React, { CSSProperties } from 'react'; import { GrafanaTheme2 } from '@grafana/data'; import { useStyles2 } from '@grafana/ui'; export interface OverlayProps { topRight1?: React.ReactNode[]; topRight2?: React.ReactNode[]; bottomLeft?: React.ReactNode[]; blStyle?: CSSProperties; } export const GeomapOverlay = ({ topRight1, topRight2, bottomLeft, blStyle }: OverlayProps) => { const topRight1Exists = (topRight1 && topRight1.length > 0) ?? false; const styles = useStyles2(getStyles(topRight1Exists)); return (
{Boolean(topRight1?.length) &&
{topRight1}
} {Boolean(topRight2?.length) &&
{topRight2}
} {Boolean(bottomLeft?.length) && (
{bottomLeft}
)}
); }; const getStyles = (topRight1Exists: boolean) => (theme: GrafanaTheme2) => ({ overlay: css` position: absolute; width: 100%; height: 100%; z-index: 500; pointer-events: none; `, TR1: css` right: 0.5em; pointer-events: auto; position: absolute; top: 0.5em; `, TR2: css` position: absolute; top: ${topRight1Exists ? '80' : '8'}px; right: 8px; pointer-events: auto; `, BL: css` position: absolute; bottom: 8px; left: 8px; pointer-events: auto; `, });