import { css } from '@emotion/css'; import { isArray, isObject, isUndefined } from 'lodash'; import React from 'react'; import { GrafanaTheme2 } from '@grafana/data'; import { useStyles2, Icon } from '@grafana/ui'; import { Diff } from './utils'; type DiffProps = { diff: Diff; }; export const DiffValues: React.FC = ({ diff }) => { const styles = useStyles2(getStyles); const hasLeftValue = !isUndefined(diff.originalValue) && !isArray(diff.originalValue) && !isObject(diff.originalValue); const hasRightValue = !isUndefined(diff.value) && !isArray(diff.value) && !isObject(diff.value); return ( <> {hasLeftValue && {String(diff.originalValue)}} {hasLeftValue && hasRightValue ? : null} {hasRightValue && {String(diff.value)}} ); }; const getStyles = (theme: GrafanaTheme2) => css` background-color: ${theme.colors.action.hover}; border-radius: ${theme.shape.borderRadius()}; color: ${theme.colors.text.primary}; font-size: ${theme.typography.body.fontSize}; margin: 0 ${theme.spacing(0.5)}; padding: ${theme.spacing(0.5, 1)}; `;