grafana/public/app/features/explore/Time.tsx
Josh Hunt 3c6e0e8ef8
Chore: ESlint import order (#44959)
* Add and configure eslint-plugin-import

* Fix the lint:ts npm command

* Autofix + prettier all the files

* Manually fix remaining files

* Move jquery code in jest-setup to external file to safely reorder imports

* Resolve issue caused by circular dependencies within Prometheus

* Update .betterer.results

* Fix missing // @ts-ignore

* ignore iconBundle.ts

* Fix missing // @ts-ignore
2022-04-22 14:33:13 +01:00

37 lines
842 B
TypeScript

import React, { FC } from 'react';
import { toDuration } from '@grafana/data';
export interface TimeProps {
timeInMs: number;
className?: string;
humanize?: boolean;
}
export const Time: FC<TimeProps> = ({ timeInMs, className, humanize }) => {
return <span className={`elapsed-time ${className}`}>{formatTime(timeInMs, humanize)}</span>;
};
const formatTime = (timeInMs: number, humanize = false): string => {
const inSeconds = timeInMs / 1000;
if (!humanize) {
return `${inSeconds.toFixed(1)}s`;
}
const duration = toDuration(inSeconds, 'seconds');
const hours = duration.hours();
const minutes = duration.minutes();
const seconds = duration.seconds();
if (hours) {
return `${hours}h ${minutes}m ${seconds}s`;
}
if (minutes) {
return `${minutes}m ${seconds}s`;
}
return `${seconds}s`;
};