Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add basic Flat Config setup to README #96

Merged
merged 9 commits into from
Aug 19, 2023

Conversation

Mitsunee
Copy link
Contributor

Adds some basic Flat Config setup instructions.

I tried to keep it as similar as possible to the current configs (with browser+es6 env and using "eslint:recommended" as a base config). I am unsure if impliedStrict is supported in Flat Configs right now, so I omitted that one.

@joshwilsonvu
Copy link
Collaborator

Thank you for suggesting this! Just curious, do you happen to have or know of a repository where the flat configuration is working as described here? It would help me with testing this out, though if not I'm happy to test it myself.

@Mitsunee
Copy link
Contributor Author

Mitsunee commented May 17, 2023

I'll set up a quick vite project to clone for testing and post here.

Edit: Here's the repo: https://github.com/Mitsunee/eslint-solid-flatconfig-test
It has the exact config copied from the README in this PR as well as a .vscode/settings.json file to enable experimental support for Flat Config with the ESLint plugin for vscode/codium. I also included two examples for lint rules in comments in App.jsx

Unrelated: I was also going to ask if the setup I currently just have in the readme could be offered as a separate import (i.e. src/flat.ts assuming the types exist already) once it's tested properly. That would make setup for users a lot simpler.

@Mitsunee
Copy link
Contributor Author

Not sure if you've gotten around to testing my initial proposal yet, but I've been tinkering and researching things a bit more and stumbled upon a promising approach by eslint-plugin-react which seems to allow using the same configs with both the legacy and the newer flat config systems.

I can try apply this same method in this PR (or a new one) if you want, or go with my original idea of adding a separate export such as src/flat.ts (or src/unstable_flat.ts if you prefer) for flat only. Either way I'd love to find a solution as the migration to the new system seems to have reached Stage 3, which includes helping plugin/config authors adopt the new system :)

@joshwilsonvu
Copy link
Collaborator

Thanks for looking into this more, and I appreciate your patience as I haven't had much time to work on this. I like the idea of using the same config for both config systems as much as possible—I get the feeling that "legacy" config is still going to be around for years. To make sure I'm understanding right, to do this we would

  1. create a configs directory with the recommended and typescript configs
  2. change the existing src/index.ts file to reference those configs, with a little manipulation to get them into the right shape

I'd love to see this happen—it feels like a better approach to focus on creating good, shareable flat configs, and then porting the legacy configs to use it under the hood.

I can take this if you want, but I'd appreciate your help in making that happen in this PR. Thanks so much!

@Mitsunee
Copy link
Contributor Author

I agree that it's vital to keep supporting both types of configs for now, especially as ESLint are still at least one major version away from removing support for it and it does take some migration to switch systems.

I'll give this a shot later, just got one question: Setting global variables (previously the "env" key) now uses a separate package which essentially contains a collection of Record<string, true> of all the variables. Would adding this globals package as a dependency be okay, or should I just not include this step in the new flat configs?

@Mitsunee Mitsunee marked this pull request as draft June 10, 2023 17:27
@Mitsunee

This comment was marked as outdated.

@Mitsunee
Copy link
Contributor Author

I should actually read errors my IDE shows, the error I did get was not from ESLint but from TypeScript which also complains about duplicate properties.

Turns out the "files" key is important so .jsx are actually checked. For the legacy configs this requires explicitly targeting the files via the --ext flag or path (like the VSCode Extension seems to be doing for legacy configs, but the eslint cli by default does not):

Screenshot_20230610_211642

This behaviour is the same with the current production version of the legacy configs (in fact I was using the one from npm in the screenshot above) so fixing that is not within the scope of this PR (could be done with overrides using the same "files" key I just added to flat configs).

Questions before merging:

  • Should the plugin apply to .js files or only for .jsx files (Same for ts/tsx)? I currently have it set to work for both file extensions
  • Should the flat configs set global variables (via the globals package as a new dependency)?
  • Should the flat configs work the same as the legacy configs where typescript users use only the typescript one? The alternative would be using both and setting it up to where the typescript config only applies to .ts/.tsx files. (This behaviour could be backported to legacy configs with the overrides key)

@joshwilsonvu
Copy link
Collaborator

I'm happy to defer to precedent for all these if there is one, but I understand it's early days.

  • I would think it's best to do js, jsx, ts, tsx, as I want to cover all common cases and some rules don't require JSX syntax. Main goal is to make it "Just Work" without requiring any fiddling, especially for newcomers to Solid and ESLint.
  • I'm fine dropping globals from the shared configs, and impliedStrict too. That, we can reasonably expect users to set up themselves. We should still include an example in the docs/README that covers targeting browsers.
  • I don't have a strong opinion on this—at first, I wanted to keep consistency with legacy config, but being smart about overrides for TS files matches what users would do anyway. So probably the latter?

@Mitsunee
Copy link
Contributor Author

  • FlatConfig seems to just work™ as is right now, so I'll stick with "**/*.js?(x)" for that then (could still be overriden by the user quite easily with object spread and/or Object.assign anyways, so my personal preference doesn't matter here)
  • impliedStrict seems to not be causing problems right now, should I remove it anyways? I will see about adding a note or example for globals.
  • I'll change that so TS uses both configs then, in favour of better compatibility for people who may be migrating to TS or don't care to use TS everywhere. As for backporting I would prefer to do that in a new PR as it would be a breaking change for legacy config users.

I also noticed that the typescript config of the current release does not actually include the parserOptions, which I accidentally fixed in this PR.

Mitsunee added 3 commits June 12, 2023 13:38
This should make it easier to maintain the configs as changes to the recommended config won't need to be copypasted over to the TS config and it's more immediatly clear where the configs differ.
@Mitsunee Mitsunee marked this pull request as ready for review June 12, 2023 11:52
@joshwilsonvu joshwilsonvu merged commit 72a7ed7 into solidjs-community:main Aug 19, 2023
@joshwilsonvu
Copy link
Collaborator

Thank you very much for your patience—ended up matching the flat configs up with the legacy configs for easier migration to flat ESLint. Just wanted to make sure what we recommend is tested and this is what made the testing work. TS users will need to configure the parser for themselves (since there are multiple options out there) so I left parserOptions out.

Thanks again!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants