Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

babel-plugin-react-svg

Package Overview
Dependencies
Maintainers
1
Versions
18
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

babel-plugin-react-svg - npm Package Compare versions

Comparing version 2.2.0-nightly.58aa6b3c to 3.0.0

LICENSE

5

lib/camelize.js

@@ -8,6 +8,5 @@ "use strict";

exports.namespaceToCamel = namespaceToCamel;
function hyphenToCamel(name) {
return name.replace(/-([a-z])/g, function (g) {
return g[1].toUpperCase();
});
return name.replace(/-([a-z])/g, g => g[1].toUpperCase());
}

@@ -14,0 +13,0 @@

26

lib/css-to-obj.js

@@ -7,15 +7,19 @@ "use strict";

exports.default = cssToObj;
function cssToObj(css) {
var o = {};
var elements = css.split(";");
elements.filter(function (el) {
return !!el;
}).map(function (el) {
var s = el.split(":"),
key = s.shift().trim(),
value = s.join(":").trim();
o[key] = value;
});
let o = {};
if (typeof css !== "undefined") {
let elements = css.split(";");
elements.filter(el => !!el).map(el => {
let s = el.split(":"),
key = s.shift().trim(),
value = s.join(":").trim();
o[key] = value;
});
}
return o;
}
module.exports = exports["default"];
module.exports = exports.default;

@@ -6,17 +6,26 @@ "use strict";

});
exports.default = _default;
exports.default = function (babel) {
var t = babel.types;
var _cssToObj = _interopRequireDefault(require("./css-to-obj"));
var createClass = function createClass(className) {
return t.logicalExpression("||", t.memberExpression(
/* object = */t.identifier("styles"),
/* property = */t.stringLiteral(className),
/* computed = */true), t.stringLiteral(className));
};
var _camelize = require("./camelize");
var attrVisitor = {
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _default(babel) {
const t = babel.types;
const restElement = t.restElement ? t.restElement : t.restProperty;
const createClass = className => t.logicalExpression("||", t.memberExpression(
/* object = */
t.identifier("styles"),
/* property = */
t.stringLiteral(className),
/* computed = */
true), t.stringLiteral(className));
const attrVisitor = {
JSXAttribute(path) {
var name = path.get("name");
var value = path.get("value");
const name = path.get("name");
const value = path.get("value");

@@ -35,39 +44,36 @@ if (name.isJSXNamespacedName()) {

// <tag className="blah blah1"/>
name.replaceWith(t.jSXIdentifier("className"));
// converts
name.replaceWith(t.jSXIdentifier("className")); // converts
// className="foo bar"
// to
// className={(styles["foo"] || "foo") + " " + (styles["bar"] || "bar")}
var classes = value.node.value.split(/\s/);
let classes = value.node.value.split(/\s/);
if (classes.length > 0) {
var expr = createClass(classes[0]);
for (var i = 1; i < classes.length; i++) {
expr = t.binaryExpression("+",
// (props.styles["foo"] || "foo") + " "
t.binaryExpression("+", expr, t.stringLiteral(" ")),
// (props.styles["bar"] || "bar")
let expr = createClass(classes[0]);
for (let i = 1; i < classes.length; i++) {
expr = t.binaryExpression("+", // (props.styles["foo"] || "foo") + " "
t.binaryExpression("+", expr, t.stringLiteral(" ")), // (props.styles["bar"] || "bar")
createClass(classes[i]));
}
value.replaceWith(t.jSXExpressionContainer(expr));
}
}
// converts
} // converts
// <tag style="text-align: center; width: 50px">
// to
// <tag style={{textAlign: 'center', width: '50px'}}>
if (name.node.name === "style") {
var csso = (0, _cssToObj2.default)(value.node.value);
var properties = Object.keys(csso).map(function (prop) {
return t.objectProperty(t.identifier((0, _camelize.hyphenToCamel)(prop)), t.stringLiteral(csso[prop]));
});
let csso = (0, _cssToObj.default)(value.node.value);
let properties = Object.keys(csso).map(prop => t.objectProperty(t.identifier((0, _camelize.hyphenToCamel)(prop)), t.stringLiteral(csso[prop])));
value.replaceWith(t.jSXExpressionContainer(t.objectExpression(properties)));
}
// converts
} // converts
// <svg stroke-width="5" data-x="0" aria-label="foo">
// to
// <svg strokeWidth="5" data-x="0" aria-label="foo">
if (!/^(data-|aria-)/.test(name.node.name)) {

@@ -78,11 +84,9 @@ name.replaceWith(t.jSXIdentifier((0, _camelize.hyphenToCamel)(path.node.name.name)));

}
};
// returns
}; // returns
// export default (props) => ${input_svg_node}
var getExport = function getExport(svg) {
return t.exportDefaultDeclaration(t.arrowFunctionExpression([t.objectPattern([t.objectProperty(t.identifier("styles"), t.assignmentPattern(t.identifier("styles"), t.objectExpression([])), false, true), t.restProperty(t.identifier("props"))])], svg));
};
// converts
const getExport = function (svg) {
return t.exportDefaultDeclaration(t.arrowFunctionExpression([t.objectPattern([t.objectProperty(t.identifier("styles"), t.assignmentPattern(t.identifier("styles"), t.objectExpression([])), false, true), restElement(t.identifier("props"))])], svg));
}; // converts
// <svg>

@@ -92,3 +96,5 @@ // to

// after passing through attributes visitors
var svgVisitor = {
const svgVisitor = {
JSXOpeningElement(path) {

@@ -100,5 +106,4 @@ if (path.node.name.name.toLowerCase() === "svg") {

}
};
// converts
}; // converts
// <svg/>

@@ -109,3 +114,4 @@ // to

// after passing through other visitors
var svgExpressionVisitor = {
const svgExpressionVisitor = {
ExpressionStatement(path) {

@@ -116,5 +122,5 @@ if (!path.get("expression").isJSXElement()) return;

}
};
var programVisitor = {
const programVisitor = {
Program(path) {

@@ -124,17 +130,9 @@ // add import react statement

}
};
return {
visitor: Object.assign({}, programVisitor, svgExpressionVisitor, svgVisitor, attrVisitor)
};
};
}
var _cssToObj = require("./css-to-obj");
var _cssToObj2 = _interopRequireDefault(_cssToObj);
var _camelize = require("./camelize");
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
module.exports = exports["default"];
module.exports = exports.default;
{
"name": "babel-plugin-react-svg",
"version": "2.2.0-nightly.58aa6b3c",
"version": "3.0.0",
"description": "Babel plugin to transform svg to react component",

@@ -18,2 +18,6 @@ "keywords": [

},
"repository": {
"type": "git",
"url": "git+https://github.com/boopathi/react-svg-loader.git"
},
"license": "MIT",

@@ -26,9 +30,9 @@ "author": "boopathi",

"main": "lib/index.js",
"repository": {
"type": "git",
"url": "git+https://github.com/boopathi/react-svg-loader.git"
"peerDependencies": {
"@babel/plugin-syntax-jsx": "^7.2.0"
},
"peerDependencies": {
"babel-plugin-syntax-jsx": "^6.18.0"
}
"engines": {
"node": ">=6"
},
"gitHead": "f99668807b16aff139efbc84c63430349ddc1bb1"
}
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc