1
0
mirror of https://github.com/yldio/copilot.git synced 2025-01-23 01:10:12 +02:00
copilot/ui/src/components/row/index.js

90 lines
1.9 KiB
JavaScript
Raw Normal View History

2016-10-24 23:58:09 +03:00
/*
* based on
2016-10-26 12:51:06 +03:00
* github.com/roylee0704/react-flexbox-grid/blob/master/src/components/Row.js
2016-10-24 23:58:09 +03:00
*/
2016-12-06 13:50:24 +02:00
const constants = require('../../shared/constants');
const match = require('../../shared/match');
const sizeMatch = require('./size-match');
const Styled = require('styled-components');
const {
breakpoints,
sizes
} = constants;
const {
default: styled
} = Styled;
const margin = sizes.gutterCompensation || '-0.5rem';
const direction = (size) => match(sizeMatch(size, {
reverse: 'row-reverse'
}), 'row');
const justify = (size) => match(sizeMatch(size, {
center: 'center',
end: 'flex-end',
around: 'space-around',
between: 'space-between'
}), 'flex-start');
const textAlign = (size) => match(sizeMatch(size, {
center: 'center',
end: 'end'
}), 'start');
const alignItems = (size) => match(sizeMatch(size, {
top: 'flex-start',
middle: 'center',
bottom: 'flex-end'
}), 'stretch');
const order = (size) => match(sizeMatch(size, {
first: -1,
last: 1
}), 0);
/**
* ```html
* <row center top={['xs', 'sm']} first='lg' />
* ```
**/
module.exports = styled.div`
box-sizing: border-box;
display: flex;
flex: 0 1 auto;
flex-wrap: wrap;
margin-left: ${margin};
margin-right: ${margin};
flex-direction: ${direction('xs')};
justify-content: ${justify('xs')};
text-align: ${textAlign('xs')};
align-items: ${alignItems('xs')};
${breakpoints.small`
flex-direction: ${direction('sm')};
justify-content: ${justify('sm')};
text-align: ${textAlign('sm')};
align-items: ${alignItems('sm')};
`}
${breakpoints.medium`
flex-direction: ${direction('md')};
justify-content: ${justify('md')};
text-align: ${textAlign('md')};
align-items: ${alignItems('md')};
`}
${breakpoints.large`
flex-direction: ${direction('lg')};
justify-content: ${justify('lg')};
text-align: ${textAlign('lg')};
align-items: ${alignItems('lg')};
`}
`;