2020-01-17 02:50:57 -07:00
|
|
|
import React from "react";
|
2020-01-26 02:24:12 -07:00
|
|
|
import { AccordionIcon, Icon, Spinner, Stack, Text, Tooltip, useColorMode } from "@chakra-ui/core";
|
2020-04-16 23:43:02 -07:00
|
|
|
import format from "string-format";
|
|
|
|
import useConfig from "~/components/HyperglassProvider";
|
2020-01-17 02:50:57 -07:00
|
|
|
|
2020-04-16 23:43:02 -07:00
|
|
|
format.extend(String.prototype, {});
|
|
|
|
|
|
|
|
const runtimeText = (runtime, text) => {
|
|
|
|
let unit;
|
2020-04-18 07:58:46 -07:00
|
|
|
if (runtime === 1) {
|
2020-04-16 23:43:02 -07:00
|
|
|
unit = "seconds";
|
|
|
|
} else {
|
|
|
|
unit = "second";
|
|
|
|
}
|
|
|
|
const fmt = text.format({ seconds: runtime });
|
|
|
|
return `${fmt} ${unit}`;
|
|
|
|
};
|
|
|
|
|
|
|
|
const statusColor = { dark: "primary.300", light: "primary.500" };
|
|
|
|
const warningColor = { dark: 300, light: 500 };
|
|
|
|
const defaultStatusColor = {
|
|
|
|
dark: "success.300",
|
|
|
|
light: "success.500",
|
|
|
|
};
|
|
|
|
|
|
|
|
export default React.forwardRef(({ title, loading, error, errorMsg, errorLevel, runtime }, ref) => {
|
2020-01-17 02:50:57 -07:00
|
|
|
const { colorMode } = useColorMode();
|
2020-04-16 23:43:02 -07:00
|
|
|
const config = useConfig();
|
2020-01-17 02:50:57 -07:00
|
|
|
return (
|
2020-01-20 00:37:04 -07:00
|
|
|
<Stack ref={ref} isInline alignItems="center" w="100%">
|
2020-01-17 02:50:57 -07:00
|
|
|
{loading ? (
|
|
|
|
<Spinner size="sm" mr={4} color={statusColor[colorMode]} />
|
|
|
|
) : error ? (
|
2020-01-26 02:24:12 -07:00
|
|
|
<Tooltip hasArrow label={errorMsg} placement="top">
|
2020-01-17 02:50:57 -07:00
|
|
|
<Icon
|
|
|
|
name="warning"
|
2020-01-26 02:24:12 -07:00
|
|
|
color={`${errorLevel}.${warningColor[colorMode]}`}
|
2020-01-17 02:50:57 -07:00
|
|
|
mr={4}
|
|
|
|
size={6}
|
|
|
|
/>
|
|
|
|
</Tooltip>
|
|
|
|
) : (
|
2020-04-16 23:43:02 -07:00
|
|
|
<Tooltip
|
|
|
|
hasArrow
|
|
|
|
label={runtimeText(runtime, config.web.text.complete_time)}
|
|
|
|
placement="top"
|
|
|
|
>
|
|
|
|
<Icon name="check" color={defaultStatusColor[colorMode]} mr={4} size={6} />
|
|
|
|
</Tooltip>
|
2020-01-17 02:50:57 -07:00
|
|
|
)}
|
|
|
|
<Text fontSize="lg">{title}</Text>
|
2020-01-20 00:37:04 -07:00
|
|
|
<AccordionIcon ml="auto" />
|
2020-01-17 02:50:57 -07:00
|
|
|
</Stack>
|
|
|
|
);
|
|
|
|
});
|