From aa4c33940223a3e49bea96c190bf8f268c1956cc Mon Sep 17 00:00:00 2001 From: Josh Eckhoff Date: Wed, 24 Oct 2018 14:16:53 -0500 Subject: [PATCH 1/2] Use `range[1]` instead of `end`, as it has wider parser support. --- lib/rules/jsx-first-prop-new-line.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/rules/jsx-first-prop-new-line.js b/lib/rules/jsx-first-prop-new-line.js index 24d063b9bf..dddc0cd993 100644 --- a/lib/rules/jsx-first-prop-new-line.js +++ b/lib/rules/jsx-first-prop-new-line.js @@ -45,7 +45,7 @@ module.exports = { node: decl, message: 'Property should be placed on a new line', fix: function(fixer) { - return fixer.replaceTextRange([node.name.end, decl.range[0]], '\n'); + return fixer.replaceTextRange([node.name.range[1], decl.range[0]], '\n'); } }); } @@ -58,7 +58,7 @@ module.exports = { node: firstNode, message: 'Property should be placed on the same line as the component declaration', fix: function(fixer) { - return fixer.replaceTextRange([node.name.end, firstNode.range[0]], ' '); + return fixer.replaceTextRange([node.name.range[1], firstNode.range[0]], ' '); } }); return; From a7cbf409ffae1f3222f6c2a7c1d0844a1d7e46e6 Mon Sep 17 00:00:00 2001 From: Josh Eckhoff Date: Wed, 24 Oct 2018 14:57:02 -0500 Subject: [PATCH 2/2] Add tests around the functionality of a parser without start/end values. --- package.json | 4 +- tests/lib/rules/jsx-first-prop-new-line.js | 81 ++++++++++++++++++++++ 2 files changed, 84 insertions(+), 1 deletion(-) diff --git a/package.json b/package.json index fc29be26d1..5a0c783aef 100644 --- a/package.json +++ b/package.json @@ -37,7 +37,9 @@ "coveralls": "^3.0.1", "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0", "istanbul": "^0.4.5", - "mocha": "^5.2.0" + "mocha": "^5.2.0", + "typescript": "^3.1.3", + "typescript-eslint-parser": "^20.0.0" }, "peerDependencies": { "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0" diff --git a/tests/lib/rules/jsx-first-prop-new-line.js b/tests/lib/rules/jsx-first-prop-new-line.js index 6a1f8b2b0b..6a3531e517 100644 --- a/tests/lib/rules/jsx-first-prop-new-line.js +++ b/tests/lib/rules/jsx-first-prop-new-line.js @@ -129,6 +129,17 @@ ruleTester.run('jsx-first-prop-new-line', rule, { options: ['multiline-multiprop'], parser: 'babel-eslint' }, + { + code: [ + '' + ].join('\n'), + options: ['multiline-multiprop'], + parser: 'typescript-eslint-parser' + }, { code: '', options: ['always'], @@ -167,6 +178,16 @@ ruleTester.run('jsx-first-prop-new-line', rule, { errors: [{message: 'Property should be placed on a new line'}], parser: 'babel-eslint' }, + { + code: '', + output: [ + '' + ].join('\n'), + options: ['always'], + errors: [{message: 'Property should be placed on a new line'}], + parser: 'typescript-eslint-parser' + }, { code: [ '' + ].join('\n'), + output: [ + '' + ].join('\n'), + options: ['always'], + errors: [{message: 'Property should be placed on a new line'}], + parser: 'typescript-eslint-parser' + }, { code: [ '' + ].join('\n'), + output: [ + '' + ].join('\n'), + options: ['never'], + errors: [{message: 'Property should be placed on the same line as the component declaration'}], + parser: 'typescript-eslint-parser' + }, { code: [ '' + ].join('\n'), + output: [ + '' + ].join('\n'), + options: ['multiline'], + errors: [{message: 'Property should be placed on a new line'}], + parser: 'typescript-eslint-parser' + }, { code: [ '' + ].join('\n'), + output: [ + '' + ].join('\n'), + options: ['multiline-multiprop'], + errors: [{message: 'Property should be placed on a new line'}], + parser: 'typescript-eslint-parser' } ] });