2017-01-09 20:58:30 +02:00
|
|
|
const fns = require('../../shared/functions');
|
2017-02-15 03:19:26 +02:00
|
|
|
const composers = require('../../shared/composers');
|
2017-02-02 21:05:45 +02:00
|
|
|
const constants = require('../../shared/constants');
|
2017-01-09 20:58:30 +02:00
|
|
|
const Item = require('./item');
|
|
|
|
const React = require('react');
|
|
|
|
const Styled = require('styled-components');
|
|
|
|
|
|
|
|
const {
|
|
|
|
remcalc
|
|
|
|
} = fns;
|
|
|
|
|
2017-02-02 21:05:45 +02:00
|
|
|
const {
|
|
|
|
colors
|
|
|
|
} = constants;
|
|
|
|
|
2017-02-15 03:19:26 +02:00
|
|
|
const {
|
|
|
|
Baseline
|
|
|
|
} = composers;
|
|
|
|
|
2017-01-09 20:58:30 +02:00
|
|
|
const {
|
|
|
|
default: styled
|
|
|
|
} = Styled;
|
|
|
|
|
|
|
|
const StyledItem = styled(Item)`
|
|
|
|
position: absolute;
|
|
|
|
|
2017-01-19 17:49:01 +02:00
|
|
|
background-color: #3B4AAF;
|
|
|
|
|
|
|
|
border: solid ${remcalc(1)} #2D3884;
|
2017-01-09 20:58:30 +02:00
|
|
|
box-shadow: none;
|
|
|
|
|
|
|
|
width: calc(100% + ${remcalc(2)});
|
|
|
|
margin: 0;
|
|
|
|
|
|
|
|
top: ${remcalc(-1)};
|
|
|
|
left: ${remcalc(-1)};
|
|
|
|
right: ${remcalc(-1)};
|
2017-02-15 03:19:26 +02:00
|
|
|
|
2017-02-02 21:05:45 +02:00
|
|
|
& [name="list-item-subtitle"],
|
|
|
|
& [name="list-item-title"] {
|
|
|
|
color: ${colors.base.white};
|
|
|
|
}
|
2017-01-09 20:58:30 +02:00
|
|
|
`;
|
|
|
|
|
|
|
|
const addFromHeader = (children) => React.Children.map(children, (c) => {
|
|
|
|
return React.cloneElement(c, {
|
|
|
|
...c.props,
|
|
|
|
fromHeader: true
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
const Header = (props) => (
|
|
|
|
<StyledItem
|
|
|
|
collapsed
|
|
|
|
headed
|
|
|
|
name='list-item-header'
|
|
|
|
>
|
|
|
|
{addFromHeader(props.children)}
|
|
|
|
</StyledItem>
|
|
|
|
);
|
|
|
|
|
|
|
|
Header.propTypes = {
|
|
|
|
children: React.PropTypes.node
|
|
|
|
};
|
|
|
|
|
2017-02-15 03:19:26 +02:00
|
|
|
module.exports = Baseline(
|
|
|
|
Header
|
|
|
|
);
|