Search code examples
eslinteslint-config-airbnb

eslint incorrectly fixing "export x from y" to "exportxfrom y"


I have an index.js which exports a few files/modules in a directory:

export DaysAsTimePeriod from "./DaysAsTimePeriod"
export Money from "./Money"
export NumberOfProducts from "./NumberOfProducts"
export ItemNumber from "./ItemNumber"

running eslint --fix removes whitespace that results in incorrect syntax:

exportDaysAsTimePeriodfrom "./DaysAsTimePeriod"
exportMoneyfrom "./Money"
exportNumberOfProductsfrom "./NumberOfProducts"
exportItemNumberfrom "./ItemNumber"
exportAttachedProducts, {NAME as PRODUCTS_NAME} from "./AttachedProducts"

I can't find the relevant rules/formatter/plugin to help with this

The projects .eslintrc:

Note: I also tried with "import/prefer-default-export": [0, { "includeExports": false }],

{
  "extends": "airbnb",
  "env": {
    "browser": true,
    "mocha": true,
    "node": true
  },
  "allowInlineConfig": false,
  "globals": {
    "expect": true,
    "shallow": true,
    "sinon": true,
    "mount": true,
    "snapshot": true,
    "__USEMOCKS__": true
  },
  "rules": {
    "array-callback-return": 0,
    "arrow-body-style": 0,
    "camelcase": 0,
    "class-methods-use-this": 0,
    "comma-dangle": [2, "never"],
    "func-names": 0,
    "import/extensions": 0,
    "import/no-extraneous-dependencies": 0,
    "import/no-named-as-default-member": 0,
    "import/prefer-default-export": 0,
    "indent": [2, 2],
    "jsx-a11y/img-has-alt": 0,
    "jsx-a11y/no-static-element-interactions": 0,
    "no-alert": 0,
    "no-console": 0,
    "no-underscore-dangle": 0,
    "object-curly-spacing": [2, "never"],
    "prefer-arrow-callback": 0,
    "quote-props": ["error", "consistent-as-needed"],
    "quotes": [2, "double"],
    "react/jsx-closing-bracket-location": [2, "after-props"],
    "react/forbid-prop-types": [2, { "forbid": ["any"] }],
    "react/jsx-curly-spacing": [2, "never"],
    "react/jsx-filename-extension": 0,
    "react/jsx-no-bind": 0,
    "react/jsx-uses-react": 1,
    "react/no-array-index-key": 0,
    "react/prefer-stateless-function": 0,
    "react/react-in-jsx-scope": 0,
    "semi": [2, "never"],
    "space-before-function-paren": ["error", "never"],
    "vars-on-top": 0
  },
  "parser": "babel-eslint",
  "parserOptions": {
    "ecmaVersion": 6,
    "ecmaFeatures": {
      "experimentalObjectRestSpread": true
    }
  },
  "plugins": [
    "class-property"
  ]
}

And from the projects package.json

"eslint": "3.19.0",
"eslint-config-airbnb": "14.1.0",
"eslint-plugin-babel": "4.1.1",
"eslint-plugin-class-property": "1.0.6",
"eslint-plugin-import": "2.2.0",
"eslint-plugin-jsx-a11y": "4.0.0",
"eslint-plugin-react": "6.10.3",

Solution

  • The eslint-friendly way to do imports to specify the {default as <name>}:

    export {default as DaysAsTimePeriod} from "./DaysAsTimePeriod"
    export {default as Money} from "./Money"
    export {default as NumberOfProducts} from "./NumberOfProducts"
    export {default as ItemNumber} from "./ItemNumber"
    

    Why? Even-though both forms are equivalent, the second form is a TC39 stage 1 proposed syntax

    (Credit to Toru Nagashima on eslint gitter for the heads up)