-
Notifications
You must be signed in to change notification settings - Fork 1.2k
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
feat: Support biome.js as a linter / formatter option in the cli #2021
base: main
Are you sure you want to change the base?
Conversation
🦋 Changeset detectedLatest commit: d9f3788 The changes in this PR will be included in the next version bump. This PR includes changesets to release 1 package
Not sure what this means? Click here to learn what changesets are. Click here if you're a maintainer who wants to add another changeset to this PR |
The latest updates on your projects. Learn more about Vercel for Git ↗︎
|
@aidansunbury is attempting to deploy a commit to the t3-oss Team on Vercel. A member of the Team first needs to authorize it. |
I checked it out locally, and from what I can tell, things are working. However, the format:check and format:write commands aren't working for me. Unfortunately, there's no biome format --check, and it's also impossible to specify file extensions to go through, as you can with Prettier. Another thing to consider: do you plan to do anything with the next lint commands inside the package.json file? |
Thanks for catching that! There are now three scripts added when you use biome. Check linting and formatting without applying fixes, apply only safe fixes, and apply unsafe fixes. They should all be working now, and biome only checks js/ts files anyways, so it is not needed to specify the file types. I removed the Also, as a minor refactoring note, I created an |
I thing Biome is cool as only a formatter until |
@TheCukitoDev Biome has three main commands: format, lint, and check (which runs the formatter and linter). I personally pretty much always just use the check command, so that is what I added in this pr, but would you from a dx perspective also prefer to have lint and format commands already included in the package.json? |
I usually only use Biome as a formatter because as I think, has the best addaption to Next.js because it actually lnts really good for Next.js but i think actually in Next.js the only linter with all the features is ESLint. When Biome fully supports Next.js it will be my first option but until then i will use the mixed version. I would like to have the 3 commands in the package.json. It only costs 2 lines of code so it should be a great option |
Hello, i created other PR Request because i dont know how could I add code to this one. I added another option with your Biome implementation and a mixed one that uses ESLint and Biome as I like to use. The PR is the #2025 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This almost looks mergeable, but I think we might want to run biome check --write --unsafe
in the CLI before staging the files, because currently the repo is not in a "tidy" state after init
we also need CI that prevents future regressinos, ensuring the generated app is always formatted, passes linting etc
@juliusmarminge I added a As far as adding the checks to CI, we are running into the issue that a matrix can only generate a max of 256 variations, which adding the additional variable of selecting a formatter puts us over. You can see this limit being reached in 08173ce. In the long run, we need to come up with a new testing strategy which will keep us under the 256 maximum while still allowing more options to be added to the cli and tested. Once this new strategy is implemented, we can add the formatter checks. |
Hey @juliusmarminge, any last modifications needed before getting this merged? I implemented all of the changes you suggested in your review. |
cwd: projectDir, | ||
}); | ||
} else if (biome) { | ||
await execa(pkgManager, ["check:unsafe"], { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
i think even if we can't have a matrix that includes biome we should atleast have 1 app scaffold (perhaps the variant with as much selected as possible? biome+drizle-+auth+trpc+tailwind) to try and surface this as best as possible
Closes #1973
✅ Checklist
Changelog
The CLI now prompts the user to select either eslint/prettier or biome as a formatting and linting option. If eslint/prettier is selected, the app is scaffolded the same way it always is. If biome is selected, files (prettier.config.js, .eslintrc.cjs) and all eslint/prettier related dependencies are no longer included and instead a biome.jsonc file is generated and @biomejs/biome is installed.
Prettier and eslint are enabled by default through cli flags, but a linter selection can now be specified with either an --eslint or --biome flag.
Additionally, the installation of prettier used to be tied to using tailwind css, meaning selecting no for "Will you be using Tailwind CSS for styling?" meant that prettier was not installed. A choice of formatter and a choice of using tailwind css should not be coupled, so now prettier will be installed so long as biome is not selected as a formatter. The 'prettier-plugin-tailwindcss' will only be configured in the prettier config file if tailwind css is selected.
For the biome.jsonc file, I just used the default configuration and added the use-sorted-classes nursery rule. I would love to hear thoughts on what should be in the default config, but making changes to the template file will not impact the changes to the functionality of this feature.
Screenshots
💯