import React, { FC, useContext, MouseEvent } from "react"; import { ToastThemeContext, Themeable } from "./themes"; import styled from "styled-components"; type Props = { icon?: string; onClick?: () => void; }; const ThemedButton = styled.button.attrs(props => ({ className: "button" }))` color: ${props => props.theme.primary}; border-color: ${props => props.theme.primary}; background-color: ${props => props.theme.secondary}; font-size: 0.75rem; &:hover { color: ${props => props.theme.primary}; border-color: ${props => props.theme.tertiary}; background-color: ${props => props.theme.tertiary}; } `; const ToastButtonIcon = styled.i` margin-right: 0.25rem; `; const ToastButton: FC = ({ icon, onClick, children }) => { const theme = useContext(ToastThemeContext); const handleClick = (e: MouseEvent) => { if (onClick) { e.preventDefault(); onClick(); } }; return ( {icon && } {children} ); }; export default ToastButton;