From 6f664058b52d70fdd8707cc16cb843ddae936440 Mon Sep 17 00:00:00 2001 From: Splines <37160523+Splines@users.noreply.github.com> Date: Tue, 19 Dec 2023 22:45:48 +0100 Subject: [PATCH] Init default settings/extensions for VSCode (#569) * Init default settings/extensions for VSCode * Add further settings * Improve "format on save" options Also do not use deprecated flags in new VSCode version. * Remove trailing comma in settings.json * Enable ESLint as formatter --- .vscode/extensions.json | 8 ++++ .vscode/settings.json | 85 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 93 insertions(+) create mode 100644 .vscode/extensions.json create mode 100644 .vscode/settings.json diff --git a/.vscode/extensions.json b/.vscode/extensions.json new file mode 100644 index 000000000..baa13b8bb --- /dev/null +++ b/.vscode/extensions.json @@ -0,0 +1,8 @@ +{ + "recommendations": [ + "shopify.ruby-lsp", + "dbaeumer.vscode-eslint", + "streetsidesoftware.code-spell-checker", + "streetsidesoftware.code-spell-checker-german" + ] +} \ No newline at end of file diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 000000000..b43e16464 --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,85 @@ +{ + ////////////////////////////////////// + // JS (ESLint) + ////////////////////////////////////// + // https://eslint.style/guide/faq#how-to-auto-format-on-save + // https://github.com/microsoft/vscode-eslint#settings-options + "[javascript]": { + "editor.formatOnSave": false, // to avoid formatting twice (ESLint + VSCode) + "editor.defaultFormatter": "dbaeumer.vscode-eslint" + }, + "editor.codeActionsOnSave": { + "source.fixAll.eslint": "explicit" + }, + "eslint.format.enable": true, // use ESLint as formatter + // this disables VSCode built-in formatter (instead we want to use ESLint) + "javascript.validate.enable": false, + ////////////////////////////////////// + // HTML + ////////////////////////////////////// + "[html]": { + "editor.formatOnSave": false // TODO: activate once HTML formatter installed + }, + ////////////////////////////////////// + // Ruby (Rubocop) + ////////////////////////////////////// + "[ruby]": { + "editor.defaultFormatter": "Shopify.ruby-lsp", + "editor.formatOnSave": true + }, + "rubyLsp.formatter": "rubocop", + "rubyLsp.rubyVersionManager": "rbenv", + "rubyLsp.enabledFeatures": { + "codeActions": true, + "diagnostics": true, + "documentHighlights": true, + "documentLink": true, + "documentSymbols": true, + "foldingRanges": true, + "formatting": true, + "hover": true, + "inlayHint": true, + "onTypeFormatting": true, + "selectionRanges": true, + "semanticHighlighting": true, + "completion": true, + "codeLens": true, + "definition": true + }, + "rubyLsp.enableExperimentalFeatures": true, + ////////////////////////////////////// + // Files + ////////////////////////////////////// + "files.exclude": { + "node_modules/": true, + "pdfcomprezzor/": true, + "coverage/": true, + "solr/": true + }, + "files.associations": { + "*.js.erb": "javascript", + "*.html.erb": "html" + }, + ////////////////////////////////////// + // Editor + ////////////////////////////////////// + "editor.wordWrap": "wordWrapColumn", + "editor.wordWrapColumn": 100, // toggle via Alt + Z shortcut + "editor.mouseWheelZoom": true, + "editor.rulers": [ + { + "column": 80, // soft limit + "color": "#e5e5e5" + }, + { + "column": 100, // hard limit + "color": "#c9c9c9" + } + ], + ////////////////////////////////////// + // Spell Checker + ////////////////////////////////////// + "cSpell.words": [ + "turbolinks" + ] +} \ No newline at end of file