styled-components
Version:
**This is a work in progress** based off of [this demo](https://github.com/geelen/css-components-demo).
70 lines (51 loc) • 2.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _hash = require('glamor/lib/hash');
var _hash2 = _interopRequireDefault(_hash);
var _camelizeStyleName = require('fbjs/lib/camelizeStyleName');
var _camelizeStyleName2 = _interopRequireDefault(_camelizeStyleName);
var _flatten = require('../utils/flatten');
var _flatten2 = _interopRequireDefault(_flatten);
var _parse = require('../vendor/postcss-safe-parser/parse');
var _parse2 = _interopRequireDefault(_parse);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var generated = {};
/*
InlineStyle takes arbitrary CSS and generates a flat object
*/
var InlineStyle = function () {
function InlineStyle(rules) {
_classCallCheck(this, InlineStyle);
this.rules = rules;
}
_createClass(InlineStyle, [{
key: 'generateStyleObject',
value: function generateStyleObject(executionContext) {
var flatCSS = (0, _flatten2.default)(this.rules, executionContext).join('');
var hash = (0, _hash2.default)(flatCSS);
if (!generated[hash]) {
(function () {
var root = (0, _parse2.default)(flatCSS);
var styleObject = {};
root.each(function (node) {
if (node.type === 'decl') {
styleObject[(0, _camelizeStyleName2.default)(node.prop)] = node.value;
} else {
/* eslint-disable no-console */
console.warn('Node of type ' + node.type + ' not supported as an inline style');
}
});
generated[hash] = styleObject;
})();
}
return generated[hash];
}
}]);
return InlineStyle;
}();
exports.default = InlineStyle;
module.exports = exports['default'];