Skip to main content
Version: Next

Timer

A live elapsed-time display that counts up from a given start time. Used to show query and dashboard load durations. Requires a startTime timestamp to function.

Live Example

Loading component...

Try It

Edit the code below to experiment with the component:

Live Editor
function Demo() {
  const [isRunning, setIsRunning] = React.useState(true);
  const [startTime] = React.useState(Date.now());
  return (
    <div style={{ display: 'flex', alignItems: 'center', gap: 16 }}>
      <Timer
        startTime={startTime}
        isRunning={isRunning}
        status="success"
      />
      <Button onClick={() => setIsRunning(r => !r)}>
        {isRunning ? 'Stop' : 'Start'}
      </Button>
    </div>
  );
}
Result
Loading...

Status Variants

Live Editor
function StatusVariants() {
  const [startTime] = React.useState(Date.now());
  return (
    <div style={{ display: 'flex', flexDirection: 'column', gap: 12 }}>
      {['success', 'warning', 'danger', 'info', 'default', 'primary', 'secondary'].map(status => (
        <div key={status} style={{ display: 'flex', alignItems: 'center', gap: 12 }}>
          <span style={{ width: 80 }}>{status}</span>
          <Timer startTime={startTime} isRunning status={status} />
        </div>
      ))}
    </div>
  );
}
Result
Loading...

Completed Timer

Live Editor
function CompletedTimer() {
  const start = Date.now() - 5230;
  const end = Date.now();
  return (
    <div style={{ display: 'flex', alignItems: 'center', gap: 12 }}>
      <Timer
        startTime={start}
        endTime={end}
        isRunning={false}
        status="success"
      />
      <span style={{ color: '#999' }}>Query completed in ~5.2 seconds</span>
    </div>
  );
}
Result
Loading...

Start and Stop

Live Editor
function StartStop() {
  const [isRunning, setIsRunning] = React.useState(false);
  const [startTime, setStartTime] = React.useState(null);
  const handleToggle = () => {
    if (!isRunning && !startTime) {
      setStartTime(Date.now());
    }
    setIsRunning(r => !r);
  };
  return (
    <div style={{ display: 'flex', alignItems: 'center', gap: 16 }}>
      <Timer
        startTime={startTime}
        isRunning={isRunning}
        status={isRunning ? 'warning' : 'success'}
      />
      <Button onClick={handleToggle}>
        {isRunning ? 'Pause' : startTime ? 'Resume' : 'Start'}
      </Button>
    </div>
  );
}
Result
Loading...

Props

PropTypeDefaultDescription
isRunningbooleantrueWhether the timer is actively counting. Toggle to start/stop.
statusstring"success"Visual status of the timer badge.
startTimenumber1737936000000-

Import

import { Timer } from '@superset/components';

Improve this page

This documentation is auto-generated from the component's Storybook story. Help improve it by editing the story file.