2017-06-07 00:22:10 +03:00
|
|
|
import React from 'react';
|
|
|
|
import styled from 'styled-components';
|
|
|
|
import remcalc from 'remcalc';
|
|
|
|
|
|
|
|
import { H2 } from '../text/headings';
|
2017-11-23 14:18:38 +02:00
|
|
|
import { Chevron } from '../icons';
|
2017-06-07 00:22:10 +03:00
|
|
|
|
|
|
|
const Name = H2.extend`
|
|
|
|
color: ${props => props.theme.primary};
|
2017-11-16 15:17:24 +02:00
|
|
|
margin: ${remcalc(12)} 0;
|
2017-06-07 00:22:10 +03:00
|
|
|
`;
|
|
|
|
|
2017-10-23 17:09:49 +03:00
|
|
|
const Arrow = styled(Chevron)`
|
2017-11-16 15:17:24 +02:00
|
|
|
margin: ${remcalc(8)} ${remcalc(10)} ${remcalc(3)} ${remcalc(10)};
|
2017-06-07 00:22:10 +03:00
|
|
|
`;
|
|
|
|
|
2017-09-20 12:30:53 +03:00
|
|
|
const Container = styled.div`
|
2017-10-23 17:09:49 +03:00
|
|
|
display: inline-flex;
|
|
|
|
align-items: center;
|
2017-09-20 12:30:53 +03:00
|
|
|
`;
|
|
|
|
|
2017-11-23 14:18:38 +02:00
|
|
|
const BaseLink = styled(({ component, children, ...rest }) =>
|
|
|
|
React.createElement(component, rest, children)
|
|
|
|
)`
|
|
|
|
text-decoration: none;
|
|
|
|
cursor: pointer;
|
|
|
|
|
|
|
|
&:visited {
|
|
|
|
color: inherit;
|
|
|
|
}
|
|
|
|
`;
|
|
|
|
|
|
|
|
export default ({ children, component, ...rest }) => {
|
|
|
|
const _child = component ? (
|
|
|
|
<BaseLink {...rest} component={component}>
|
|
|
|
{children}
|
|
|
|
</BaseLink>
|
|
|
|
) : (
|
|
|
|
children
|
|
|
|
);
|
2017-09-20 12:30:53 +03:00
|
|
|
|
|
|
|
return (
|
|
|
|
<Container>
|
2017-11-23 14:18:38 +02:00
|
|
|
<Name name="breadcrum-item">{_child}</Name>
|
2017-09-20 12:30:53 +03:00
|
|
|
<Arrow />
|
|
|
|
</Container>
|
|
|
|
);
|
|
|
|
};
|