You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
46 lines
1.1 KiB
46 lines
1.1 KiB
6 years ago
|
import React from 'react'
|
||
|
import PropTypes from 'prop-types'
|
||
6 years ago
|
import { Box, Flex, Text } from 'rebass'
|
||
|
import Success from 'components/Icon/Success'
|
||
|
import Warning from 'components/Icon/Warning'
|
||
|
import Error from 'components/Icon/Error'
|
||
6 years ago
|
|
||
|
import styled from 'styled-components'
|
||
|
import { variant } from 'styled-system'
|
||
|
|
||
|
const messageStyle = variant({ key: 'messages' })
|
||
6 years ago
|
const StyledMessage = styled(Flex)(messageStyle)
|
||
6 years ago
|
|
||
|
/**
|
||
|
* @render react
|
||
6 years ago
|
* @name Message
|
||
6 years ago
|
* @example
|
||
6 years ago
|
* <Message message="Error message" />
|
||
6 years ago
|
*/
|
||
6 years ago
|
class Message extends React.Component {
|
||
|
static displayName = 'Message'
|
||
6 years ago
|
|
||
|
static propTypes = {
|
||
|
variant: PropTypes.string,
|
||
|
children: PropTypes.node
|
||
|
}
|
||
|
|
||
|
render() {
|
||
6 years ago
|
const { children, variant, ...rest } = this.props
|
||
6 years ago
|
return (
|
||
6 years ago
|
<StyledMessage {...rest} variant={variant} alignItems="center">
|
||
6 years ago
|
<Box mr={1}>
|
||
6 years ago
|
{variant === 'success' && <Success />}
|
||
|
{variant === 'warning' && <Warning />}
|
||
|
{variant === 'error' && <Error />}
|
||
6 years ago
|
</Box>
|
||
6 years ago
|
<Text fontSize="s" fontWeight="normal">
|
||
|
{children}
|
||
|
</Text>
|
||
6 years ago
|
</StyledMessage>
|
||
6 years ago
|
)
|
||
|
}
|
||
|
}
|
||
|
|
||
6 years ago
|
export default Message
|