123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- 'use strict';
- const docsUrl = require('../util/docsUrl');
- module.exports = {
- meta: {
- docs: {
- description: 'Ensure proper position of the first property in JSX',
- category: 'Stylistic Issues',
- recommended: false,
- url: docsUrl('jsx-first-prop-new-line')
- },
- fixable: 'code',
- messages: {
- propOnNewLine: 'Property should be placed on a new line',
- propOnSameLine: 'Property should be placed on the same line as the component declaration'
- },
- schema: [{
- enum: ['always', 'never', 'multiline', 'multiline-multiprop']
- }]
- },
- create(context) {
- const configuration = context.options[0] || 'multiline-multiprop';
- function isMultilineJSX(jsxNode) {
- return jsxNode.loc.start.line < jsxNode.loc.end.line;
- }
- return {
- JSXOpeningElement(node) {
- if (
- (configuration === 'multiline' && isMultilineJSX(node))
- || (configuration === 'multiline-multiprop' && isMultilineJSX(node) && node.attributes.length > 1)
- || (configuration === 'always')
- ) {
- node.attributes.some((decl) => {
- if (decl.loc.start.line === node.loc.start.line) {
- context.report({
- node: decl,
- messageId: 'propOnNewLine',
- fix(fixer) {
- return fixer.replaceTextRange([node.name.range[1], decl.range[0]], '\n');
- }
- });
- }
- return true;
- });
- } else if (configuration === 'never' && node.attributes.length > 0) {
- const firstNode = node.attributes[0];
- if (node.loc.start.line < firstNode.loc.start.line) {
- context.report({
- node: firstNode,
- messageId: 'propOnSameLine',
- fix(fixer) {
- return fixer.replaceTextRange([node.name.range[1], firstNode.range[0]], ' ');
- }
- });
- }
- }
- }
- };
- }
- };
|