Comparing version 0.2.2 to 0.2.3
@@ -6,6 +6,8 @@ 'use strict'; | ||
}); | ||
exports.ex = exports.pc = exports.cm = exports.vmin = exports.mm = exports.inch = exports.vw = exports.vh = exports.pt = exports.rad = exports.em = exports.percent = exports.px = exports.dim = exports.colorFunctions = exports.callable = exports.lessly = exports.parse = undefined; | ||
exports.dimensions = exports.ex = exports.pc = exports.cm = exports.vmin = exports.mm = exports.inch = exports.vw = exports.vh = exports.pt = exports.rad = exports.em = exports.percent = exports.px = exports.dim = exports.colorFunctions = exports.callable = exports.lessly = exports.parse = undefined; | ||
var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); | ||
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; }; | ||
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; | ||
@@ -85,2 +87,4 @@ | ||
function bindParse(func, vars) { | ||
var convert = arguments.length <= 2 || arguments[2] === undefined ? true : arguments[2]; | ||
return function () { | ||
@@ -94,3 +98,8 @@ for (var _len = arguments.length, args = Array(_len), _key2 = 0; _key2 < _len; _key2++) { | ||
}); | ||
var result = func.apply(undefined, _toConsumableArray(finalArgs.map(_parser2.default))).toCSS(); | ||
var result = func.apply(undefined, _toConsumableArray(finalArgs.map(function () { | ||
return convert ? _parser2.default.apply(undefined, arguments) : arguments.length <= 0 ? undefined : arguments[0]; | ||
}))); | ||
if (convert) { | ||
result = result.toCSS(); | ||
} | ||
return isNaN(result) ? result : Number(result); | ||
@@ -110,3 +119,3 @@ }; | ||
return Object.keys(_functions.callable).reduce(function (pointer, key) { | ||
defaulFunction = Object.keys(_functions.callable).reduce(function (pointer, key) { | ||
var func = _functions.callable[key]; | ||
@@ -116,2 +125,10 @@ pointer[key] = bindParse(func, vars); | ||
}, defaulFunction); | ||
defaulFunction = Object.keys(dimensions).reduce(function (pointer, key) { | ||
var func = dimensions[key]; | ||
pointer[key] = bindParse(func, vars, false); | ||
return pointer; | ||
}, defaulFunction); | ||
return defaulFunction; | ||
} | ||
@@ -131,7 +148,7 @@ | ||
function isPlainObj(o) { | ||
return (typeof o === 'undefined' ? 'undefined' : _typeof(o)) == 'object' && o.constructor == Object; | ||
} | ||
function dimension(val, unit) { | ||
if (unit === undefined) { | ||
return op(val); | ||
} | ||
for (var _len2 = arguments.length, args = Array(_len2 > 2 ? _len2 - 2 : 0), _key3 = 2; _key3 < _len2; _key3++) { | ||
@@ -141,2 +158,11 @@ args[_key3 - 2] = arguments[_key3]; | ||
if (isPlainObj(val)) { | ||
return Object.keys(val).reduce(function (pointer, key) { | ||
var subVal = val[key]; | ||
return _extends({}, pointer, _defineProperty({}, key, dimension.apply(undefined, [subVal, unit].concat(args)))); | ||
}, {}); | ||
} | ||
if (unit === undefined) { | ||
return op(val); | ||
} | ||
if (args.length) { | ||
@@ -253,2 +279,6 @@ return op(toOps.apply(undefined, [val, unit].concat(args))); | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lessly.js"],"names":["theme","dimension","value","parse","camelCaseToDash","key","replace","toLowerCase","parseVars","str","vars","keys","Object","sort","a","b","length","reduce","pointer","replacement","_key","dashKey","lessly","finalstr","toCSS","bindParse","func","args","finalArgs","map","String","arg","result","isNaN","Number","callable","defaulFunction","subVars","colorFunctions","module","exports","val","unit","undefined","op","toOps","containsOp","dim","search","trim","join","getUnit","getValue","getArgs","split","slice","val2","dim1","dim2","operate","px","percent","em","rad","pt","vh","vw","inch","mm","vmin","cm","pc","ex"],"mappings":";;;;;;;;;;;QAwDgBA,K,GAAAA,K;QA2BAC,S,GAAAA,S;QAcAC,K,GAAAA,K;;AAjGhB;;;;AAoDA;;AA8BA;;;;;;;;;;;;QAjFQC,K;;AAER;;;;AAGA,SAASC,eAAT,CAAyBC,GAAzB,EAA8B;AAC5B,SAAOA,IAAIC,OAAJ,CAAa,iBAAb,EAAgC,OAAhC,EAA0CC,WAA1C,EAAP;AACD;;AAED;;;AAGA,SAASC,SAAT,CAAmBC,GAAnB,EAAmC;AAAA,MAAXC,IAAW,yDAAJ,EAAI;;AACjC,MAAMC,OAAOC,OAAOD,IAAP,CAAYD,IAAZ,CAAb;AACAC,OAAKE,IAAL,CAAU,UAASC,CAAT,EAAYC,CAAZ,EAAc;AACtB,WAAOA,EAAEC,MAAF,GAAWF,EAAEE,MAApB;AACD,GAFD;AAGA,SAAOL,KAAKM,MAAL,CAAY,UAACC,OAAD,EAAUb,GAAV,EAAkB;AACnC,QAAMc,cAAcT,KAAKL,GAAL,CAApB;AACA,QAAMe,OAAOf,IAAI,CAAJ,MAAW,GAAX,GAAiBA,GAAjB,SAA2BA,GAAxC;AACA,QAAMgB,UAAUjB,gBAAgBgB,IAAhB,CAAhB;AACA,QAAIC,YAAYD,IAAhB,EAAsB;AACpBF,gBAAUA,QAAQZ,OAAR,CAAgBe,OAAhB,EAAyBF,WAAzB,CAAV;AACD;;AAED,WAAOD,QAAQZ,OAAR,CAAgBc,IAAhB,EAAsBD,WAAtB,CAAP;AACD,GATM,EASJV,GATI,CAAP;AAUD;;AAED;;;AAGA,SAASa,MAAT,CAAgBb,GAAhB,EAAgC;AAAA,MAAXC,IAAW,yDAAJ,EAAI;;AAC9B,MAAMa,WAAWf,UAAUC,GAAV,EAAeC,IAAf,CAAjB;AACA,SAAO,sBAAMa,QAAN,EAAgBC,KAAhB,EAAP;AACD;;kBAEcF,M;QACPA,M,GAAAA,M;;AAER;;AAEA;;AACA,SAASG,SAAT,CAAmBC,IAAnB,EAAyBhB,IAAzB,EAA+B;AAC7B,SAAO,YAAa;AAAA,sCAATiB,IAAS;AAATA,UAAS;AAAA;;AAClB,QAAMC,YAAYD,KAAKE,GAAL,CAAS;AAAA,aAAOrB,UAAUsB,OAAOC,GAAP,CAAV,EAAuBrB,IAAvB,CAAP;AAAA,KAAT,CAAlB;AACA,QAAMsB,SAASN,yCAAQE,UAAUC,GAAV,kBAAR,GAA8BL,KAA9B,EAAf;AACA,WAAOS,MAAMD,MAAN,IAAgBA,MAAhB,GAAyBE,OAAOF,MAAP,CAAhC;AACD,GAJD;AAKD;;QAIOG,Q;AAED,SAASnC,KAAT,GAA0B;AAAA,MAAXU,IAAW,yDAAJ,EAAI;;AAC/B,MAAM0B,iBAAiB,SAAjBA,cAAiB,CAAC3B,GAAD,EAAuB;AAAA,QAAjB4B,OAAiB,yDAAP,EAAO;;AAC5C,WAAOf,OAAOb,GAAP,eAAgBC,IAAhB,EAAyB2B,OAAzB,EAAP;AACD,GAFD;;AAIA,SAAOzB,OAAOD,IAAP,sBAAsBM,MAAtB,CAA6B,UAACC,OAAD,EAAUb,GAAV,EAAkB;AACpD,QAAMqB,OAAO,oBAASrB,GAAT,CAAb;AACAa,YAAQb,GAAR,IAAeoB,UAAUC,IAAV,EAAgBhB,IAAhB,CAAf;AACA,WAAOQ,OAAP;AACD,GAJM,EAIJkB,cAJI,CAAP;AAKD;;AAED,IAAME,iBAAiB1B,OAAOD,IAAP,sBAAsBM,MAAtB,CAA6B,UAACC,OAAD,EAAUb,GAAV,EAAkB;AACpE,MAAMqB,OAAO,oBAASrB,GAAT,CAAb;AACA,sBACKa,OADL,sBAEGb,GAFH,EAESoB,UAAUC,IAAV,CAFT;AAID,CANsB,EAMpB,EANoB,CAAvB;;QAQQY,c,GAAAA,c;;;AAER,KAAI,IAAIjC,GAAR,IAAeiC,cAAf,EAA+B;AAC7BC,SAAOC,OAAP,CAAenC,GAAf,IAAsBiC,eAAejC,GAAf,CAAtB;AACD;;AAGM,SAASJ,SAAT,CAAmBwC,GAAnB,EAAwBC,IAAxB,EAAuC;AAC5C,MAAIA,SAASC,SAAb,EAAwB;AACtB,WAAOC,GAAGH,GAAH,CAAP;AACD;;AAH2C,qCAANd,IAAM;AAANA,QAAM;AAAA;;AAI5C,MAAIA,KAAKX,MAAT,EAAiB;AACf,WAAO4B,GAAGC,wBAAMJ,GAAN,EAAWC,IAAX,SAAoBf,IAApB,EAAH,CAAP;AACD;AACD,MAAImB,WAAWL,GAAX,KAAmBK,WAAWJ,IAAX,CAAvB,EAAyC;AACvC,WAAOE,GAAGC,MAAMJ,GAAN,EAAWC,IAAX,CAAH,CAAP;AACD;AACD,MAAMK,MAAM,wBAAcN,GAAd,EAAmBC,IAAnB,CAAZ;AACA,SAAOK,IAAIvB,KAAJ,EAAP;AACD;;AAEM,SAAStB,KAAT,CAAeuC,GAAf,EAAoB;AACzB,MAAMM,MAAM,wBAAcN,GAAd,EAAmBC,IAAnB,CAAZ;AACA,SAAOR,OAAOa,IAAIvB,KAAJ,EAAP,CAAP;AACD;;AAED,SAASsB,UAAT,CAAoBL,GAApB,EAAyB;AACvB,SAAOA,IAAIO,MAAJ,IAAcP,IAAIO,MAAJ,CAAW,YAAX,IAA2B,CAAC,CAAjD;AACD;;AAED,SAASH,KAAT,GAAwB;AAAA,qCAANlB,IAAM;AAANA,QAAM;AAAA;;AACtB,SAAOA,KAAKE,GAAL,CAAS;AAAA,WAAOE,IAAIkB,IAAJ,GAAWlB,IAAIkB,IAAJ,EAAX,GAAwBlB,GAA/B;AAAA,GAAT,EAA6CmB,IAA7C,CAAkD,GAAlD,CAAP;AACD;;AAED,SAASC,OAAT,CAAiB1C,GAAjB,EAAsB;AACpB,SAAOA,IAAIH,OAAJ,CAAY,WAAZ,EAAyB,EAAzB,CAAP;AACD;;AAED,SAAS8C,QAAT,CAAkB3C,GAAlB,EAAuB;AACrB,SAAOA,IAAIH,OAAJ,CAAY,UAAZ,EAAwB,EAAxB,CAAP;AACD;;AAED,SAAS+C,OAAT,CAAiB5C,GAAjB,EAAsB;AACpB,SAAO,CAAC2C,SAAS3C,GAAT,CAAD,EAAgB0C,QAAQ1C,GAAR,CAAhB,CAAP;AACD;;AAED,SAASmC,EAAT,CAAYH,GAAZ,EAAiB;AAAA,mBACSA,IAAIa,KAAJ,CAAU,GAAV,CADT;;AAAA;;AAAA,MACVtB,MADU;;AAAA,MACCL,IADD;;AAEf,MAAIA,KAAKX,MAAL,GAAc,CAAlB,EAAqB;AACnB,QAAM+B,OAAM,wBAAcf,MAAd,CAAZ;AACA,WAAOe,KAAIvB,KAAJ,EAAP;AACD;AACDQ,oGAA0BqB,QAAQrB,MAAR,CAA1B;AACA,SAAML,KAAKX,MAAL,IAAe,CAArB,EAAwB;AAAA,sBACHW,KAAK4B,KAAL,CAAW,CAAX,EAAc,CAAd,CADG;;AAAA;;AAAA,QACfX,GADe;AAAA,QACXY,IADW;;AAEtB7B,WAAOA,KAAK4B,KAAL,CAAW,CAAX,CAAP;AACA,QAAME,OAAOzB,MAAb;AACA,QAAM0B,gGAAwBL,QAAQG,IAAR,CAAxB,MAAN;AACAxB,aAASyB,KAAKE,OAAL,CAAa,EAAb,EAAiBf,GAAjB,EAAqBc,IAArB,CAAT;AACD;AACD,SAAO1B,OAAOR,KAAP,EAAP;AACD;;AAEM,IAAMuB,oBAAM9C,SAAZ;AACA,IAAM2D,kBAAK,SAALA,EAAK;AAAA,SAAO3D,UAAUwC,GAAV,EAAe,IAAf,CAAP;AAAA,CAAX;AACA,IAAMoB,4BAAU,SAAVA,OAAU;AAAA,SAAO5D,UAAUwC,GAAV,EAAe,GAAf,CAAP;AAAA,CAAhB;AACA,IAAMqB,kBAAK,SAALA,EAAK;AAAA,SAAO7D,UAAUwC,GAAV,EAAe,IAAf,CAAP;AAAA,CAAX;AACA,IAAMsB,oBAAM,SAANA,GAAM;AAAA,SAAO9D,UAAUwC,GAAV,EAAe,KAAf,CAAP;AAAA,CAAZ;AACA,IAAMuB,kBAAK,SAALA,EAAK;AAAA,SAAO/D,UAAUwC,GAAV,EAAe,IAAf,CAAP;AAAA,CAAX;AACA,IAAMwB,kBAAK,SAALA,EAAK;AAAA,SAAOhE,UAAUwC,GAAV,EAAe,IAAf,CAAP;AAAA,CAAX;AACA,IAAMyB,kBAAK,SAALA,EAAK;AAAA,SAAOjE,UAAUwC,GAAV,EAAe,IAAf,CAAP;AAAA,CAAX;AACA,IAAM0B,sBAAO,SAAPA,IAAO;AAAA,SAAOlE,UAAUwC,GAAV,EAAe,IAAf,CAAP;AAAA,CAAb;AACA,IAAM2B,kBAAK,SAALA,EAAK;AAAA,SAAOnE,UAAUwC,GAAV,EAAe,IAAf,CAAP;AAAA,CAAX;AACA,IAAM4B,sBAAO,SAAPA,IAAO;AAAA,SAAOpE,UAAUwC,GAAV,EAAe,MAAf,CAAP;AAAA,CAAb;AACA,IAAM6B,kBAAK,SAALA,EAAK;AAAA,SAAOrE,UAAUwC,GAAV,EAAe,IAAf,CAAP;AAAA,CAAX;AACA,IAAM8B,kBAAK,SAALA,EAAK;AAAA,SAAOtE,UAAUwC,GAAV,EAAe,IAAf,CAAP;AAAA,CAAX;AACA,IAAM+B,kBAAK,SAALA,EAAK;AAAA,SAAOvE,UAAUwC,GAAV,EAAe,IAAf,CAAP;AAAA,CAAX","file":"lessly.js","sourcesContent":["import parse from './parser/parser'\nexport {parse};\n\n/*\n  Converts camelCase to camel-case\n */\nfunction camelCaseToDash(key) {\n  return key.replace( /([a-z])([A-Z])/g, '$1-$2' ).toLowerCase();\n}\n\n/*\n Parses @var with {var: 'value'}\n */\nfunction parseVars(str, vars = {}) {\n  const keys = Object.keys(vars);\n  keys.sort(function(a, b){\n    return b.length - a.length;\n  });\n  return keys.reduce((pointer, key) => {\n    const replacement = vars[key];\n    const _key = key[0] === '@' ? key : `@${key}`;\n    const dashKey = camelCaseToDash(_key);\n    if (dashKey !== _key) {\n      pointer = pointer.replace(dashKey, replacement);\n    }\n\n    return pointer.replace(_key, replacement);\n  }, str);\n}\n\n/*\n  Parses less entity string\n */\nfunction lessly(str, vars = {}) {\n  const finalstr = parseVars(str, vars);\n  return parse(finalstr).toCSS();\n};\n\nexport default lessly;\nexport {lessly};\n\n// export functions\n\n// parse function args so we dont need to expose Color Node\nfunction bindParse(func, vars) {\n  return (...args) => {\n    const finalArgs = args.map(arg => parseVars(String(arg), vars));\n    const result = func(...finalArgs.map(parse)).toCSS();\n    return isNaN(result) ? result : Number(result);\n  };\n}\n\nimport {callable} from './functions';\n\nexport {callable};\n\nexport function theme(vars = {}) {\n  const defaulFunction = (str, subVars = {}) => {\n    return lessly(str, {...vars, ...subVars});\n  };\n\n  return Object.keys(callable).reduce((pointer, key) => {\n    const func = callable[key];\n    pointer[key] = bindParse(func, vars);\n    return pointer;\n  }, defaulFunction);\n}\n\nconst colorFunctions = Object.keys(callable).reduce((pointer, key) => {\n  const func = callable[key];\n  return {\n    ...pointer,\n    [key]: bindParse(func)\n  };\n}, {});\n\nexport {colorFunctions};\n\nfor(let key in colorFunctions) {\n  module.exports[key] = colorFunctions[key];\n}\n\nimport Dimension from './tree/dimension';\nexport function dimension(val, unit, ...args) {\n  if (unit === undefined) {\n    return op(val);\n  }\n  if (args.length) {\n    return op(toOps(val, unit, ...args));\n  }\n  if (containsOp(val) || containsOp(unit)) {\n    return op(toOps(val, unit));\n  }\n  const dim = new Dimension(val, unit);\n  return dim.toCSS();\n}\n\nexport function value(val) {\n  const dim = new Dimension(val, unit);\n  return Number(dim.toCSS());\n}\n\nfunction containsOp(val) {\n  return val.search && val.search(/[\\+\\*\\-\\/]/) > -1;\n}\n\nfunction toOps(...args) {\n  return args.map(arg => arg.trim ? arg.trim() : arg).join(' ');\n}\n\nfunction getUnit(str) {\n  return str.replace(/[0-9\\s]/gi, '');\n}\n\nfunction getValue(str) {\n  return str.replace(/[^0-9]/gi, '');\n}\n\nfunction getArgs(str) {\n  return [getValue(str), getUnit(str)];\n}\n\nfunction op(val) {\n  let [result, ...args] = val.split(' ');\n  if (args.length < 2) {\n    const dim = new Dimension(result);\n    return dim.toCSS();\n  }\n  result = new Dimension(...getArgs(result));\n  while(args.length >= 2) {\n    const [op, val2] = args.slice(0, 2);\n    args = args.slice(2);\n    const dim1 = result;\n    const dim2 = new Dimension(...getArgs(val2));\n    result = dim1.operate({}, op, dim2);\n  }\n  return result.toCSS();\n}\n\nexport const dim = dimension;\nexport const px = val => dimension(val, 'px');\nexport const percent = val => dimension(val, '%');\nexport const em = val => dimension(val, 'em');\nexport const rad = val => dimension(val, 'rad');\nexport const pt = val => dimension(val, 'pt');\nexport const vh = val => dimension(val, 'vh');\nexport const vw = val => dimension(val, 'vw');\nexport const inch = val => dimension(val, 'in');\nexport const mm = val => dimension(val, 'mm');\nexport const vmin = val => dimension(val, 'vmin');\nexport const cm = val => dimension(val, 'cm');\nexport const pc = val => dimension(val, 'pc');\nexport const ex = val => dimension(val, 'ex');\n"]} | ||
var dimensions = exports.dimensions = { | ||
px: px, percent: percent, inch: inch, mm: mm, vh: vh, vw: vw, rad: rad, pt: pt, cm: cm, vmin: vmin, pc: pc, ex: ex, dimension: dimension, dim: dim | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/lessly.js"],"names":["theme","dimension","value","parse","camelCaseToDash","key","replace","toLowerCase","parseVars","str","vars","keys","Object","sort","a","b","length","reduce","pointer","replacement","_key","dashKey","lessly","finalstr","toCSS","bindParse","func","convert","args","finalArgs","map","String","arg","result","isNaN","Number","callable","defaulFunction","subVars","dimensions","colorFunctions","module","exports","isPlainObj","o","constructor","val","unit","subVal","undefined","op","toOps","containsOp","dim","search","trim","join","getUnit","getValue","getArgs","split","slice","val2","dim1","dim2","operate","px","percent","em","rad","pt","vh","vw","inch","mm","vmin","cm","pc","ex"],"mappings":"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","file":"lessly.js","sourcesContent":["import parse from './parser/parser'\nexport {parse};\n\n/*\n  Converts camelCase to camel-case\n */\nfunction camelCaseToDash(key) {\n  return key.replace( /([a-z])([A-Z])/g, '$1-$2' ).toLowerCase();\n}\n\n/*\n Parses @var with {var: 'value'}\n */\nfunction parseVars(str, vars = {}) {\n  const keys = Object.keys(vars);\n  keys.sort(function(a, b){\n    return b.length - a.length;\n  });\n  return keys.reduce((pointer, key) => {\n    const replacement = vars[key];\n    const _key = key[0] === '@' ? key : `@${key}`;\n    const dashKey = camelCaseToDash(_key);\n    if (dashKey !== _key) {\n      pointer = pointer.replace(dashKey, replacement);\n    }\n\n    return pointer.replace(_key, replacement);\n  }, str);\n}\n\n/*\n  Parses less entity string\n */\nfunction lessly(str, vars = {}) {\n  const finalstr = parseVars(str, vars);\n  return parse(finalstr).toCSS();\n};\n\nexport default lessly;\nexport {lessly};\n\n// export functions\n\n// parse function args so we dont need to expose Color Node\nfunction bindParse(func, vars, convert = true) {\n  return (...args) => {\n    const finalArgs = args.map(arg => parseVars(String(arg), vars));\n    let result = func(...finalArgs.map((...argSet) => convert ? parse(...argSet) : argSet[0]));\n    if (convert) {\n      result = result.toCSS();\n    }\n    return isNaN(result) ? result : Number(result);\n  };\n}\n\nimport {callable} from './functions';\n\nexport {callable};\n\nexport function theme(vars = {}) {\n  let defaulFunction = (str, subVars = {}) => {\n    return lessly(str, {...vars, ...subVars});\n  };\n\n  defaulFunction = Object.keys(callable).reduce((pointer, key) => {\n    const func = callable[key];\n    pointer[key] = bindParse(func, vars);\n    return pointer;\n  }, defaulFunction);\n\n  defaulFunction = Object.keys(dimensions).reduce((pointer, key) => {\n    const func = dimensions[key];\n    pointer[key] = bindParse(func, vars, false);\n    return pointer;\n  }, defaulFunction);\n\n  return defaulFunction;\n}\n\nconst colorFunctions = Object.keys(callable).reduce((pointer, key) => {\n  const func = callable[key];\n  return {\n    ...pointer,\n    [key]: bindParse(func)\n  };\n}, {});\n\nexport {colorFunctions};\n\nfor(let key in colorFunctions) {\n  module.exports[key] = colorFunctions[key];\n}\n\nfunction isPlainObj(o) {\n  return typeof o == 'object' && o.constructor == Object;\n}\n\nimport Dimension from './tree/dimension';\nexport function dimension(val, unit, ...args) {\n  if (isPlainObj(val)) {\n    return Object.keys(val).reduce(function(pointer, key){\n      const subVal = val[key];\n      return {\n        ...pointer,\n        [key]: dimension(subVal, unit, ...args)\n      };\n    }, {});\n  }\n  if (unit === undefined) {\n    return op(val);\n  }\n  if (args.length) {\n    return op(toOps(val, unit, ...args));\n  }\n  if (containsOp(val) || containsOp(unit)) {\n    return op(toOps(val, unit));\n  }\n  const dim = new Dimension(val, unit);\n  return dim.toCSS();\n}\n\nexport function value(val) {\n  const dim = new Dimension(val, unit);\n  return Number(dim.toCSS());\n}\n\nfunction containsOp(val) {\n  return val.search && val.search(/[\\+\\*\\-\\/]/) > -1;\n}\n\nfunction toOps(...args) {\n  return args.map(arg => arg.trim ? arg.trim() : arg).join(' ');\n}\n\nfunction getUnit(str) {\n  return str.replace(/[0-9\\s]/gi, '');\n}\n\nfunction getValue(str) {\n  return str.replace(/[^0-9]/gi, '');\n}\n\nfunction getArgs(str) {\n  return [getValue(str), getUnit(str)];\n}\n\nfunction op(val) {\n  let [result, ...args] = val.split(' ');\n  if (args.length < 2) {\n    const dim = new Dimension(result);\n    return dim.toCSS();\n  }\n  result = new Dimension(...getArgs(result));\n  while(args.length >= 2) {\n    const [op, val2] = args.slice(0, 2);\n    args = args.slice(2);\n    const dim1 = result;\n    const dim2 = new Dimension(...getArgs(val2));\n    result = dim1.operate({}, op, dim2);\n  }\n  return result.toCSS();\n}\n\nexport const dim = dimension;\nexport const px = val => dimension(val, 'px');\nexport const percent = val => dimension(val, '%');\nexport const em = val => dimension(val, 'em');\nexport const rad = val => dimension(val, 'rad');\nexport const pt = val => dimension(val, 'pt');\nexport const vh = val => dimension(val, 'vh');\nexport const vw = val => dimension(val, 'vw');\nexport const inch = val => dimension(val, 'in');\nexport const mm = val => dimension(val, 'mm');\nexport const vmin = val => dimension(val, 'vmin');\nexport const cm = val => dimension(val, 'cm');\nexport const pc = val => dimension(val, 'pc');\nexport const ex = val => dimension(val, 'ex');\n\nexport const dimensions = {\n  px, percent, inch, mm, vh, vw, rad, pt, cm, vmin, pc, ex, dimension, dim\n};\n"]} |
{ | ||
"name": "lessly", | ||
"version": "0.2.2", | ||
"version": "0.2.3", | ||
"description": "Less functions without less", | ||
@@ -5,0 +5,0 @@ "main": "lib/lessly.js", |
@@ -106,2 +106,20 @@ # [Less][] Standalone Functions [![Build Status](https://travis-ci.org/gtg092x/lessly.svg?branch=master)](https://travis-ci.org/gtg092x/lessly) | ||
We'll also recurse any object and apply operations to child values | ||
```js | ||
import {dimension} from 'lessly'; // or dim for short | ||
dimension({ | ||
myRule: 10 | ||
}, 'px'); | ||
// outputs {myRule: '10px'} | ||
dimension({ | ||
myRule: 10 | ||
}, '+ 10px'); | ||
// outputs {myRule: '20px'} | ||
``` | ||
There's also handy shortcuts for [every css unit](http://www.tutorialspoint.com/css/css_measurement_units.htm). | ||
@@ -108,0 +126,0 @@ |
@@ -45,6 +45,9 @@ import parse from './parser/parser' | ||
// parse function args so we dont need to expose Color Node | ||
function bindParse(func, vars) { | ||
function bindParse(func, vars, convert = true) { | ||
return (...args) => { | ||
const finalArgs = args.map(arg => parseVars(String(arg), vars)); | ||
const result = func(...finalArgs.map(parse)).toCSS(); | ||
let result = func(...finalArgs.map((...argSet) => convert ? parse(...argSet) : argSet[0])); | ||
if (convert) { | ||
result = result.toCSS(); | ||
} | ||
return isNaN(result) ? result : Number(result); | ||
@@ -59,7 +62,7 @@ }; | ||
export function theme(vars = {}) { | ||
const defaulFunction = (str, subVars = {}) => { | ||
let defaulFunction = (str, subVars = {}) => { | ||
return lessly(str, {...vars, ...subVars}); | ||
}; | ||
return Object.keys(callable).reduce((pointer, key) => { | ||
defaulFunction = Object.keys(callable).reduce((pointer, key) => { | ||
const func = callable[key]; | ||
@@ -69,2 +72,10 @@ pointer[key] = bindParse(func, vars); | ||
}, defaulFunction); | ||
defaulFunction = Object.keys(dimensions).reduce((pointer, key) => { | ||
const func = dimensions[key]; | ||
pointer[key] = bindParse(func, vars, false); | ||
return pointer; | ||
}, defaulFunction); | ||
return defaulFunction; | ||
} | ||
@@ -86,4 +97,17 @@ | ||
function isPlainObj(o) { | ||
return typeof o == 'object' && o.constructor == Object; | ||
} | ||
import Dimension from './tree/dimension'; | ||
export function dimension(val, unit, ...args) { | ||
if (isPlainObj(val)) { | ||
return Object.keys(val).reduce(function(pointer, key){ | ||
const subVal = val[key]; | ||
return { | ||
...pointer, | ||
[key]: dimension(subVal, unit, ...args) | ||
}; | ||
}, {}); | ||
} | ||
if (unit === undefined) { | ||
@@ -158,1 +182,5 @@ return op(val); | ||
export const ex = val => dimension(val, 'ex'); | ||
export const dimensions = { | ||
px, percent, inch, mm, vh, vw, rad, pt, cm, vmin, pc, ex, dimension, dim | ||
}; |
@@ -84,3 +84,23 @@ import chai from 'chai'; | ||
assert.deepEqual(dimension({ | ||
'rule1': 10, | ||
'rule2': 20 | ||
}, ' * 10%'), { | ||
rule1: '100%', | ||
rule2: '200%', | ||
}); | ||
assert.deepEqual(px({ | ||
'rule1': 10, | ||
'rule2': { | ||
subrule: 20 | ||
} | ||
}), { | ||
rule1: '10px', | ||
rule2: { | ||
subrule: '20px' | ||
} | ||
}); | ||
const units = { | ||
@@ -97,3 +117,8 @@ px, '%': percent, 'in': inch, mm, vh, vw, rad, pt, cm, vmin, pc, ex | ||
it('supports dimension theme', function() { | ||
let lesslyTheme = theme({mySize: 10}); | ||
assert.equal(lesslyTheme.px('@my-size'), '10px'); | ||
}); | ||
}); | ||
} |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
346192
3816
168