Package Exports
- glam
- glam/babel
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (glam) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
glam
npm install glam
- super fast + small (<2k gz)
- extract
.cssfiles - readable classnames (eg.
name: myButton;) - future facing css - nested selectors, autoprefixing, etc
- parallel load / append
- Make Alex Happy (tm)
input -
// index.js
import css from 'glam'
let myColor = '#ab67ee'
let radius = '20px'
let myclass = css`
color: red;
&:hover {
font-weight: bold;
color: ${myColor};
border-radius: ${radius};
}
`
output -
// index.js
import('./index.js.css')
// defaults to async load
// sync load with explicit require('./index.js.css')
import css from 'glam'
let myColor = '#ab67ee'
let radius = '20px'
let myClass = css('css-1bh6s', [myColor, radius]) // "css-1bh6s vars-h23psd"/* index.js.css */
.css-1bh6s {
color: red
}
.css-1bh6s:hover {
font-weight: bold;
color: var(--css-1bh6s-0);
border-radius: var(--css-1bh6s-1);
}
/* dynamically added */
.vars-h23psd {
--css-1bh6s-0: #ab67ee;
--css-1bh6s-1: 20px;
}
caveats
- only property values can be interpolated
- interpolated values can't be 'processed'
- doesn't solve the '7 big problems'... yet
usage
- add
glam/babelto your babel plugins - add
glam/loaderto webpack's css loaders - ???
- profit
plugin options
sync-true/false- loads css synchronously, preventing foucinline-true/false- fallback for browsers that don't support css props.
zero cost react variant
you could define your own variant, bringing down runtime cost further
(react@16.alpha-11 and above)
function css(cls, vars = []){
return {
className: cls,
style: vars.reduce((o, v, i) =>
(o[`--${cls}-${i}`] = v, o), {})
}
}
// ...
<div {...css` font-weight:bold; color: ${props.color}; `}>
hello!
</div>
todo
- web components, shadow dom et al
- keyframes, fonts, imports
- emit css files with webpack?
- ssr
- custom postcss pipeline
- source maps?
- typed om?
- SC api?
- unload styles?
- work with extract-text-plugin
- hot loading support