Skip to content

Commit

Permalink
fix: vue config should be placed at the end of extends
Browse files Browse the repository at this point in the history
  • Loading branch information
aladdin-add committed May 30, 2023
1 parent 72ffdcd commit d7d71e4
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 13 deletions.
35 changes: 24 additions & 11 deletions lib/init/config-initializer.js
Original file line number Diff line number Diff line change
Expand Up @@ -156,6 +156,7 @@ function processAnswers(answers) {
env: {},
parserOptions: {},
extends: [],
plugins: [],
overrides: []
};

Expand All @@ -174,18 +175,15 @@ function processAnswers(answers) {
config.env[env] = true;
});

// add in library information
if (answers.framework === "react") {
config.plugins = ["react"];
config.extends.push("plugin:react/recommended");
} else if (answers.framework === "vue") {
config.plugins = ["vue"];
config.extends.push("plugin:vue/vue3-essential");
}

// if answers.source == "guide", the ts supports should be in the shared config.
if (answers.typescript && answers.source !== "guide") {
config.parser = "@typescript-eslint/parser";

// .vue files should be parsed by vue-eslint-parser.
if (answers.framework === "vue") {
config.parserOptions.parser = "@typescript-eslint/parser";
} else {
config.parser = "@typescript-eslint/parser";
}

if (Array.isArray(config.plugins)) {
config.plugins.push("@typescript-eslint");
Expand All @@ -209,7 +207,6 @@ function processAnswers(answers) {
}
}


// setup rules based on problems/style enforcement preferences
if (answers.purpose === "problems") {
config.extends.unshift("eslint:recommended");
Expand All @@ -226,12 +223,28 @@ function processAnswers(answers) {
config.extends.push("plugin:@typescript-eslint/recommended");
}

// add in library information
// The configuration of the framework plugins should be placed at the end of extends.
if (answers.framework === "react") {
config.plugins.push("react");
config.extends.push("plugin:react/recommended");
} else if (answers.framework === "vue") {
config.plugins.push("vue");
config.extends.push("plugin:vue/vue3-essential");
}

// normalize extends
if (config.extends.length === 0) {
delete config.extends;
} else if (config.extends.length === 1) {
config.extends = config.extends[0];
}
if (config.overrides.length === 0) {
delete config.overrides;
}
if (config.plugins.length === 0) {
delete config.plugins;
}

ConfigOps.normalizeToStrings(config);
return config;
Expand Down
5 changes: 3 additions & 2 deletions tests/init/config-initializer.js
Original file line number Diff line number Diff line change
Expand Up @@ -207,8 +207,9 @@ describe("configInitializer", () => {
answers.typescript = true;
const config = init.processAnswers(answers);

assert.deepStrictEqual(config.extends, ["eslint:recommended", "plugin:vue/vue3-essential", "plugin:@typescript-eslint/recommended"]);
assert.deepStrictEqual(config.plugins, ["vue", "@typescript-eslint"]);
assert.include(config.parserOptions, { parser: "@typescript-eslint/parser" });
assert.deepStrictEqual(config.extends, ["eslint:recommended", "plugin:@typescript-eslint/recommended", "plugin:vue/vue3-essential"]);
assert.deepStrictEqual(config.plugins, ["@typescript-eslint", "vue"]);
});

it("should extend eslint:recommended", () => {
Expand Down

0 comments on commit d7d71e4

Please sign in to comment.