@mcro/css
TypeScript icon, indicating that this package has built-in type declarations

2.3.10 • Public • Published

@mcro/css

Turns objects into nice CSS styles. Has a few helpers:

  • Arrays to strings:
{
  border: [1, 'solid', '#eee'], // 1px solid #eee
  border: [1, '#eee'], // defaults (solid)
  color: [0, 0, 0, 0.5], // rgba(0,0,0,0.5)
}
  • Transform objects:
{
  transform: { x: 0, y: 10, z: 0, rotate: '100deg' }
}
  • Color objects:
{
  background: [0, 255, 0, 0.5] // rgba(0, 255, 0, 0.5)
}
  • Converts css-able functions/objects:
{
  background: chroma('#fff') // will call .css() automatically
}
  • Recurses into media queries + & selectors
{
  '@media screen': { ... }
}
{
  '& child': { ... }
}
  • Extra border shorthands
{
  borderLeftRadius: ['borderTopLeftRadius', 'borderBottomLeftRadius'],
  borderRightRadius: ['borderTopRightRadius', 'borderBottomRightRadius'],
  borderBottomRadius: ['borderBottomLeftRadius', 'borderBottomRightRadius'],
  borderTopRadius: ['borderTopRightRadius', 'borderTopLeftRadius'],
}
  • Position shorthand
{
  position: [0, 'auto', 20, '50%'],
  /*
    position: absolute;
    top: 0px;
    right: auto;
    bottom: 20px;
    left: 50%;
  */
  position: ['fixed', 0, 'auto'],
  /*
    position: fixed;
    top: 0px;
    right: auto;
  */
}
  • Comma separations for multiple boxShadows and transitions:
{
  boxShadow: [
    { x: 5, y: 5, blur: 2, spread: 5, color: [0, 0, 0, 0.1] },
    [0, 0, 10, [0, 0, 0, 0.2]],
  ]
}
  • Object to value:
{
  background: {
    color: 'green',
    image: 'url(image.jpg)',
    position: [0, 0],
    repeat: 'no-repeat'
  }
}

Readme

Keywords

none

Package Sidebar

Install

npm i @mcro/css

Weekly Downloads

1

Version

2.3.10

License

MIT

Unpacked Size

176 kB

Total Files

44

Last publish

Collaborators

  • nwienert