revite/src/components/ui/Tip.tsx

72 lines
1.6 KiB
TypeScript
Raw Normal View History

2021-07-01 17:36:34 +01:00
import { InfoCircle } from "@styled-icons/boxicons-regular";
2021-07-05 11:23:23 +01:00
import styled, { css } from "styled-components";
import { Children } from "../../types/Preact";
2021-07-01 17:36:34 +01:00
interface Props {
2021-07-05 11:25:20 +01:00
warning?: boolean;
error?: boolean;
2021-07-01 17:36:34 +01:00
}
2021-06-18 14:20:57 +01:00
export const Separator = styled.div<Props>`
2021-07-05 11:25:20 +01:00
height: 1px;
width: calc(100% - 10px);
background: var(--secondary-header);
margin: 18px auto;
`;
2021-07-01 17:36:34 +01:00
export const TipBase = styled.div<Props>`
2021-07-05 11:25:20 +01:00
display: flex;
padding: 12px;
overflow: hidden;
align-items: center;
2021-06-18 14:20:57 +01:00
2021-07-05 11:25:20 +01:00
font-size: 14px;
background: var(--primary-header);
2021-07-10 15:42:13 +01:00
border-radius: var(--border-radius);
2021-07-05 11:25:20 +01:00
border: 2px solid var(--secondary-header);
2021-06-18 14:20:57 +01:00
2021-07-05 11:25:20 +01:00
a {
cursor: pointer;
&:hover {
text-decoration: underline;
}
}
2021-06-18 15:57:08 +01:00
2021-07-05 11:25:20 +01:00
svg {
flex-shrink: 0;
margin-inline-end: 10px;
}
2021-07-01 17:36:34 +01:00
2021-07-05 11:25:20 +01:00
${(props) =>
props.warning &&
css`
color: var(--warning);
border: 2px solid var(--warning);
background: var(--secondary-header);
`}
2021-07-01 17:36:34 +01:00
2021-07-05 11:25:20 +01:00
${(props) =>
props.error &&
css`
color: var(--error);
border: 2px solid var(--error);
background: var(--secondary-header);
`}
2021-06-18 14:20:57 +01:00
`;
2021-07-24 19:39:41 +01:00
export default function Tip(
props: Props & { children: Children; hideSeparator?: boolean },
) {
const { children, hideSeparator, ...tipProps } = props;
2021-07-05 11:25:20 +01:00
return (
<>
2021-07-24 19:39:41 +01:00
{!hideSeparator && <Separator />}
2021-07-05 11:25:20 +01:00
<TipBase {...tipProps}>
<InfoCircle size={20} />
2021-08-05 14:47:00 +01:00
<span>{children}</span>
2021-07-05 11:25:20 +01:00
</TipBase>
</>
);
2021-06-18 14:20:57 +01:00
}