Skip to content

Instantly share code, notes, and snippets.

@birkir
Created November 16, 2017 18:49
Show Gist options
  • Save birkir/d78ac6067c85c27e56a8fc4d60604f0f to your computer and use it in GitHub Desktop.
Save birkir/d78ac6067c85c27e56a8fc4d60604f0f to your computer and use it in GitHub Desktop.
requirebin sketch
const css2rn = require('css-to-react-native');
const input = document.getElementById('code');
const result = document.getElementById('result');
const strrf = str => str.trim().replace(/^"/, "'").replace(/",?$/, "'");
const btn = document.querySelector('#go');
btn.addEventListener('click', () => {
const rules = input.value.replace(/\/\*(.|\n)*?\*\//, '').split(';').map(item => item.split(':').map(x => String(x).trim())).filter(x => x && x[0] !== '');
const output = JSON.stringify(css2rn.default(rules), null, 2);
const ok = output.replace(/ \"(.*)\":(.*)\n/g, (n, a, b) => { return ` ${a}: ${strrf(b)},\n`; }).replace(/,,/g, ',');
result.value = ok.substr(1, ok.length - 2).trim().replace(/\n\s+/g, '\n');
});
setTimeout(function(){
;require=(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
// shim for using process in browser
var process = module.exports = {};
// cached from whatever global is present so that test runners that stub it
// don't break things. But we need to wrap it in a try catch in case it is
// wrapped in strict mode code which doesn't define any globals. It's inside a
// function because try/catches deoptimize in certain engines.
var cachedSetTimeout;
var cachedClearTimeout;
function defaultSetTimout() {
throw new Error('setTimeout has not been defined');
}
function defaultClearTimeout () {
throw new Error('clearTimeout has not been defined');
}
(function () {
try {
if (typeof setTimeout === 'function') {
cachedSetTimeout = setTimeout;
} else {
cachedSetTimeout = defaultSetTimout;
}
} catch (e) {
cachedSetTimeout = defaultSetTimout;
}
try {
if (typeof clearTimeout === 'function') {
cachedClearTimeout = clearTimeout;
} else {
cachedClearTimeout = defaultClearTimeout;
}
} catch (e) {
cachedClearTimeout = defaultClearTimeout;
}
} ())
function runTimeout(fun) {
if (cachedSetTimeout === setTimeout) {
//normal enviroments in sane situations
return setTimeout(fun, 0);
}
// if setTimeout wasn't available but was latter defined
if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {
cachedSetTimeout = setTimeout;
return setTimeout(fun, 0);
}
try {
// when when somebody has screwed with setTimeout but no I.E. maddness
return cachedSetTimeout(fun, 0);
} catch(e){
try {
// When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally
return cachedSetTimeout.call(null, fun, 0);
} catch(e){
// same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error
return cachedSetTimeout.call(this, fun, 0);
}
}
}
function runClearTimeout(marker) {
if (cachedClearTimeout === clearTimeout) {
//normal enviroments in sane situations
return clearTimeout(marker);
}
// if clearTimeout wasn't available but was latter defined
if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {
cachedClearTimeout = clearTimeout;
return clearTimeout(marker);
}
try {
// when when somebody has screwed with setTimeout but no I.E. maddness
return cachedClearTimeout(marker);
} catch (e){
try {
// When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally
return cachedClearTimeout.call(null, marker);
} catch (e){
// same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.
// Some versions of I.E. have different rules for clearTimeout vs setTimeout
return cachedClearTimeout.call(this, marker);
}
}
}
var queue = [];
var draining = false;
var currentQueue;
var queueIndex = -1;
function cleanUpNextTick() {
if (!draining || !currentQueue) {
return;
}
draining = false;
if (currentQueue.length) {
queue = currentQueue.concat(queue);
} else {
queueIndex = -1;
}
if (queue.length) {
drainQueue();
}
}
function drainQueue() {
if (draining) {
return;
}
var timeout = runTimeout(cleanUpNextTick);
draining = true;
var len = queue.length;
while(len) {
currentQueue = queue;
queue = [];
while (++queueIndex < len) {
if (currentQueue) {
currentQueue[queueIndex].run();
}
}
queueIndex = -1;
len = queue.length;
}
currentQueue = null;
draining = false;
runClearTimeout(timeout);
}
process.nextTick = function (fun) {
var args = new Array(arguments.length - 1);
if (arguments.length > 1) {
for (var i = 1; i < arguments.length; i++) {
args[i - 1] = arguments[i];
}
}
queue.push(new Item(fun, args));
if (queue.length === 1 && !draining) {
runTimeout(drainQueue);
}
};
// v8 likes predictible objects
function Item(fun, array) {
this.fun = fun;
this.array = array;
}
Item.prototype.run = function () {
this.fun.apply(null, this.array);
};
process.title = 'browser';
process.browser = true;
process.env = {};
process.argv = [];
process.version = ''; // empty string to avoid regexp issues
process.versions = {};
function noop() {}
process.on = noop;
process.addListener = noop;
process.once = noop;
process.off = noop;
process.removeListener = noop;
process.removeAllListeners = noop;
process.emit = noop;
process.binding = function (name) {
throw new Error('process.binding is not supported');
};
process.cwd = function () { return '/' };
process.chdir = function (dir) {
throw new Error('process.chdir is not supported');
};
process.umask = function() { return 0; };
},{}],2:[function(require,module,exports){
'use strict';
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; }; }();
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
var SYMBOL_MATCH = 'SYMBOL_MATCH';
module.exports = function () {
function TokenStream(nodes, parent) {
_classCallCheck(this, TokenStream);
this.nodes = nodes;
this.parent = parent;
this.lastFunction = null;
this.lastValue = null;
}
_createClass(TokenStream, [{
key: 'hasTokens',
value: function hasTokens() {
return this.nodes.length > 0;
}
}, {
key: 'lookahead',
value: function lookahead() {
return new TokenStream(this.nodes.slice(1), this.parent);
}
}, {
key: SYMBOL_MATCH,
value: function value() {
var node = this.node;
if (!node) return null;
for (var i = 0; i < arguments.length; i += 1) {
var tokenDescriptor = arguments.length <= i ? undefined : arguments[i];
var value = tokenDescriptor(node);
if (value !== null) {
this.nodes = this.nodes.slice(1);
this.lastFunction = null;
this.lastValue = value;
return value;
}
}
return null;
}
}, {
key: 'matches',
value: function matches() {
return this[SYMBOL_MATCH].apply(this, arguments) !== null;
}
}, {
key: 'expect',
value: function expect() {
var value = this[SYMBOL_MATCH].apply(this, arguments);
if (value !== null) return value;
return this.throw();
}
}, {
key: 'matchFunction',
value: function matchFunction() {
var node = this.node;
if (node.type !== 'function') return null;
var value = new TokenStream(node.nodes, node);
this.nodes = this.nodes.slice(1);
this.lastFunction = value;
this.lastValue = null;
return value;
}
}, {
key: 'expectFunction',
value: function expectFunction() {
var value = this.matchFunction();
if (value !== null) return value;
return this.throw();
}
}, {
key: 'expectEmpty',
value: function expectEmpty() {
if (this.hasTokens()) this.throw();
}
}, {
key: 'throw',
value: function _throw() {
throw new Error('Unexpected token type: ' + this.node.type);
}
}, {
key: 'node',
get: function get() {
return this.nodes[0];
}
}]);
return TokenStream;
}();
},{}],3:[function(require,module,exports){
'use strict';
var _require = require('postcss-value-parser'),
stringify = _require.stringify;
var cssColorKeywords = require('css-color-keywords');
var matchString = function matchString(node) {
if (node.type !== 'string') return null;
return node.value.replace(/\\([0-9a-f]{1,6})(?:\s|$)/gi, function (match, charCode) {
return String.fromCharCode(parseInt(charCode, 16));
}).replace(/\\/g, '');
};
var hexColorRe = /^(#(?:[0-9a-f]{3,4}){1,2})$/i;
var cssFunctionNameRe = /^(rgba?|hsla?|hwb|lab|lch|gray|color)$/;
var matchColor = function matchColor(node) {
if (node.type === 'word' && (hexColorRe.test(node.value) || node.value in cssColorKeywords)) {
return node.value;
} else if (node.type === 'function' && cssFunctionNameRe.test(node.value)) {
return stringify(node);
}
return null;
};
var noneRe = /^(none)$/i;
var autoRe = /^(auto)$/i;
var identRe = /(^-?[_a-z][_a-z0-9-]*$)/i;
// Note if these are wrong, you'll need to change index.js too
var numberRe = /^([+-]?(?:\d*\.)?\d+(?:[Ee][+-]?\d+)?)$/;
// Note lengthRe is sneaky: you can omit units for 0
var lengthRe = /^(0$|(?:[+-]?(?:\d*\.)?\d+(?:[Ee][+-]?\d+)?)(?=px$))/;
var angleRe = /^([+-]?(?:\d*\.)?\d+(?:[Ee][+-]?\d+)?(?:deg|rad))$/;
var percentRe = /^([+-]?(?:\d*\.)?\d+(?:[Ee][+-]?\d+)?%)$/;
var noopToken = function noopToken(predicate) {
return function (node) {
return predicate(node) ? '<token>' : null;
};
};
var valueForTypeToken = function valueForTypeToken(type) {
return function (node) {
return node.type === type ? node.value : null;
};
};
var regExpToken = function regExpToken(regExp) {
var transform = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : String;
return function (node) {
if (node.type !== 'word') return null;
var match = node.value.match(regExp);
if (match === null) return null;
var value = transform(match[1]);
return value;
};
};
module.exports.regExpToken = regExpToken;
module.exports.tokens = {
SPACE: noopToken(function (node) {
return node.type === 'space';
}),
SLASH: noopToken(function (node) {
return node.type === 'div' && node.value === '/';
}),
COMMA: noopToken(function (node) {
return node.type === 'div' && node.value === ',';
}),
WORD: valueForTypeToken('word'),
NONE: regExpToken(noneRe),
AUTO: regExpToken(autoRe),
NUMBER: regExpToken(numberRe, Number),
LENGTH: regExpToken(lengthRe, Number),
ANGLE: regExpToken(angleRe),
PERCENT: regExpToken(percentRe),
IDENT: regExpToken(identRe),
STRING: matchString,
COLOR: matchColor
};
},{"css-color-keywords":11,"postcss-value-parser":14}],4:[function(require,module,exports){
'use strict';
var _require = require('../tokenTypes'),
tokens = _require.tokens;
var NONE = tokens.NONE,
AUTO = tokens.AUTO,
NUMBER = tokens.NUMBER,
LENGTH = tokens.LENGTH,
SPACE = tokens.SPACE;
var defaultFlexGrow = 1;
var defaultFlexShrink = 1;
var defaultFlexBasis = 0;
module.exports = function (tokenStream) {
var flexGrow = void 0;
var flexShrink = void 0;
var flexBasis = void 0;
if (tokenStream.matches(NONE)) {
tokenStream.expectEmpty();
return { $merge: { flexGrow: 0, flexShrink: 0 } };
} else if (tokenStream.matches(AUTO)) {
tokenStream.expectEmpty();
return { $merge: { flexGrow: 1, flexShrink: 1 } };
}
var partsParsed = 0;
while (partsParsed < 2 && tokenStream.hasTokens()) {
if (partsParsed !== 0) tokenStream.expect(SPACE);
if (flexGrow === undefined && tokenStream.matches(NUMBER)) {
flexGrow = tokenStream.lastValue;
if (tokenStream.lookahead().matches(NUMBER)) {
tokenStream.expect(SPACE);
flexShrink = tokenStream.expect(NUMBER);
}
} else if (flexBasis === undefined && tokenStream.matches(LENGTH)) {
flexBasis = tokenStream.lastValue;
} else {
tokenStream.throw();
}
partsParsed += 1;
}
tokenStream.expectEmpty();
if (flexGrow === undefined) flexGrow = defaultFlexGrow;
if (flexShrink === undefined) flexShrink = defaultFlexShrink;
if (flexBasis === undefined) flexBasis = defaultFlexBasis;
return { $merge: { flexGrow: flexGrow, flexShrink: flexShrink, flexBasis: flexBasis } };
};
},{"../tokenTypes":3}],5:[function(require,module,exports){
'use strict';
var parseFontFamily = require('./fontFamily');
var _require = require('../tokenTypes'),
regExpToken = _require.regExpToken,
tokens = _require.tokens;
var SPACE = tokens.SPACE,
LENGTH = tokens.LENGTH,
NUMBER = tokens.NUMBER,
SLASH = tokens.SLASH;
var NORMAL = regExpToken(/^(normal)$/);
var STYLE = regExpToken(/^(italic)$/);
var WEIGHT = regExpToken(/^([1-9]00|bold)$/);
var VARIANT = regExpToken(/^(small-caps)$/);
var defaultFontStyle = 'normal';
var defaultFontWeight = 'normal';
var defaultFontVariant = [];
module.exports = function (tokenStream) {
var fontStyle = void 0;
var fontWeight = void 0;
var fontVariant = void 0;
// let fontSize;
var lineHeight = void 0;
// let fontFamily;
var numStyleWeightVariantMatched = 0;
while (numStyleWeightVariantMatched < 3 && tokenStream.hasTokens()) {
if (tokenStream.matches(NORMAL)) {
/* pass */
} else if (fontStyle === undefined && tokenStream.matches(STYLE)) {
fontStyle = tokenStream.lastValue;
} else if (fontWeight === undefined && tokenStream.matches(WEIGHT)) {
fontWeight = tokenStream.lastValue;
} else if (fontVariant === undefined && tokenStream.matches(VARIANT)) {
fontVariant = [tokenStream.lastValue];
} else {
break;
}
tokenStream.expect(SPACE);
numStyleWeightVariantMatched += 1;
}
var fontSize = tokenStream.expect(LENGTH);
if (tokenStream.matches(SLASH)) {
if (tokenStream.matches(NUMBER)) {
lineHeight = fontSize * tokenStream.lastValue;
} else {
lineHeight = tokenStream.expect(LENGTH);
}
}
tokenStream.expect(SPACE);
var fontFamily = parseFontFamily(tokenStream);
if (fontStyle === undefined) fontStyle = defaultFontStyle;
if (fontWeight === undefined) fontWeight = defaultFontWeight;
if (fontVariant === undefined) fontVariant = defaultFontVariant;
var out = { fontStyle: fontStyle, fontWeight: fontWeight, fontVariant: fontVariant, fontSize: fontSize, fontFamily: fontFamily };
if (lineHeight !== undefined) out.lineHeight = lineHeight;
return { $merge: out };
};
},{"../tokenTypes":3,"./fontFamily":6}],6:[function(require,module,exports){
'use strict';
var _require = require('../tokenTypes'),
tokens = _require.tokens;
var SPACE = tokens.SPACE,
IDENT = tokens.IDENT,
STRING = tokens.STRING;
module.exports = function (tokenStream) {
var fontFamily = void 0;
if (tokenStream.matches(STRING)) {
fontFamily = tokenStream.lastValue;
} else {
fontFamily = tokenStream.expect(IDENT);
while (tokenStream.hasTokens()) {
tokenStream.expect(SPACE);
var nextIdent = tokenStream.expect(IDENT);
fontFamily += ' ' + nextIdent;
}
}
tokenStream.expectEmpty();
return fontFamily;
};
},{"../tokenTypes":3}],7:[function(require,module,exports){
'use strict';
var _require = require('../tokenTypes'),
regExpToken = _require.regExpToken,
tokens = _require.tokens;
var flex = require('./flex');
var font = require('./font');
var fontFamily = require('./fontFamily');
var transform = require('./transform');
var _require2 = require('./util'),
directionFactory = _require2.directionFactory,
anyOrderFactory = _require2.anyOrderFactory,
shadowOffsetFactory = _require2.shadowOffsetFactory;
var IDENT = tokens.IDENT,
WORD = tokens.WORD,
COLOR = tokens.COLOR;
var background = function background(tokenStream) {
return { $merge: { backgroundColor: tokenStream.expect(COLOR) } };
};
var border = anyOrderFactory({
borderWidth: {
token: tokens.LENGTH,
default: 1
},
borderColor: {
token: COLOR,
default: 'black'
},
borderStyle: {
token: regExpToken(/^(solid|dashed|dotted)$/),
default: 'solid'
}
});
var borderColor = directionFactory({
types: [WORD],
prefix: 'border',
suffix: 'Color'
});
var borderRadius = directionFactory({
directions: ['TopRight', 'BottomRight', 'BottomLeft', 'TopLeft'],
prefix: 'border',
suffix: 'Radius'
});
var borderWidth = directionFactory({ prefix: 'border', suffix: 'Width' });
var margin = directionFactory({ prefix: 'margin' });
var padding = directionFactory({ prefix: 'padding' });
var flexFlow = anyOrderFactory({
flexWrap: {
token: regExpToken(/(nowrap|wrap|wrap-reverse)/),
default: 'nowrap'
},
flexDirection: {
token: regExpToken(/(row|row-reverse|column|column-reverse)/),
default: 'row'
}
});
var fontVariant = function fontVariant(tokenStream) {
return [tokenStream.expect(IDENT)];
};
var fontWeight = function fontWeight(tokenStream) {
return tokenStream.expect(WORD);
}; // Also match numbers as strings
var shadowOffset = shadowOffsetFactory();
var textShadowOffset = shadowOffsetFactory();
module.exports = {
background: background,
border: border,
borderColor: borderColor,
borderRadius: borderRadius,
borderWidth: borderWidth,
flex: flex,
flexFlow: flexFlow,
font: font,
fontFamily: fontFamily,
fontVariant: fontVariant,
fontWeight: fontWeight,
margin: margin,
padding: padding,
shadowOffset: shadowOffset,
textShadowOffset: textShadowOffset,
transform: transform
};
},{"../tokenTypes":3,"./flex":4,"./font":5,"./fontFamily":6,"./transform":8,"./util":9}],8:[function(require,module,exports){
'use strict';
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
var _require = require('../tokenTypes'),
tokens = _require.tokens;
var SPACE = tokens.SPACE,
COMMA = tokens.COMMA,
LENGTH = tokens.LENGTH,
NUMBER = tokens.NUMBER,
ANGLE = tokens.ANGLE;
var oneOfType = function oneOfType(tokenType) {
return function (functionStream) {
var value = functionStream.expect(tokenType);
functionStream.expectEmpty();
return value;
};
};
var singleNumber = oneOfType(NUMBER);
var singleLength = oneOfType(LENGTH);
var singleAngle = oneOfType(ANGLE);
var xyTransformFactory = function xyTransformFactory(tokenType) {
return function (key, valueIfOmitted) {
return function (functionStream) {
var x = functionStream.expect(tokenType);
var y = void 0;
if (functionStream.hasTokens()) {
functionStream.expect(COMMA);
y = functionStream.expect(tokenType);
} else if (valueIfOmitted !== undefined) {
y = valueIfOmitted;
} else {
// Assumption, if x === y, then we can omit XY
// I.e. scale(5) => [{ scale: 5 }] rather than [{ scaleX: 5 }, { scaleY: 5 }]
return x;
}
functionStream.expectEmpty();
return [_defineProperty({}, key + 'Y', y), _defineProperty({}, key + 'X', x)];
};
};
};
var xyNumber = xyTransformFactory(NUMBER);
var xyLength = xyTransformFactory(LENGTH);
var xyAngle = xyTransformFactory(ANGLE);
var partTransforms = {
perspective: singleNumber,
scale: xyNumber('scale'),
scaleX: singleNumber,
scaleY: singleNumber,
translate: xyLength('translate', 0),
translateX: singleLength,
translateY: singleLength,
rotate: singleAngle,
rotateX: singleAngle,
rotateY: singleAngle,
rotateZ: singleAngle,
skewX: singleAngle,
skewY: singleAngle,
skew: xyAngle('skew', '0deg')
};
module.exports = function (tokenStream) {
var transforms = [];
var didParseFirst = false;
while (tokenStream.hasTokens()) {
if (didParseFirst) tokenStream.expect(SPACE);
var functionStream = tokenStream.expectFunction();
var transformName = functionStream.parent.value;
var transformedValues = partTransforms[transformName](functionStream);
if (!Array.isArray(transformedValues)) {
transformedValues = [_defineProperty({}, transformName, transformedValues)];
}
transforms = transformedValues.concat(transforms);
didParseFirst = true;
}
return transforms;
};
},{"../tokenTypes":3}],9:[function(require,module,exports){
'use strict';
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
var _require = require('../tokenTypes'),
tokens = _require.tokens;
var LENGTH = tokens.LENGTH,
PERCENT = tokens.PERCENT,
SPACE = tokens.SPACE;
module.exports.directionFactory = function (_ref) {
var _ref$types = _ref.types,
types = _ref$types === undefined ? [LENGTH, PERCENT] : _ref$types,
_ref$directions = _ref.directions,
directions = _ref$directions === undefined ? ['Top', 'Right', 'Bottom', 'Left'] : _ref$directions,
_ref$prefix = _ref.prefix,
prefix = _ref$prefix === undefined ? '' : _ref$prefix,
_ref$suffix = _ref.suffix,
suffix = _ref$suffix === undefined ? '' : _ref$suffix;
return function (tokenStream) {
var _output;
var values = [];
// borderWidth doesn't currently allow a percent value, but may do in the future
values.push(tokenStream.expect.apply(tokenStream, _toConsumableArray(types)));
while (values.length < 4 && tokenStream.hasTokens()) {
tokenStream.expect(SPACE);
values.push(tokenStream.expect.apply(tokenStream, _toConsumableArray(types)));
}
tokenStream.expectEmpty();
var top = values[0],
_values$ = values[1],
right = _values$ === undefined ? top : _values$,
_values$2 = values[2],
bottom = _values$2 === undefined ? top : _values$2,
_values$3 = values[3],
left = _values$3 === undefined ? right : _values$3;
var keyFor = function keyFor(n) {
return '' + prefix + directions[n] + suffix;
};
var output = (_output = {}, _defineProperty(_output, keyFor(0), top), _defineProperty(_output, keyFor(1), right), _defineProperty(_output, keyFor(2), bottom), _defineProperty(_output, keyFor(3), left), _output);
return { $merge: output };
};
};
module.exports.anyOrderFactory = function (properties) {
var delim = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SPACE;
return function (tokenStream) {
var propertyNames = Object.keys(properties);
var values = propertyNames.reduce(function (accum, propertyName) {
accum[propertyName] === undefined; // eslint-disable-line
return accum;
}, {});
var numParsed = 0;
while (numParsed < propertyNames.length && tokenStream.hasTokens()) {
if (numParsed) tokenStream.expect(delim);
var matchedPropertyName = propertyNames.find(function (propertyName) {
return values[propertyName] === undefined && tokenStream.matches(properties[propertyName].token);
});
if (!matchedPropertyName) {
tokenStream.throw();
} else {
values[matchedPropertyName] = tokenStream.lastValue;
}
numParsed += 1;
}
tokenStream.expectEmpty();
propertyNames.forEach(function (propertyName) {
if (values[propertyName] === undefined) values[propertyName] = properties[propertyName].default;
});
return { $merge: values };
};
};
module.exports.shadowOffsetFactory = function () {
return function (tokenStream) {
var width = tokenStream.expect(LENGTH);
var height = tokenStream.matches(SPACE) ? tokenStream.expect(LENGTH) : width;
tokenStream.expectEmpty();
return { width: width, height: height };
};
};
},{"../tokenTypes":3}],10:[function(require,module,exports){
module.exports={
"black": "#000000",
"silver": "#c0c0c0",
"gray": "#808080",
"white": "#ffffff",
"maroon": "#800000",
"red": "#ff0000",
"purple": "#800080",
"fuchsia": "#ff00ff",
"green": "#008000",
"lime": "#00ff00",
"olive": "#808000",
"yellow": "#ffff00",
"navy": "#000080",
"blue": "#0000ff",
"teal": "#008080",
"aqua": "#00ffff",
"orange": "#ffa500",
"aliceblue": "#f0f8ff",
"antiquewhite": "#faebd7",
"aquamarine": "#7fffd4",
"azure": "#f0ffff",
"beige": "#f5f5dc",
"bisque": "#ffe4c4",
"blanchedalmond": "#ffebcd",
"blueviolet": "#8a2be2",
"brown": "#a52a2a",
"burlywood": "#deb887",
"cadetblue": "#5f9ea0",
"chartreuse": "#7fff00",
"chocolate": "#d2691e",
"coral": "#ff7f50",
"cornflowerblue": "#6495ed",
"cornsilk": "#fff8dc",
"crimson": "#dc143c",
"darkblue": "#00008b",
"darkcyan": "#008b8b",
"darkgoldenrod": "#b8860b",
"darkgray": "#a9a9a9",
"darkgreen": "#006400",
"darkgrey": "#a9a9a9",
"darkkhaki": "#bdb76b",
"darkmagenta": "#8b008b",
"darkolivegreen": "#556b2f",
"darkorange": "#ff8c00",
"darkorchid": "#9932cc",
"darkred": "#8b0000",
"darksalmon": "#e9967a",
"darkseagreen": "#8fbc8f",
"darkslateblue": "#483d8b",
"darkslategray": "#2f4f4f",
"darkslategrey": "#2f4f4f",
"darkturquoise": "#00ced1",
"darkviolet": "#9400d3",
"deeppink": "#ff1493",
"deepskyblue": "#00bfff",
"dimgray": "#696969",
"dimgrey": "#696969",
"dodgerblue": "#1e90ff",
"firebrick": "#b22222",
"floralwhite": "#fffaf0",
"forestgreen": "#228b22",
"gainsboro": "#dcdcdc",
"ghostwhite": "#f8f8ff",
"gold": "#ffd700",
"goldenrod": "#daa520",
"greenyellow": "#adff2f",
"grey": "#808080",
"honeydew": "#f0fff0",
"hotpink": "#ff69b4",
"indianred": "#cd5c5c",
"indigo": "#4b0082",
"ivory": "#fffff0",
"khaki": "#f0e68c",
"lavender": "#e6e6fa",
"lavenderblush": "#fff0f5",
"lawngreen": "#7cfc00",
"lemonchiffon": "#fffacd",
"lightblue": "#add8e6",
"lightcoral": "#f08080",
"lightcyan": "#e0ffff",
"lightgoldenrodyellow": "#fafad2",
"lightgray": "#d3d3d3",
"lightgreen": "#90ee90",
"lightgrey": "#d3d3d3",
"lightpink": "#ffb6c1",
"lightsalmon": "#ffa07a",
"lightseagreen": "#20b2aa",
"lightskyblue": "#87cefa",
"lightslategray": "#778899",
"lightslategrey": "#778899",
"lightsteelblue": "#b0c4de",
"lightyellow": "#ffffe0",
"limegreen": "#32cd32",
"linen": "#faf0e6",
"mediumaquamarine": "#66cdaa",
"mediumblue": "#0000cd",
"mediumorchid": "#ba55d3",
"mediumpurple": "#9370db",
"mediumseagreen": "#3cb371",
"mediumslateblue": "#7b68ee",
"mediumspringgreen": "#00fa9a",
"mediumturquoise": "#48d1cc",
"mediumvioletred": "#c71585",
"midnightblue": "#191970",
"mintcream": "#f5fffa",
"mistyrose": "#ffe4e1",
"moccasin": "#ffe4b5",
"navajowhite": "#ffdead",
"oldlace": "#fdf5e6",
"olivedrab": "#6b8e23",
"orangered": "#ff4500",
"orchid": "#da70d6",
"palegoldenrod": "#eee8aa",
"palegreen": "#98fb98",
"paleturquoise": "#afeeee",
"palevioletred": "#db7093",
"papayawhip": "#ffefd5",
"peachpuff": "#ffdab9",
"peru": "#cd853f",
"pink": "#ffc0cb",
"plum": "#dda0dd",
"powderblue": "#b0e0e6",
"rosybrown": "#bc8f8f",
"royalblue": "#4169e1",
"saddlebrown": "#8b4513",
"salmon": "#fa8072",
"sandybrown": "#f4a460",
"seagreen": "#2e8b57",
"seashell": "#fff5ee",
"sienna": "#a0522d",
"skyblue": "#87ceeb",
"slateblue": "#6a5acd",
"slategray": "#708090",
"slategrey": "#708090",
"snow": "#fffafa",
"springgreen": "#00ff7f",
"steelblue": "#4682b4",
"tan": "#d2b48c",
"thistle": "#d8bfd8",
"tomato": "#ff6347",
"turquoise": "#40e0d0",
"violet": "#ee82ee",
"wheat": "#f5deb3",
"whitesmoke": "#f5f5f5",
"yellowgreen": "#9acd32",
"rebeccapurple": "#663399"
}
},{}],11:[function(require,module,exports){
'use strict'
module.exports = require('./colors.json')
},{"./colors.json":10}],12:[function(require,module,exports){
"use strict";
/**
* Copyright (c) 2013-present, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
* @typechecks
*/
var _hyphenPattern = /-(.)/g;
/**
* Camelcases a hyphenated string, for example:
*
* > camelize('background-color')
* < "backgroundColor"
*
* @param {string} string
* @return {string}
*/
function camelize(string) {
return string.replace(_hyphenPattern, function (_, character) {
return character.toUpperCase();
});
}
module.exports = camelize;
},{}],13:[function(require,module,exports){
/**
* Copyright (c) 2013-present, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
* @typechecks
*/
'use strict';
var camelize = require('./camelize');
var msPattern = /^-ms-/;
/**
* Camelcases a hyphenated CSS property name, for example:
*
* > camelizeStyleName('background-color')
* < "backgroundColor"
* > camelizeStyleName('-moz-transition')
* < "MozTransition"
* > camelizeStyleName('-ms-transition')
* < "msTransition"
*
* As Andi Smith suggests
* (http://www.andismith.com/blog/2012/02/modernizr-prefixed/), an `-ms` prefix
* is converted to lowercase `ms`.
*
* @param {string} string
* @return {string}
*/
function camelizeStyleName(string) {
return camelize(string.replace(msPattern, 'ms-'));
}
module.exports = camelizeStyleName;
},{"./camelize":12}],14:[function(require,module,exports){
var parse = require('./parse');
var walk = require('./walk');
var stringify = require('./stringify');
function ValueParser(value) {
if (this instanceof ValueParser) {
this.nodes = parse(value);
return this;
}
return new ValueParser(value);
}
ValueParser.prototype.toString = function () {
return Array.isArray(this.nodes) ? stringify(this.nodes) : '';
};
ValueParser.prototype.walk = function (cb, bubble) {
walk(this.nodes, cb, bubble);
return this;
};
ValueParser.unit = require('./unit');
ValueParser.walk = walk;
ValueParser.stringify = stringify;
module.exports = ValueParser;
},{"./parse":15,"./stringify":16,"./unit":17,"./walk":18}],15:[function(require,module,exports){
var openParentheses = '('.charCodeAt(0);
var closeParentheses = ')'.charCodeAt(0);
var singleQuote = '\''.charCodeAt(0);
var doubleQuote = '"'.charCodeAt(0);
var backslash = '\\'.charCodeAt(0);
var slash = '/'.charCodeAt(0);
var comma = ','.charCodeAt(0);
var colon = ':'.charCodeAt(0);
var star = '*'.charCodeAt(0);
module.exports = function (input) {
var tokens = [];
var value = input;
var next, quote, prev, token, escape, escapePos, whitespacePos;
var pos = 0;
var code = value.charCodeAt(pos);
var max = value.length;
var stack = [{ nodes: tokens }];
var balanced = 0;
var parent;
var name = '';
var before = '';
var after = '';
while (pos < max) {
// Whitespaces
if (code <= 32) {
next = pos;
do {
next += 1;
code = value.charCodeAt(next);
} while (code <= 32);
token = value.slice(pos, next);
prev = tokens[tokens.length - 1];
if (code === closeParentheses && balanced) {
after = token;
} else if (prev && prev.type === 'div') {
prev.after = token;
} else if (code === comma || code === colon || code === slash && value.charCodeAt(next + 1) !== star) {
before = token;
} else {
tokens.push({
type: 'space',
sourceIndex: pos,
value: token
});
}
pos = next;
// Quotes
} else if (code === singleQuote || code === doubleQuote) {
next = pos;
quote = code === singleQuote ? '\'' : '"';
token = {
type: 'string',
sourceIndex: pos,
quote: quote
};
do {
escape = false;
next = value.indexOf(quote, next + 1);
if (~next) {
escapePos = next;
while (value.charCodeAt(escapePos - 1) === backslash) {
escapePos -= 1;
escape = !escape;
}
} else {
value += quote;
next = value.length - 1;
token.unclosed = true;
}
} while (escape);
token.value = value.slice(pos + 1, next);
tokens.push(token);
pos = next + 1;
code = value.charCodeAt(pos);
// Comments
} else if (code === slash && value.charCodeAt(pos + 1) === star) {
token = {
type: 'comment',
sourceIndex: pos
};
next = value.indexOf('*/', pos);
if (next === -1) {
token.unclosed = true;
next = value.length;
}
token.value = value.slice(pos + 2, next);
tokens.push(token);
pos = next + 2;
code = value.charCodeAt(pos);
// Dividers
} else if (code === slash || code === comma || code === colon) {
token = value[pos];
tokens.push({
type: 'div',
sourceIndex: pos - before.length,
value: token,
before: before,
after: ''
});
before = '';
pos += 1;
code = value.charCodeAt(pos);
// Open parentheses
} else if (openParentheses === code) {
// Whitespaces after open parentheses
next = pos;
do {
next += 1;
code = value.charCodeAt(next);
} while (code <= 32);
token = {
type: 'function',
sourceIndex: pos - name.length,
value: name,
before: value.slice(pos + 1, next)
};
pos = next;
if (name === 'url' && code !== singleQuote && code !== doubleQuote) {
next -= 1;
do {
escape = false;
next = value.indexOf(')', next + 1);
if (~next) {
escapePos = next;
while (value.charCodeAt(escapePos - 1) === backslash) {
escapePos -= 1;
escape = !escape;
}
} else {
value += ')';
next = value.length - 1;
token.unclosed = true;
}
} while (escape);
// Whitespaces before closed
whitespacePos = next;
do {
whitespacePos -= 1;
code = value.charCodeAt(whitespacePos);
} while (code <= 32);
if (pos !== whitespacePos + 1) {
token.nodes = [{
type: 'word',
sourceIndex: pos,
value: value.slice(pos, whitespacePos + 1)
}];
} else {
token.nodes = [];
}
if (token.unclosed && whitespacePos + 1 !== next) {
token.after = '';
token.nodes.push({
type: 'space',
sourceIndex: whitespacePos + 1,
value: value.slice(whitespacePos + 1, next)
});
} else {
token.after = value.slice(whitespacePos + 1, next);
}
pos = next + 1;
code = value.charCodeAt(pos);
tokens.push(token);
} else {
balanced += 1;
token.after = '';
tokens.push(token);
stack.push(token);
tokens = token.nodes = [];
parent = token;
}
name = '';
// Close parentheses
} else if (closeParentheses === code && balanced) {
pos += 1;
code = value.charCodeAt(pos);
parent.after = after;
after = '';
balanced -= 1;
stack.pop();
parent = stack[balanced];
tokens = parent.nodes;
// Words
} else {
next = pos;
do {
if (code === backslash) {
next += 1;
}
next += 1;
code = value.charCodeAt(next);
} while (next < max && !(
code <= 32 ||
code === singleQuote ||
code === doubleQuote ||
code === comma ||
code === colon ||
code === slash ||
code === openParentheses ||
code === closeParentheses && balanced
));
token = value.slice(pos, next);
if (openParentheses === code) {
name = token;
} else {
tokens.push({
type: 'word',
sourceIndex: pos,
value: token
});
}
pos = next;
}
}
for (pos = stack.length - 1; pos; pos -= 1) {
stack[pos].unclosed = true;
}
return stack[0].nodes;
};
},{}],16:[function(require,module,exports){
function stringifyNode(node, custom) {
var type = node.type;
var value = node.value;
var buf;
var customResult;
if (custom && (customResult = custom(node)) !== undefined) {
return customResult;
} else if (type === 'word' || type === 'space') {
return value;
} else if (type === 'string') {
buf = node.quote || '';
return buf + value + (node.unclosed ? '' : buf);
} else if (type === 'comment') {
return '/*' + value + (node.unclosed ? '' : '*/');
} else if (type === 'div') {
return (node.before || '') + value + (node.after || '');
} else if (Array.isArray(node.nodes)) {
buf = stringify(node.nodes);
if (type !== 'function') {
return buf;
}
return value + '(' + (node.before || '') + buf + (node.after || '') + (node.unclosed ? '' : ')');
}
return value;
}
function stringify(nodes, custom) {
var result, i;
if (Array.isArray(nodes)) {
result = '';
for (i = nodes.length - 1; ~i; i -= 1) {
result = stringifyNode(nodes[i], custom) + result;
}
return result;
}
return stringifyNode(nodes, custom);
}
module.exports = stringify;
},{}],17:[function(require,module,exports){
var minus = '-'.charCodeAt(0);
var plus = '+'.charCodeAt(0);
var dot = '.'.charCodeAt(0);
module.exports = function (value) {
var pos = 0;
var length = value.length;
var dotted = false;
var containsNumber = false;
var code;
var number = '';
while (pos < length) {
code = value.charCodeAt(pos);
if (code >= 48 && code <= 57) {
number += value[pos];
containsNumber = true;
} else if (code === dot) {
if (dotted) {
break;
}
dotted = true;
number += value[pos];
} else if (code === plus || code === minus) {
if (pos !== 0) {
break;
}
number += value[pos];
} else {
break;
}
pos += 1;
}
return containsNumber ? {
number: number,
unit: value.slice(pos)
} : false;
};
},{}],18:[function(require,module,exports){
module.exports = function walk(nodes, cb, bubble) {
var i, max, node, result;
for (i = 0, max = nodes.length; i < max; i += 1) {
node = nodes[i];
if (!bubble) {
result = cb(node, i, nodes);
}
if (result !== false && node.type === 'function' && Array.isArray(node.nodes)) {
walk(node.nodes, cb, bubble);
}
if (bubble) {
cb(node, i, nodes);
}
}
};
},{}],"css-to-react-native":[function(require,module,exports){
(function (process){
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
/* eslint-disable no-param-reassign */
var parse = require('postcss-value-parser');
var camelizeStyleName = require('fbjs/lib/camelizeStyleName');
var transforms = require('./transforms');
var TokenStream = require('./TokenStream');
// Note if this is wrong, you'll need to change tokenTypes.js too
var numberOrLengthRe = /^([+-]?(?:\d*\.)?\d+(?:[Ee][+-]?\d+)?)(?:px)?$/i;
var boolRe = /^true|false$/i;
// Undocumented export
var transformRawValue = exports.transformRawValue = function transformRawValue(input) {
var value = input.trim();
var numberMatch = value.match(numberOrLengthRe);
if (numberMatch !== null) return Number(numberMatch[1]);
var boolMatch = input.match(boolRe);
if (boolMatch !== null) return boolMatch[0].toLowerCase() === 'true';
return value;
};
var baseTransformShorthandValue = function baseTransformShorthandValue(propName, inputValue) {
var ast = parse(inputValue.trim());
var tokenStream = new TokenStream(ast.nodes);
return transforms[propName](tokenStream);
};
var transformShorthandValue = process.env.NODE_ENV === 'production' ? baseTransformShorthandValue : function (propName, inputValue) {
try {
return baseTransformShorthandValue(propName, inputValue);
} catch (e) {
throw new Error('Failed to parse declaration "' + propName + ': ' + inputValue + '"');
}
};
var getStylesForProperty = exports.getStylesForProperty = function getStylesForProperty(propName, inputValue, allowShorthand) {
var isRawValue = allowShorthand === false || !(propName in transforms);
var propValue = isRawValue ? transformRawValue(inputValue) : transformShorthandValue(propName, inputValue.trim());
return propValue && propValue.$merge ? propValue.$merge : _defineProperty({}, propName, propValue);
};
var getPropertyName = exports.getPropertyName = camelizeStyleName;
exports.default = function (rules) {
var shorthandBlacklist = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
return rules.reduce(function (accum, rule) {
var propertyName = getPropertyName(rule[0]);
var value = rule[1];
var allowShorthand = shorthandBlacklist.indexOf(propertyName) === -1;
return Object.assign(accum, getStylesForProperty(propertyName, value, allowShorthand));
}, {});
};
}).call(this,require('_process'))
},{"./TokenStream":2,"./transforms":7,"_process":1,"fbjs/lib/camelizeStyleName":13,"postcss-value-parser":14}]},{},[])
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/browser-pack/_prelude.js","../../../../home/admin/browserify-cdn/node_modules/browserify/node_modules/process/browser.js","dist/TokenStream.js","dist/tokenTypes.js","dist/transforms/flex.js","dist/transforms/font.js","dist/transforms/fontFamily.js","dist/transforms/index.js","dist/transforms/transform.js","dist/transforms/util.js","node_modules/css-color-keywords/colors.json","node_modules/css-color-keywords/index.js","node_modules/fbjs/lib/camelize.js","node_modules/fbjs/lib/camelizeStyleName.js","node_modules/postcss-value-parser/lib/index.js","node_modules/postcss-value-parser/lib/parse.js","node_modules/postcss-value-parser/lib/stringify.js","node_modules/postcss-value-parser/lib/unit.js","node_modules/postcss-value-parser/lib/walk.js","dist/index.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpJA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","'use strict';\n\nvar _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; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar SYMBOL_MATCH = 'SYMBOL_MATCH';\n\nmodule.exports = function () {\n  function TokenStream(nodes, parent) {\n    _classCallCheck(this, TokenStream);\n\n    this.nodes = nodes;\n    this.parent = parent;\n    this.lastFunction = null;\n    this.lastValue = null;\n  }\n\n  _createClass(TokenStream, [{\n    key: 'hasTokens',\n    value: function hasTokens() {\n      return this.nodes.length > 0;\n    }\n  }, {\n    key: 'lookahead',\n    value: function lookahead() {\n      return new TokenStream(this.nodes.slice(1), this.parent);\n    }\n  }, {\n    key: SYMBOL_MATCH,\n    value: function value() {\n      var node = this.node;\n\n      if (!node) return null;\n\n      for (var i = 0; i < arguments.length; i += 1) {\n        var tokenDescriptor = arguments.length <= i ? undefined : arguments[i];\n        var value = tokenDescriptor(node);\n\n        if (value !== null) {\n          this.nodes = this.nodes.slice(1);\n          this.lastFunction = null;\n          this.lastValue = value;\n          return value;\n        }\n      }\n\n      return null;\n    }\n  }, {\n    key: 'matches',\n    value: function matches() {\n      return this[SYMBOL_MATCH].apply(this, arguments) !== null;\n    }\n  }, {\n    key: 'expect',\n    value: function expect() {\n      var value = this[SYMBOL_MATCH].apply(this, arguments);\n      if (value !== null) return value;\n      return this.throw();\n    }\n  }, {\n    key: 'matchFunction',\n    value: function matchFunction() {\n      var node = this.node;\n      if (node.type !== 'function') return null;\n      var value = new TokenStream(node.nodes, node);\n      this.nodes = this.nodes.slice(1);\n      this.lastFunction = value;\n      this.lastValue = null;\n      return value;\n    }\n  }, {\n    key: 'expectFunction',\n    value: function expectFunction() {\n      var value = this.matchFunction();\n      if (value !== null) return value;\n      return this.throw();\n    }\n  }, {\n    key: 'expectEmpty',\n    value: function expectEmpty() {\n      if (this.hasTokens()) this.throw();\n    }\n  }, {\n    key: 'throw',\n    value: function _throw() {\n      throw new Error('Unexpected token type: ' + this.node.type);\n    }\n  }, {\n    key: 'node',\n    get: function get() {\n      return this.nodes[0];\n    }\n  }]);\n\n  return TokenStream;\n}();","'use strict';\n\nvar _require = require('postcss-value-parser'),\n    stringify = _require.stringify;\n\nvar cssColorKeywords = require('css-color-keywords');\n\nvar matchString = function matchString(node) {\n  if (node.type !== 'string') return null;\n  return node.value.replace(/\\\\([0-9a-f]{1,6})(?:\\s|$)/gi, function (match, charCode) {\n    return String.fromCharCode(parseInt(charCode, 16));\n  }).replace(/\\\\/g, '');\n};\n\nvar hexColorRe = /^(#(?:[0-9a-f]{3,4}){1,2})$/i;\nvar cssFunctionNameRe = /^(rgba?|hsla?|hwb|lab|lch|gray|color)$/;\n\nvar matchColor = function matchColor(node) {\n  if (node.type === 'word' && (hexColorRe.test(node.value) || node.value in cssColorKeywords)) {\n    return node.value;\n  } else if (node.type === 'function' && cssFunctionNameRe.test(node.value)) {\n    return stringify(node);\n  }\n  return null;\n};\n\nvar noneRe = /^(none)$/i;\nvar autoRe = /^(auto)$/i;\nvar identRe = /(^-?[_a-z][_a-z0-9-]*$)/i;\n// Note if these are wrong, you'll need to change index.js too\nvar numberRe = /^([+-]?(?:\\d*\\.)?\\d+(?:[Ee][+-]?\\d+)?)$/;\n// Note lengthRe is sneaky: you can omit units for 0\nvar lengthRe = /^(0$|(?:[+-]?(?:\\d*\\.)?\\d+(?:[Ee][+-]?\\d+)?)(?=px$))/;\nvar angleRe = /^([+-]?(?:\\d*\\.)?\\d+(?:[Ee][+-]?\\d+)?(?:deg|rad))$/;\nvar percentRe = /^([+-]?(?:\\d*\\.)?\\d+(?:[Ee][+-]?\\d+)?%)$/;\n\nvar noopToken = function noopToken(predicate) {\n  return function (node) {\n    return predicate(node) ? '<token>' : null;\n  };\n};\n\nvar valueForTypeToken = function valueForTypeToken(type) {\n  return function (node) {\n    return node.type === type ? node.value : null;\n  };\n};\n\nvar regExpToken = function regExpToken(regExp) {\n  var transform = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : String;\n  return function (node) {\n    if (node.type !== 'word') return null;\n\n    var match = node.value.match(regExp);\n    if (match === null) return null;\n\n    var value = transform(match[1]);\n\n    return value;\n  };\n};\n\nmodule.exports.regExpToken = regExpToken;\n\nmodule.exports.tokens = {\n  SPACE: noopToken(function (node) {\n    return node.type === 'space';\n  }),\n  SLASH: noopToken(function (node) {\n    return node.type === 'div' && node.value === '/';\n  }),\n  COMMA: noopToken(function (node) {\n    return node.type === 'div' && node.value === ',';\n  }),\n  WORD: valueForTypeToken('word'),\n  NONE: regExpToken(noneRe),\n  AUTO: regExpToken(autoRe),\n  NUMBER: regExpToken(numberRe, Number),\n  LENGTH: regExpToken(lengthRe, Number),\n  ANGLE: regExpToken(angleRe),\n  PERCENT: regExpToken(percentRe),\n  IDENT: regExpToken(identRe),\n  STRING: matchString,\n  COLOR: matchColor\n};","'use strict';\n\nvar _require = require('../tokenTypes'),\n    tokens = _require.tokens;\n\nvar NONE = tokens.NONE,\n    AUTO = tokens.AUTO,\n    NUMBER = tokens.NUMBER,\n    LENGTH = tokens.LENGTH,\n    SPACE = tokens.SPACE;\n\n\nvar defaultFlexGrow = 1;\nvar defaultFlexShrink = 1;\nvar defaultFlexBasis = 0;\n\nmodule.exports = function (tokenStream) {\n  var flexGrow = void 0;\n  var flexShrink = void 0;\n  var flexBasis = void 0;\n\n  if (tokenStream.matches(NONE)) {\n    tokenStream.expectEmpty();\n    return { $merge: { flexGrow: 0, flexShrink: 0 } };\n  } else if (tokenStream.matches(AUTO)) {\n    tokenStream.expectEmpty();\n    return { $merge: { flexGrow: 1, flexShrink: 1 } };\n  }\n\n  var partsParsed = 0;\n  while (partsParsed < 2 && tokenStream.hasTokens()) {\n    if (partsParsed !== 0) tokenStream.expect(SPACE);\n\n    if (flexGrow === undefined && tokenStream.matches(NUMBER)) {\n      flexGrow = tokenStream.lastValue;\n\n      if (tokenStream.lookahead().matches(NUMBER)) {\n        tokenStream.expect(SPACE);\n        flexShrink = tokenStream.expect(NUMBER);\n      }\n    } else if (flexBasis === undefined && tokenStream.matches(LENGTH)) {\n      flexBasis = tokenStream.lastValue;\n    } else {\n      tokenStream.throw();\n    }\n\n    partsParsed += 1;\n  }\n\n  tokenStream.expectEmpty();\n\n  if (flexGrow === undefined) flexGrow = defaultFlexGrow;\n  if (flexShrink === undefined) flexShrink = defaultFlexShrink;\n  if (flexBasis === undefined) flexBasis = defaultFlexBasis;\n\n  return { $merge: { flexGrow: flexGrow, flexShrink: flexShrink, flexBasis: flexBasis } };\n};","'use strict';\n\nvar parseFontFamily = require('./fontFamily');\n\nvar _require = require('../tokenTypes'),\n    regExpToken = _require.regExpToken,\n    tokens = _require.tokens;\n\nvar SPACE = tokens.SPACE,\n    LENGTH = tokens.LENGTH,\n    NUMBER = tokens.NUMBER,\n    SLASH = tokens.SLASH;\n\nvar NORMAL = regExpToken(/^(normal)$/);\nvar STYLE = regExpToken(/^(italic)$/);\nvar WEIGHT = regExpToken(/^([1-9]00|bold)$/);\nvar VARIANT = regExpToken(/^(small-caps)$/);\n\nvar defaultFontStyle = 'normal';\nvar defaultFontWeight = 'normal';\nvar defaultFontVariant = [];\n\nmodule.exports = function (tokenStream) {\n  var fontStyle = void 0;\n  var fontWeight = void 0;\n  var fontVariant = void 0;\n  // let fontSize;\n  var lineHeight = void 0;\n  // let fontFamily;\n\n  var numStyleWeightVariantMatched = 0;\n  while (numStyleWeightVariantMatched < 3 && tokenStream.hasTokens()) {\n    if (tokenStream.matches(NORMAL)) {\n      /* pass */\n    } else if (fontStyle === undefined && tokenStream.matches(STYLE)) {\n      fontStyle = tokenStream.lastValue;\n    } else if (fontWeight === undefined && tokenStream.matches(WEIGHT)) {\n      fontWeight = tokenStream.lastValue;\n    } else if (fontVariant === undefined && tokenStream.matches(VARIANT)) {\n      fontVariant = [tokenStream.lastValue];\n    } else {\n      break;\n    }\n\n    tokenStream.expect(SPACE);\n    numStyleWeightVariantMatched += 1;\n  }\n\n  var fontSize = tokenStream.expect(LENGTH);\n\n  if (tokenStream.matches(SLASH)) {\n    if (tokenStream.matches(NUMBER)) {\n      lineHeight = fontSize * tokenStream.lastValue;\n    } else {\n      lineHeight = tokenStream.expect(LENGTH);\n    }\n  }\n\n  tokenStream.expect(SPACE);\n\n  var fontFamily = parseFontFamily(tokenStream);\n\n  if (fontStyle === undefined) fontStyle = defaultFontStyle;\n  if (fontWeight === undefined) fontWeight = defaultFontWeight;\n  if (fontVariant === undefined) fontVariant = defaultFontVariant;\n\n  var out = { fontStyle: fontStyle, fontWeight: fontWeight, fontVariant: fontVariant, fontSize: fontSize, fontFamily: fontFamily };\n  if (lineHeight !== undefined) out.lineHeight = lineHeight;\n\n  return { $merge: out };\n};","'use strict';\n\nvar _require = require('../tokenTypes'),\n    tokens = _require.tokens;\n\nvar SPACE = tokens.SPACE,\n    IDENT = tokens.IDENT,\n    STRING = tokens.STRING;\n\n\nmodule.exports = function (tokenStream) {\n  var fontFamily = void 0;\n\n  if (tokenStream.matches(STRING)) {\n    fontFamily = tokenStream.lastValue;\n  } else {\n    fontFamily = tokenStream.expect(IDENT);\n    while (tokenStream.hasTokens()) {\n      tokenStream.expect(SPACE);\n      var nextIdent = tokenStream.expect(IDENT);\n      fontFamily += ' ' + nextIdent;\n    }\n  }\n\n  tokenStream.expectEmpty();\n\n  return fontFamily;\n};","'use strict';\n\nvar _require = require('../tokenTypes'),\n    regExpToken = _require.regExpToken,\n    tokens = _require.tokens;\n\nvar flex = require('./flex');\nvar font = require('./font');\nvar fontFamily = require('./fontFamily');\nvar transform = require('./transform');\n\nvar _require2 = require('./util'),\n    directionFactory = _require2.directionFactory,\n    anyOrderFactory = _require2.anyOrderFactory,\n    shadowOffsetFactory = _require2.shadowOffsetFactory;\n\nvar IDENT = tokens.IDENT,\n    WORD = tokens.WORD,\n    COLOR = tokens.COLOR;\n\n\nvar background = function background(tokenStream) {\n  return { $merge: { backgroundColor: tokenStream.expect(COLOR) } };\n};\nvar border = anyOrderFactory({\n  borderWidth: {\n    token: tokens.LENGTH,\n    default: 1\n  },\n  borderColor: {\n    token: COLOR,\n    default: 'black'\n  },\n  borderStyle: {\n    token: regExpToken(/^(solid|dashed|dotted)$/),\n    default: 'solid'\n  }\n});\nvar borderColor = directionFactory({\n  types: [WORD],\n  prefix: 'border',\n  suffix: 'Color'\n});\nvar borderRadius = directionFactory({\n  directions: ['TopRight', 'BottomRight', 'BottomLeft', 'TopLeft'],\n  prefix: 'border',\n  suffix: 'Radius'\n});\nvar borderWidth = directionFactory({ prefix: 'border', suffix: 'Width' });\nvar margin = directionFactory({ prefix: 'margin' });\nvar padding = directionFactory({ prefix: 'padding' });\nvar flexFlow = anyOrderFactory({\n  flexWrap: {\n    token: regExpToken(/(nowrap|wrap|wrap-reverse)/),\n    default: 'nowrap'\n  },\n  flexDirection: {\n    token: regExpToken(/(row|row-reverse|column|column-reverse)/),\n    default: 'row'\n  }\n});\nvar fontVariant = function fontVariant(tokenStream) {\n  return [tokenStream.expect(IDENT)];\n};\nvar fontWeight = function fontWeight(tokenStream) {\n  return tokenStream.expect(WORD);\n}; // Also match numbers as strings\nvar shadowOffset = shadowOffsetFactory();\nvar textShadowOffset = shadowOffsetFactory();\n\nmodule.exports = {\n  background: background,\n  border: border,\n  borderColor: borderColor,\n  borderRadius: borderRadius,\n  borderWidth: borderWidth,\n  flex: flex,\n  flexFlow: flexFlow,\n  font: font,\n  fontFamily: fontFamily,\n  fontVariant: fontVariant,\n  fontWeight: fontWeight,\n  margin: margin,\n  padding: padding,\n  shadowOffset: shadowOffset,\n  textShadowOffset: textShadowOffset,\n  transform: transform\n};","'use strict';\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nvar _require = require('../tokenTypes'),\n    tokens = _require.tokens;\n\nvar SPACE = tokens.SPACE,\n    COMMA = tokens.COMMA,\n    LENGTH = tokens.LENGTH,\n    NUMBER = tokens.NUMBER,\n    ANGLE = tokens.ANGLE;\n\n\nvar oneOfType = function oneOfType(tokenType) {\n  return function (functionStream) {\n    var value = functionStream.expect(tokenType);\n    functionStream.expectEmpty();\n    return value;\n  };\n};\n\nvar singleNumber = oneOfType(NUMBER);\nvar singleLength = oneOfType(LENGTH);\nvar singleAngle = oneOfType(ANGLE);\nvar xyTransformFactory = function xyTransformFactory(tokenType) {\n  return function (key, valueIfOmitted) {\n    return function (functionStream) {\n      var x = functionStream.expect(tokenType);\n\n      var y = void 0;\n      if (functionStream.hasTokens()) {\n        functionStream.expect(COMMA);\n        y = functionStream.expect(tokenType);\n      } else if (valueIfOmitted !== undefined) {\n        y = valueIfOmitted;\n      } else {\n        // Assumption, if x === y, then we can omit XY\n        // I.e. scale(5) => [{ scale: 5 }] rather than [{ scaleX: 5 }, { scaleY: 5 }]\n        return x;\n      }\n\n      functionStream.expectEmpty();\n\n      return [_defineProperty({}, key + 'Y', y), _defineProperty({}, key + 'X', x)];\n    };\n  };\n};\nvar xyNumber = xyTransformFactory(NUMBER);\nvar xyLength = xyTransformFactory(LENGTH);\nvar xyAngle = xyTransformFactory(ANGLE);\n\nvar partTransforms = {\n  perspective: singleNumber,\n  scale: xyNumber('scale'),\n  scaleX: singleNumber,\n  scaleY: singleNumber,\n  translate: xyLength('translate', 0),\n  translateX: singleLength,\n  translateY: singleLength,\n  rotate: singleAngle,\n  rotateX: singleAngle,\n  rotateY: singleAngle,\n  rotateZ: singleAngle,\n  skewX: singleAngle,\n  skewY: singleAngle,\n  skew: xyAngle('skew', '0deg')\n};\n\nmodule.exports = function (tokenStream) {\n  var transforms = [];\n\n  var didParseFirst = false;\n  while (tokenStream.hasTokens()) {\n    if (didParseFirst) tokenStream.expect(SPACE);\n\n    var functionStream = tokenStream.expectFunction();\n    var transformName = functionStream.parent.value;\n    var transformedValues = partTransforms[transformName](functionStream);\n    if (!Array.isArray(transformedValues)) {\n      transformedValues = [_defineProperty({}, transformName, transformedValues)];\n    }\n    transforms = transformedValues.concat(transforms);\n\n    didParseFirst = true;\n  }\n\n  return transforms;\n};","'use strict';\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nvar _require = require('../tokenTypes'),\n    tokens = _require.tokens;\n\nvar LENGTH = tokens.LENGTH,\n    PERCENT = tokens.PERCENT,\n    SPACE = tokens.SPACE;\n\n\nmodule.exports.directionFactory = function (_ref) {\n  var _ref$types = _ref.types,\n      types = _ref$types === undefined ? [LENGTH, PERCENT] : _ref$types,\n      _ref$directions = _ref.directions,\n      directions = _ref$directions === undefined ? ['Top', 'Right', 'Bottom', 'Left'] : _ref$directions,\n      _ref$prefix = _ref.prefix,\n      prefix = _ref$prefix === undefined ? '' : _ref$prefix,\n      _ref$suffix = _ref.suffix,\n      suffix = _ref$suffix === undefined ? '' : _ref$suffix;\n  return function (tokenStream) {\n    var _output;\n\n    var values = [];\n\n    // borderWidth doesn't currently allow a percent value, but may do in the future\n    values.push(tokenStream.expect.apply(tokenStream, _toConsumableArray(types)));\n\n    while (values.length < 4 && tokenStream.hasTokens()) {\n      tokenStream.expect(SPACE);\n      values.push(tokenStream.expect.apply(tokenStream, _toConsumableArray(types)));\n    }\n\n    tokenStream.expectEmpty();\n\n    var top = values[0],\n        _values$ = values[1],\n        right = _values$ === undefined ? top : _values$,\n        _values$2 = values[2],\n        bottom = _values$2 === undefined ? top : _values$2,\n        _values$3 = values[3],\n        left = _values$3 === undefined ? right : _values$3;\n\n\n    var keyFor = function keyFor(n) {\n      return '' + prefix + directions[n] + suffix;\n    };\n\n    var output = (_output = {}, _defineProperty(_output, keyFor(0), top), _defineProperty(_output, keyFor(1), right), _defineProperty(_output, keyFor(2), bottom), _defineProperty(_output, keyFor(3), left), _output);\n\n    return { $merge: output };\n  };\n};\n\nmodule.exports.anyOrderFactory = function (properties) {\n  var delim = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SPACE;\n  return function (tokenStream) {\n    var propertyNames = Object.keys(properties);\n    var values = propertyNames.reduce(function (accum, propertyName) {\n      accum[propertyName] === undefined; // eslint-disable-line\n      return accum;\n    }, {});\n\n    var numParsed = 0;\n    while (numParsed < propertyNames.length && tokenStream.hasTokens()) {\n      if (numParsed) tokenStream.expect(delim);\n\n      var matchedPropertyName = propertyNames.find(function (propertyName) {\n        return values[propertyName] === undefined && tokenStream.matches(properties[propertyName].token);\n      });\n\n      if (!matchedPropertyName) {\n        tokenStream.throw();\n      } else {\n        values[matchedPropertyName] = tokenStream.lastValue;\n      }\n\n      numParsed += 1;\n    }\n\n    tokenStream.expectEmpty();\n\n    propertyNames.forEach(function (propertyName) {\n      if (values[propertyName] === undefined) values[propertyName] = properties[propertyName].default;\n    });\n\n    return { $merge: values };\n  };\n};\n\nmodule.exports.shadowOffsetFactory = function () {\n  return function (tokenStream) {\n    var width = tokenStream.expect(LENGTH);\n    var height = tokenStream.matches(SPACE) ? tokenStream.expect(LENGTH) : width;\n    tokenStream.expectEmpty();\n    return { width: width, height: height };\n  };\n};","module.exports={\n  \"black\": \"#000000\",\n  \"silver\": \"#c0c0c0\",\n  \"gray\": \"#808080\",\n  \"white\": \"#ffffff\",\n  \"maroon\": \"#800000\",\n  \"red\": \"#ff0000\",\n  \"purple\": \"#800080\",\n  \"fuchsia\": \"#ff00ff\",\n  \"green\": \"#008000\",\n  \"lime\": \"#00ff00\",\n  \"olive\": \"#808000\",\n  \"yellow\": \"#ffff00\",\n  \"navy\": \"#000080\",\n  \"blue\": \"#0000ff\",\n  \"teal\": \"#008080\",\n  \"aqua\": \"#00ffff\",\n  \"orange\": \"#ffa500\",\n  \"aliceblue\": \"#f0f8ff\",\n  \"antiquewhite\": \"#faebd7\",\n  \"aquamarine\": \"#7fffd4\",\n  \"azure\": \"#f0ffff\",\n  \"beige\": \"#f5f5dc\",\n  \"bisque\": \"#ffe4c4\",\n  \"blanchedalmond\": \"#ffebcd\",\n  \"blueviolet\": \"#8a2be2\",\n  \"brown\": \"#a52a2a\",\n  \"burlywood\": \"#deb887\",\n  \"cadetblue\": \"#5f9ea0\",\n  \"chartreuse\": \"#7fff00\",\n  \"chocolate\": \"#d2691e\",\n  \"coral\": \"#ff7f50\",\n  \"cornflowerblue\": \"#6495ed\",\n  \"cornsilk\": \"#fff8dc\",\n  \"crimson\": \"#dc143c\",\n  \"darkblue\": \"#00008b\",\n  \"darkcyan\": \"#008b8b\",\n  \"darkgoldenrod\": \"#b8860b\",\n  \"darkgray\": \"#a9a9a9\",\n  \"darkgreen\": \"#006400\",\n  \"darkgrey\": \"#a9a9a9\",\n  \"darkkhaki\": \"#bdb76b\",\n  \"darkmagenta\": \"#8b008b\",\n  \"darkolivegreen\": \"#556b2f\",\n  \"darkorange\": \"#ff8c00\",\n  \"darkorchid\": \"#9932cc\",\n  \"darkred\": \"#8b0000\",\n  \"darksalmon\": \"#e9967a\",\n  \"darkseagreen\": \"#8fbc8f\",\n  \"darkslateblue\": \"#483d8b\",\n  \"darkslategray\": \"#2f4f4f\",\n  \"darkslategrey\": \"#2f4f4f\",\n  \"darkturquoise\": \"#00ced1\",\n  \"darkviolet\": \"#9400d3\",\n  \"deeppink\": \"#ff1493\",\n  \"deepskyblue\": \"#00bfff\",\n  \"dimgray\": \"#696969\",\n  \"dimgrey\": \"#696969\",\n  \"dodgerblue\": \"#1e90ff\",\n  \"firebrick\": \"#b22222\",\n  \"floralwhite\": \"#fffaf0\",\n  \"forestgreen\": \"#228b22\",\n  \"gainsboro\": \"#dcdcdc\",\n  \"ghostwhite\": \"#f8f8ff\",\n  \"gold\": \"#ffd700\",\n  \"goldenrod\": \"#daa520\",\n  \"greenyellow\": \"#adff2f\",\n  \"grey\": \"#808080\",\n  \"honeydew\": \"#f0fff0\",\n  \"hotpink\": \"#ff69b4\",\n  \"indianred\": \"#cd5c5c\",\n  \"indigo\": \"#4b0082\",\n  \"ivory\": \"#fffff0\",\n  \"khaki\": \"#f0e68c\",\n  \"lavender\": \"#e6e6fa\",\n  \"lavenderblush\": \"#fff0f5\",\n  \"lawngreen\": \"#7cfc00\",\n  \"lemonchiffon\": \"#fffacd\",\n  \"lightblue\": \"#add8e6\",\n  \"lightcoral\": \"#f08080\",\n  \"lightcyan\": \"#e0ffff\",\n  \"lightgoldenrodyellow\": \"#fafad2\",\n  \"lightgray\": \"#d3d3d3\",\n  \"lightgreen\": \"#90ee90\",\n  \"lightgrey\": \"#d3d3d3\",\n  \"lightpink\": \"#ffb6c1\",\n  \"lightsalmon\": \"#ffa07a\",\n  \"lightseagreen\": \"#20b2aa\",\n  \"lightskyblue\": \"#87cefa\",\n  \"lightslategray\": \"#778899\",\n  \"lightslategrey\": \"#778899\",\n  \"lightsteelblue\": \"#b0c4de\",\n  \"lightyellow\": \"#ffffe0\",\n  \"limegreen\": \"#32cd32\",\n  \"linen\": \"#faf0e6\",\n  \"mediumaquamarine\": \"#66cdaa\",\n  \"mediumblue\": \"#0000cd\",\n  \"mediumorchid\": \"#ba55d3\",\n  \"mediumpurple\": \"#9370db\",\n  \"mediumseagreen\": \"#3cb371\",\n  \"mediumslateblue\": \"#7b68ee\",\n  \"mediumspringgreen\": \"#00fa9a\",\n  \"mediumturquoise\": \"#48d1cc\",\n  \"mediumvioletred\": \"#c71585\",\n  \"midnightblue\": \"#191970\",\n  \"mintcream\": \"#f5fffa\",\n  \"mistyrose\": \"#ffe4e1\",\n  \"moccasin\": \"#ffe4b5\",\n  \"navajowhite\": \"#ffdead\",\n  \"oldlace\": \"#fdf5e6\",\n  \"olivedrab\": \"#6b8e23\",\n  \"orangered\": \"#ff4500\",\n  \"orchid\": \"#da70d6\",\n  \"palegoldenrod\": \"#eee8aa\",\n  \"palegreen\": \"#98fb98\",\n  \"paleturquoise\": \"#afeeee\",\n  \"palevioletred\": \"#db7093\",\n  \"papayawhip\": \"#ffefd5\",\n  \"peachpuff\": \"#ffdab9\",\n  \"peru\": \"#cd853f\",\n  \"pink\": \"#ffc0cb\",\n  \"plum\": \"#dda0dd\",\n  \"powderblue\": \"#b0e0e6\",\n  \"rosybrown\": \"#bc8f8f\",\n  \"royalblue\": \"#4169e1\",\n  \"saddlebrown\": \"#8b4513\",\n  \"salmon\": \"#fa8072\",\n  \"sandybrown\": \"#f4a460\",\n  \"seagreen\": \"#2e8b57\",\n  \"seashell\": \"#fff5ee\",\n  \"sienna\": \"#a0522d\",\n  \"skyblue\": \"#87ceeb\",\n  \"slateblue\": \"#6a5acd\",\n  \"slategray\": \"#708090\",\n  \"slategrey\": \"#708090\",\n  \"snow\": \"#fffafa\",\n  \"springgreen\": \"#00ff7f\",\n  \"steelblue\": \"#4682b4\",\n  \"tan\": \"#d2b48c\",\n  \"thistle\": \"#d8bfd8\",\n  \"tomato\": \"#ff6347\",\n  \"turquoise\": \"#40e0d0\",\n  \"violet\": \"#ee82ee\",\n  \"wheat\": \"#f5deb3\",\n  \"whitesmoke\": \"#f5f5f5\",\n  \"yellowgreen\": \"#9acd32\",\n  \"rebeccapurple\": \"#663399\"\n}\n","'use strict'\n\nmodule.exports = require('./colors.json')\n","\"use strict\";\n\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n *\n * @typechecks\n */\n\nvar _hyphenPattern = /-(.)/g;\n\n/**\n * Camelcases a hyphenated string, for example:\n *\n *   > camelize('background-color')\n *   < \"backgroundColor\"\n *\n * @param {string} string\n * @return {string}\n */\nfunction camelize(string) {\n  return string.replace(_hyphenPattern, function (_, character) {\n    return character.toUpperCase();\n  });\n}\n\nmodule.exports = camelize;","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n *\n * @typechecks\n */\n\n'use strict';\n\nvar camelize = require('./camelize');\n\nvar msPattern = /^-ms-/;\n\n/**\n * Camelcases a hyphenated CSS property name, for example:\n *\n *   > camelizeStyleName('background-color')\n *   < \"backgroundColor\"\n *   > camelizeStyleName('-moz-transition')\n *   < \"MozTransition\"\n *   > camelizeStyleName('-ms-transition')\n *   < \"msTransition\"\n *\n * As Andi Smith suggests\n * (http://www.andismith.com/blog/2012/02/modernizr-prefixed/), an `-ms` prefix\n * is converted to lowercase `ms`.\n *\n * @param {string} string\n * @return {string}\n */\nfunction camelizeStyleName(string) {\n  return camelize(string.replace(msPattern, 'ms-'));\n}\n\nmodule.exports = camelizeStyleName;","var parse = require('./parse');\nvar walk = require('./walk');\nvar stringify = require('./stringify');\n\nfunction ValueParser(value) {\n    if (this instanceof ValueParser) {\n        this.nodes = parse(value);\n        return this;\n    }\n    return new ValueParser(value);\n}\n\nValueParser.prototype.toString = function () {\n    return Array.isArray(this.nodes) ? stringify(this.nodes) : '';\n};\n\nValueParser.prototype.walk = function (cb, bubble) {\n    walk(this.nodes, cb, bubble);\n    return this;\n};\n\nValueParser.unit = require('./unit');\n\nValueParser.walk = walk;\n\nValueParser.stringify = stringify;\n\nmodule.exports = ValueParser;\n","var openParentheses = '('.charCodeAt(0);\nvar closeParentheses = ')'.charCodeAt(0);\nvar singleQuote = '\\''.charCodeAt(0);\nvar doubleQuote = '\"'.charCodeAt(0);\nvar backslash = '\\\\'.charCodeAt(0);\nvar slash = '/'.charCodeAt(0);\nvar comma = ','.charCodeAt(0);\nvar colon = ':'.charCodeAt(0);\nvar star = '*'.charCodeAt(0);\n\nmodule.exports = function (input) {\n    var tokens = [];\n    var value = input;\n\n    var next, quote, prev, token, escape, escapePos, whitespacePos;\n    var pos = 0;\n    var code = value.charCodeAt(pos);\n    var max = value.length;\n    var stack = [{ nodes: tokens }];\n    var balanced = 0;\n    var parent;\n\n    var name = '';\n    var before = '';\n    var after = '';\n\n    while (pos < max) {\n        // Whitespaces\n        if (code <= 32) {\n            next = pos;\n            do {\n                next += 1;\n                code = value.charCodeAt(next);\n            } while (code <= 32);\n            token = value.slice(pos, next);\n\n            prev = tokens[tokens.length - 1];\n            if (code === closeParentheses && balanced) {\n                after = token;\n            } else if (prev && prev.type === 'div') {\n                prev.after = token;\n            } else if (code === comma || code === colon || code === slash && value.charCodeAt(next + 1) !== star) {\n                before = token;\n            } else {\n                tokens.push({\n                    type: 'space',\n                    sourceIndex: pos,\n                    value: token\n                });\n            }\n\n            pos = next;\n\n        // Quotes\n        } else if (code === singleQuote || code === doubleQuote) {\n            next = pos;\n            quote = code === singleQuote ? '\\'' : '\"';\n            token = {\n                type: 'string',\n                sourceIndex: pos,\n                quote: quote\n            };\n            do {\n                escape = false;\n                next = value.indexOf(quote, next + 1);\n                if (~next) {\n                    escapePos = next;\n                    while (value.charCodeAt(escapePos - 1) === backslash) {\n                        escapePos -= 1;\n                        escape = !escape;\n                    }\n                } else {\n                    value += quote;\n                    next = value.length - 1;\n                    token.unclosed = true;\n                }\n            } while (escape);\n            token.value = value.slice(pos + 1, next);\n\n            tokens.push(token);\n            pos = next + 1;\n            code = value.charCodeAt(pos);\n\n        // Comments\n        } else if (code === slash && value.charCodeAt(pos + 1) === star) {\n            token = {\n                type: 'comment',\n                sourceIndex: pos\n            };\n\n            next = value.indexOf('*/', pos);\n            if (next === -1) {\n                token.unclosed = true;\n                next = value.length;\n            }\n\n            token.value = value.slice(pos + 2, next);\n            tokens.push(token);\n\n            pos = next + 2;\n            code = value.charCodeAt(pos);\n\n        // Dividers\n        } else if (code === slash || code === comma || code === colon) {\n            token = value[pos];\n\n            tokens.push({\n                type: 'div',\n                sourceIndex: pos - before.length,\n                value: token,\n                before: before,\n                after: ''\n            });\n            before = '';\n\n            pos += 1;\n            code = value.charCodeAt(pos);\n\n        // Open parentheses\n        } else if (openParentheses === code) {\n            // Whitespaces after open parentheses\n            next = pos;\n            do {\n                next += 1;\n                code = value.charCodeAt(next);\n            } while (code <= 32);\n            token = {\n                type: 'function',\n                sourceIndex: pos - name.length,\n                value: name,\n                before: value.slice(pos + 1, next)\n            };\n            pos = next;\n\n            if (name === 'url' && code !== singleQuote && code !== doubleQuote) {\n                next -= 1;\n                do {\n                    escape = false;\n                    next = value.indexOf(')', next + 1);\n                    if (~next) {\n                        escapePos = next;\n                        while (value.charCodeAt(escapePos - 1) === backslash) {\n                            escapePos -= 1;\n                            escape = !escape;\n                        }\n                    } else {\n                        value += ')';\n                        next = value.length - 1;\n                        token.unclosed = true;\n                    }\n                } while (escape);\n                // Whitespaces before closed\n                whitespacePos = next;\n                do {\n                    whitespacePos -= 1;\n                    code = value.charCodeAt(whitespacePos);\n                } while (code <= 32);\n                if (pos !== whitespacePos + 1) {\n                    token.nodes = [{\n                        type: 'word',\n                        sourceIndex: pos,\n                        value: value.slice(pos, whitespacePos + 1)\n                    }];\n                } else {\n                    token.nodes = [];\n                }\n                if (token.unclosed && whitespacePos + 1 !== next) {\n                    token.after = '';\n                    token.nodes.push({\n                        type: 'space',\n                        sourceIndex: whitespacePos + 1,\n                        value: value.slice(whitespacePos + 1, next)\n                    });\n                } else {\n                    token.after = value.slice(whitespacePos + 1, next);\n                }\n                pos = next + 1;\n                code = value.charCodeAt(pos);\n                tokens.push(token);\n            } else {\n                balanced += 1;\n                token.after = '';\n                tokens.push(token);\n                stack.push(token);\n                tokens = token.nodes = [];\n                parent = token;\n            }\n            name = '';\n\n        // Close parentheses\n        } else if (closeParentheses === code && balanced) {\n            pos += 1;\n            code = value.charCodeAt(pos);\n\n            parent.after = after;\n            after = '';\n            balanced -= 1;\n            stack.pop();\n            parent = stack[balanced];\n            tokens = parent.nodes;\n\n        // Words\n        } else {\n            next = pos;\n            do {\n                if (code === backslash) {\n                    next += 1;\n                }\n                next += 1;\n                code = value.charCodeAt(next);\n            } while (next < max && !(\n                code <= 32 ||\n                code === singleQuote ||\n                code === doubleQuote ||\n                code === comma ||\n                code === colon ||\n                code === slash ||\n                code === openParentheses ||\n                code === closeParentheses && balanced\n            ));\n            token = value.slice(pos, next);\n\n            if (openParentheses === code) {\n                name = token;\n            } else {\n                tokens.push({\n                    type: 'word',\n                    sourceIndex: pos,\n                    value: token\n                });\n            }\n\n            pos = next;\n        }\n    }\n\n    for (pos = stack.length - 1; pos; pos -= 1) {\n        stack[pos].unclosed = true;\n    }\n\n    return stack[0].nodes;\n};\n","function stringifyNode(node, custom) {\r\n    var type = node.type;\r\n    var value = node.value;\r\n    var buf;\r\n    var customResult;\r\n\r\n    if (custom && (customResult = custom(node)) !== undefined) {\r\n        return customResult;\r\n    } else if (type === 'word' || type === 'space') {\r\n        return value;\r\n    } else if (type === 'string') {\r\n        buf = node.quote || '';\r\n        return buf + value + (node.unclosed ? '' : buf);\r\n    } else if (type === 'comment') {\r\n        return '/*' + value + (node.unclosed ? '' : '*/');\r\n    } else if (type === 'div') {\r\n        return (node.before || '') + value + (node.after || '');\r\n    } else if (Array.isArray(node.nodes)) {\r\n        buf = stringify(node.nodes);\r\n        if (type !== 'function') {\r\n            return buf;\r\n        }\r\n        return value + '(' + (node.before || '') + buf + (node.after || '') + (node.unclosed ? '' : ')');\r\n    }\r\n    return value;\r\n}\r\n\r\nfunction stringify(nodes, custom) {\r\n    var result, i;\r\n\r\n    if (Array.isArray(nodes)) {\r\n        result = '';\r\n        for (i = nodes.length - 1; ~i; i -= 1) {\r\n            result = stringifyNode(nodes[i], custom) + result;\r\n        }\r\n        return result;\r\n    }\r\n    return stringifyNode(nodes, custom);\r\n}\r\n\r\nmodule.exports = stringify;\r\n","var minus = '-'.charCodeAt(0);\nvar plus  = '+'.charCodeAt(0);\nvar dot   = '.'.charCodeAt(0);\n\nmodule.exports = function (value) {\n    var pos = 0;\n    var length = value.length;\n    var dotted = false;\n    var containsNumber = false;\n    var code;\n    var number = '';\n\n    while (pos < length) {\n        code = value.charCodeAt(pos);\n\n        if (code >= 48 && code <= 57) {\n            number += value[pos];\n            containsNumber = true;\n        } else if (code === dot) {\n            if (dotted) {\n                break;\n            }\n            dotted = true;\n            number += value[pos];\n        } else if (code === plus || code === minus) {\n            if (pos !== 0) {\n                break;\n            }\n            number += value[pos];\n        } else {\n            break;\n        }\n\n        pos += 1;\n    }\n\n    return containsNumber ? {\n        number: number,\n        unit: value.slice(pos)\n    } : false;\n};\n","module.exports = function walk(nodes, cb, bubble) {\r\n    var i, max, node, result;\r\n\r\n    for (i = 0, max = nodes.length; i < max; i += 1) {\r\n        node = nodes[i];\r\n        if (!bubble) {\r\n            result = cb(node, i, nodes);\r\n        }\r\n\r\n        if (result !== false && node.type === 'function' && Array.isArray(node.nodes)) {\r\n            walk(node.nodes, cb, bubble);\r\n        }\r\n\r\n        if (bubble) {\r\n            cb(node, i, nodes);\r\n        }\r\n    }\r\n};\r\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n/* eslint-disable no-param-reassign */\nvar parse = require('postcss-value-parser');\nvar camelizeStyleName = require('fbjs/lib/camelizeStyleName');\nvar transforms = require('./transforms');\nvar TokenStream = require('./TokenStream');\n\n// Note if this is wrong, you'll need to change tokenTypes.js too\nvar numberOrLengthRe = /^([+-]?(?:\\d*\\.)?\\d+(?:[Ee][+-]?\\d+)?)(?:px)?$/i;\nvar boolRe = /^true|false$/i;\n\n// Undocumented export\nvar transformRawValue = exports.transformRawValue = function transformRawValue(input) {\n  var value = input.trim();\n\n  var numberMatch = value.match(numberOrLengthRe);\n  if (numberMatch !== null) return Number(numberMatch[1]);\n\n  var boolMatch = input.match(boolRe);\n  if (boolMatch !== null) return boolMatch[0].toLowerCase() === 'true';\n\n  return value;\n};\n\nvar baseTransformShorthandValue = function baseTransformShorthandValue(propName, inputValue) {\n  var ast = parse(inputValue.trim());\n  var tokenStream = new TokenStream(ast.nodes);\n  return transforms[propName](tokenStream);\n};\n\nvar transformShorthandValue = process.env.NODE_ENV === 'production' ? baseTransformShorthandValue : function (propName, inputValue) {\n  try {\n    return baseTransformShorthandValue(propName, inputValue);\n  } catch (e) {\n    throw new Error('Failed to parse declaration \"' + propName + ': ' + inputValue + '\"');\n  }\n};\n\nvar getStylesForProperty = exports.getStylesForProperty = function getStylesForProperty(propName, inputValue, allowShorthand) {\n  var isRawValue = allowShorthand === false || !(propName in transforms);\n  var propValue = isRawValue ? transformRawValue(inputValue) : transformShorthandValue(propName, inputValue.trim());\n\n  return propValue && propValue.$merge ? propValue.$merge : _defineProperty({}, propName, propValue);\n};\n\nvar getPropertyName = exports.getPropertyName = camelizeStyleName;\n\nexports.default = function (rules) {\n  var shorthandBlacklist = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];\n  return rules.reduce(function (accum, rule) {\n    var propertyName = getPropertyName(rule[0]);\n    var value = rule[1];\n    var allowShorthand = shorthandBlacklist.indexOf(propertyName) === -1;\n    return Object.assign(accum, getStylesForProperty(propertyName, value, allowShorthand));\n  }, {});\n};"]}
const css2rn = require('css-to-react-native');
const input = document.getElementById('code');
const result = document.getElementById('result');
const strrf = str => str.trim().replace(/^"/, "'").replace(/",?$/, "'");
const btn = document.querySelector('#go');
btn.addEventListener('click', () => {
const rules = input.value.replace(/\/\*(.|\n)*?\*\//, '').split(';').map(item => item.split(':').map(x => String(x).trim())).filter(x => x && x[0] !== '');
const output = JSON.stringify(css2rn.default(rules), null, 2);
const ok = output.replace(/ \"(.*)\":(.*)\n/g, (n, a, b) => { return ` ${a}: ${strrf(b)},\n`; }).replace(/,,/g, ',');
result.value = ok.substr(1, ok.length - 2).trim().replace(/\n\s+/g, '\n');
});
;}, 0)
{
"name": "requirebin-sketch",
"version": "1.0.0",
"dependencies": {
"css-to-react-native": "2.0.4"
}
}
<!-- contents of this file will be placed inside the <body> -->
<label>CSS</label><br />
<textarea id="code" style="width: 500px" rows=12>
font-size: 12px;
color: red;
</textarea><br />
<button id="go">Parse</button><br /><br />
<textarea id="result" style="width: 500px" rows=12></textarea>
<!-- contents of this file will be placed inside the <head> -->
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment