UNPKG

material-ui-cordova

Version:

React components that implement Google's Material Design.

65 lines (52 loc) 1.91 kB
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } // Sorted ASC by size. That's important. // It can't be configured as it's used statically for propTypes. export const keys = ['xs', 'sm', 'md', 'lg', 'xl']; // Keep in mind that @media is inclusive by the CSS specification. export default function createBreakpoints(breakpoints) { const { // The breakpoint **start** at this value. // For instance with the first breakpoint xs: [xs, sm[. values = { xs: 0, sm: 600, md: 960, lg: 1280, xl: 1920 }, unit = 'px', step = 5 } = breakpoints, other = _objectWithoutProperties(breakpoints, ['values', 'unit', 'step']); function up(key) { const value = typeof values[key] === 'number' ? values[key] : key; return `@media (min-width:${value}${unit})`; } function down(key) { const value = typeof values[key] === 'number' ? values[key] : key; return `@media (max-width:${value - step / 100}${unit})`; } function between(start, end) { const endIndex = keys.indexOf(end) + 1; if (endIndex === keys.length) { return up(start); } return `@media (min-width:${values[start]}${unit}) and ` + `(max-width:${values[keys[endIndex]] - step / 100}${unit})`; } function only(key) { return between(key, key); } function width(key) { return values[key]; } return _extends({ keys, values, up, down, between, only, width }, other); }