import React, { useState, useCallback } from 'react'; import { Stack, Callout, Link, IconButton } from '@fluentui/react'; import LogDrawer from '../../modals/LogPanel'; import { EXPERIMENT } from '../../../static/datamodel'; import { formatTimestamp } from '../../../static/function'; import { useId } from '@uifabric/react-hooks'; import { BestMetricContext } from '../../Overview'; import { styles } from './basicInfoStyles'; import '../../../static/style/overview/probar.scss'; import '../../../static/style/overview/basic.scss'; export const BasicInfo = (): any => { const labelId: string = useId('callout-label'); const descriptionId: string = useId('callout-description'); const ref = React.createRef(); const [isCalloutVisible, setCalloutVisible] = useState(false); const [isShowLogDrawer, setShowLogDrawer] = useState(false); const onDismiss = useCallback(() => setCalloutVisible(false), []); const showCallout = useCallback(() => setCalloutVisible(true), []); const closeLogDrawer = useCallback(() => setShowLogDrawer(false), []); const ShowLogDrawer = useCallback(() => setShowLogDrawer(true), []); return (

Name

{EXPERIMENT.profile.params.experimentName || '--'}

ID

{EXPERIMENT.profile.id}

Status

{EXPERIMENT.status} {EXPERIMENT.status === 'ERROR' ? (
{isCalloutVisible && (

Error

{EXPERIMENT.error}

Learn about
)}
) : null}
{(value): React.ReactNode => (

Best metric

{isNaN(value.bestAccuracy) ? 'N/A' : value.bestAccuracy.toFixed(6)}
)}

Start time

{formatTimestamp(EXPERIMENT.profile.startTime)}

End time

{formatTimestamp(EXPERIMENT.profile.endTime)}
{/* learn about click -> default active key is dispatcher. */} {isShowLogDrawer ? : null}
); };