1
0
mirror of https://github.com/yldio/copilot.git synced 2025-01-23 09:20:12 +02:00
copilot/ui/src/shared/constants/breakpoints.js

60 lines
1.4 KiB
JavaScript
Raw Normal View History

const styled = require('styled-components');
const {
css
} = styled;
// github.com/kristoferjoseph/flexboxgrid/blob/master/dist/flexboxgrid.css
const small = {
upper: '48rem'
};
const medium = {
upper: '64rem',
2017-02-20 16:51:54 +02:00
lower: '48.1rem'
};
const large = {
upper: '75rem',
2017-02-20 16:51:54 +02:00
lower: '64.1rem'
};
const xlarge = {
2017-02-20 16:51:54 +02:00
lower: '75.1rem'
};
const screen = 'only screen';
const screens = {
// >= 768px
'smallOnly': `${screen} and (max-width: ${small.upper})`,
'small': `${screen} and (min-width: ${small.upper}})`,
// >= 1024px
'mediumOnly': `${screen} and (min-width: ${medium.lower})
and (max-width: ${medium.upper})`,
2017-02-03 15:27:14 +02:00
'mediumDown': `${screen} and (max-width: ${medium.upper})`,
'medium': `${screen} and (min-width: ${medium.lower})`,
// >= 1200px
'largeOnly': `${screen} and (min-width: ${large.lower})
and (max-width: ${large.upper})`,
2017-02-03 15:27:14 +02:00
'largeDown': `${screen} and (max-width: ${large.upper})`,
'large': `${screen} and (min-width: 75rem)`,
'xlarge': `${screen} and (min-width: ${xlarge.lower})
and (max-width: ${xlarge.upper})`,
2017-02-20 16:51:54 +02:00
'xlargeUp': `${screen} and (min-width: ${xlarge.lower})`
};
const breakpoints = Object.keys(screens).reduce((acc, label) => {
return {
...acc,
[label]: (...args) => css`
@media ${screens[label]} {
${css(...args)}
}
`
};
}, {});
module.exports = breakpoints;