1
0
mirror of https://github.com/checktheroads/hyperglass synced 2024-05-11 05:55:08 +00:00

33 lines
1.2 KiB
JavaScript
Raw Normal View History

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-01-17 02:50:57 -07:00
2020-01-26 02:24:12 -07:00
export default React.forwardRef(({ title, loading, error, errorMsg, errorLevel }, ref) => {
2020-01-17 02:50:57 -07:00
const { colorMode } = useColorMode();
2020-01-20 00:37:04 -07:00
const statusColor = { dark: "primary.300", light: "primary.500" };
2020-01-17 02:50:57 -07:00
const warningColor = { dark: 300, light: 500 };
const defaultStatusColor = {
2020-01-20 00:37:04 -07:00
dark: "success.300",
light: "success.500"
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>
) : (
<Icon name="check" color={defaultStatusColor[colorMode]} mr={4} size={6} />
)}
<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>
);
});