-
Notifications
You must be signed in to change notification settings - Fork 140
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
Sorting of extended/new attributes #228
Comments
Hey! I can't seem to reproduce this, when I hit "Tidy" in your Play it sorts the class to the expected spot: |
Interesting. There are times when it happens and others when it doesn't. Maybe it's not compiling the new styles, that's why it's defaulting to the first one. Indeed, it seems there are no problems. Sorry for the misunderstanding. By the way, I'm not sure if I can still jump in on this issue, but if not, that's okay. I created an app with SvelteKit + Prettier using the In development mode with The configuration in the .prettierrrc file is as follows:
Do you have any knowledge to tell me if it's possible to apply some kind of configuration to solve this 'problem'? If I run the |
The prettier plugin loads the tailwind config itself — there can be a small delay in when you change the config to when it's picked up when in an IDE setting (should be no more than 10 seconds). This is because we have a cache that keeps the config around based on it's path for about 10 seconds — this significantly speeds up processing so we're not reloading the config for every file — or in the case of languages like Svelte — for every expression in the file. Could that be what you're seeing @giovannialo? The compiled CSS should not have any affect on it at all — only the content of the file you're editing and your config file. |
I have the same issue as @giovannialo but on VSCode. Example, I have a custom class
Running the prettier command line changes that to:
Which I believe is the correct output, because if I change the custom class to a default tw class like |
@hugotox can you provide a reproduction? And are you using pnpm? The vscode extension has known issues with it. |
I'm using npm. Might be an issue with vscode, prettier and monorepos. On a fresh installation of sveltekit, tailwind and shadcn this issue doesn't happen 😭 |
We are also encountering this issue currently and wondering if there is any workaround for now. TailwindCSS extension formatting in VSCode: Prettier plugin with prettier-plugin-tailwindcss: Happens on a SvelteKit project using pnpm. |
@mcmxcdev I just started seeing that today as well. I'm not sure what happened. |
Since the update to tailwind For example these classes will be sorted differently with the same prettier configuration. <div class="xl:px-4 dark:bg-gray-800" /> My on-save prettier will sort it <div class="dark:bg-gray-800 xl:px-4" /> but running <div class="xl:px-4 dark:bg-gray-800" /> This just started to happen with the update to (If you prefer me to open a separate issue for this because of the higher tailwind version, I'll be happy to) |
Installing the pre-release version of the Tailwind CSS IntelliSense extension seems to fix the issue. A button is shown when opened from the VS Code extension panel. |
Can confirm I have the same issue as @theovier describes (xl:... get sorted differently with CLI vs VSCode extension). |
I'm seeing the same issue as @DaLukasDev I've updated the VSCode extension to the pre release, and I'm still getting the issue. |
Switchting to the pre-release version of IntelliSense resolved my issue where eslint with the prettier plugin sorted custom classes differently from vs code Edit: in conjunction with reloading the window after defining them in tailwind.config.ts |
Switching to the pre-release version of IntelliSense didn't work for me |
The IntelliSense plugin needs a VSCode reload in order to get the new Tailwind config. Getting the pre-release only works because you need to reload to get it. It seems unrelated to actually getting the pre-release itself. |
It happens to me too. I use: |
I was able to solve this by setting the default formatter to FWIW - I found the solution by right clicking on the .svelte file and selecting "format document with" and then seeing that Svelte was the default formatter but Prettier was an option. Relevant VSCode settings: // Without this, the official Svelte extension was selected as the formatter.
// But since .prettierrc has the Svelte plugin configured, we can just use Prettier.
"[svelte]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
} .prettierrc {
"useTabs": false,
"tabWidth": 2,
"semi": false,
"singleQuote": true,
"trailingComma": "es5",
"printWidth": 100,
"bracketSameLine": true,
"arrowParens": "always",
"plugins": ["prettier-plugin-svelte", "prettier-plugin-tailwindcss"],
"overrides": [
{
"files": "*.svelte",
"options": {
"parser": "svelte"
}
}
]
} |
@coryvirok |
It should format svelte if you have the prettier-plugin-svelte installed. The only other relevant extension I have is svelte.svelte-vscode which is the default formatter for svelte if you don't override it, (like I did.) If you're using a monorepo, you might need to explicitly set your prettier config. Eg. {
"svelte.enable-ts-plugin": true,
"editor.formatOnSave": true,
"editor.defaultFormatter": "esbenp.prettier-vscode",
"prettier.configPath": "./apps/web/.prettierrc",
"[svelte]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
} |
This is, however, not a solution for Vue, HTML or JS, where Prettier has built-in support for them and |
This might be the missing piece. I removed it from my original config and it caused my setup to complain about Prettier not being able to format Svelte files. "prettier.documentSelectors": ["**/*.svelte"], full workspace config {
"svelte.enable-ts-plugin": true,
"eslint.validate": ["javascript", "typescript", "svelte"],
"editor.formatOnSave": true,
"editor.defaultFormatter": "esbenp.prettier-vscode",
"prettier.configPath": "./apps/web/.prettierrc",
"prettier.documentSelectors": ["**/*.svelte"],
"[svelte]": {
"editor.defaultFormatter": "esbenp.prettier-vscode"
},
"prettier.enableDebugLogs": true,
} .prettierrc {
"useTabs": false,
"tabWidth": 2,
"semi": false,
"singleQuote": true,
"trailingComma": "es5",
"printWidth": 100,
"bracketSameLine": true,
"arrowParens": "always",
"plugins": ["prettier-plugin-svelte", "prettier-plugin-tailwindcss"],
"overrides": [
{
"files": "*.svelte",
"options": {
"parser": "svelte"
}
}
]
} .eslintrc.cjs /** @type { import("eslint").Linter.Config } */
module.exports = {
root: true,
extends: [
'eslint:recommended',
'plugin:@typescript-eslint/recommended',
'plugin:svelte/recommended',
'plugin:svelte/prettier',
'prettier',
],
parser: '@typescript-eslint/parser',
plugins: ['@typescript-eslint'],
parserOptions: {
sourceType: 'module',
ecmaVersion: 2020,
extraFileExtensions: ['.svelte'],
},
env: {
browser: true,
es2017: true,
node: true,
},
overrides: [
{
files: ['*.svelte'],
parser: 'svelte-eslint-parser',
parserOptions: {
parser: '@typescript-eslint/parser',
},
},
{
files: ['src/lib/components/ui/**/*.svelte'],
rules: {
'@typescript-eslint/no-unused-vars': 'warn',
},
},
],
} |
@coryvirok : thank you. This have fixed my issue in vscode. Like you said, the key was in the settings
|
I was experiencing the same issue that was described here: the Prettier CLI formats classes in the correct order while the IDE, WebStorm in my case, does not (putting all custom class in the beginning). For some reason, restarting the IDE resolved the issue and now WebStorm produces the same output as the Prettier CLI. |
Update: After modifying There's probably some aggressive caching going on, either in the IDE itself or in the Prettier plugin. |
I can confirm what @MrOxMasTer says. I have custom classes with const config = {
plugins: [
{
handler({ addVariant }) {
addVariant("nl", '[data-nav-theme="light"] &');
addVariant("nd", '[data-nav-theme="dark"] &');
},
},
],
}; …so I have classes like Versions:
|
for me the issue was in eslintrc.json (i had tailwind as a plugin instead of extends) eslintrc.json {
"extends": [
"next",
"next/core-web-vitals",
"plugin:prettier/recommended",
"prettier"
],
"plugins": ["@typescript-eslint"],
"rules": {
"prettier/prettier": "error"
}
} .prettierrc.json {
"singleQuote": true,
"jsxSingleQuote": false,
"semi": true,
"tabWidth": 2,
"trailingComma": "es5",
"bracketSpacing": true,
"jsxBracketSameLine": false,
"printWidth": 80,
"arrowParens": "always",
"endOfLine": "auto",
"plugins": ["prettier-plugin-tailwindcss"]
} |
What version of
prettier-plugin-tailwindcss
are you using?v0.5.7
What version of Tailwind CSS are you using?
v3.3.5
What version of Node.js are you using?
v18.16.1
What package manager are you using?
npm
What operating system are you using?
Windows
Reproduction URL
https://play.tailwindcss.com/4hYmtn5TfP
Describe your issue
I extended the 'opacity' property, adding a value of 1 as 0.01. For extended/new attributes, the sorting behavior is lost. Such attributes are sorted to the beginning of the classes. Example:
bg-indigo-500 text-white hover:bg-indigo-700/50 active:bg-indigo-700/1
is turning into this:
active:bg-indigo-700/1 bg-indigo-500 text-white hover:bg-indigo-700/50
The text was updated successfully, but these errors were encountered: