1
0
mirror of https://github.com/yldio/copilot.git synced 2025-01-10 02:50:11 +02:00
copilot/ui/src/components/list/header.js

69 lines
1.2 KiB
JavaScript
Raw Normal View History

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;
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
);