made with requirebin
Created
November 16, 2017 18:49
-
-
Save birkir/d78ac6067c85c27e56a8fc4d60604f0f to your computer and use it in GitHub Desktop.
requirebin sketch
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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'); | |
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
{ | |
"name": "requirebin-sketch", | |
"version": "1.0.0", | |
"dependencies": { | |
"css-to-react-native": "2.0.4" | |
} | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!-- 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> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!-- 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