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

Error when parsing dynamic attributes expressions #110

Closed
eriandev opened this issue Jul 18, 2020 · 9 comments · Fixed by #119
Closed

Error when parsing dynamic attributes expressions #110

eriandev opened this issue Jul 18, 2020 · 9 comments · Fixed by #119
Labels
bug Something isn't working

Comments

@eriandev
Copy link

I have the following code:

<script>
    import Typewritter from './Typewritter.svelte'
    const texts = ['text1', 'text2']
</script>

<div class="parallax-cover">
    <h1>Random Title</h1>
    <Typewritter {texts} />     <!-- This will be formatted -->
</div>

I use the npm run format command and the result is:

<script>
    import Typewritter from './Typewritter.svelte'
    const texts = ['text1', 'text2']
</script>

<div class="parallax-cover">
    <h1>Random Title</h1>
    <Typewritter texts="texts" />   <!-- The expected result was texts="{texts}" -->
</div>

This changes the expected result, because you are assigning the text string "texts", not the variable texts.

Additional information

"scripts": {
        "start": "sirv public",
        "autobuild": "rollup -c -w",
        "dev": "run-p watch:tailwind autobuild",
        "build": "npm run build:tailwind && rollup -c",
        "format": "prettier --write \"{,!(public)/**/}*.{js,json,svelte}\"",
        "watch:tailwind": "postcss src/tailwind.css -o public/global.css -w",
        "build:tailwind": "cross-env NODE_ENV=production postcss src/tailwind.css -o public/global.css"
    },
"dependencies": {
        "sirv-cli": "^1.0.3"
    },
    "devDependencies": {
        "@fullhuman/postcss-purgecss": "^2.3.0",
        "@rollup/plugin-commonjs": "^14.0.0",
        "@rollup/plugin-node-resolve": "^8.4.0",
        "cross-env": "^7.0.2",
        "cssnano": "^4.1.10",
        "npm-run-all": "^4.1.5",
        "postcss-cli": "^7.1.1",
        "prettier": "^2.0.5",
        "prettier-plugin-svelte": "^1.1.0",
        "rollup": "^2.21.0",
        "rollup-plugin-livereload": "^1.3.0",
        "rollup-plugin-svelte": "^5.2.3",
        "rollup-plugin-terser": "^6.1.0",
        "svelte": "^3.24.0",
        "svelte-preprocess": "^4.0.8",
        "tailwindcss": "^1.5.1"
    }
@eriandev eriandev changed the title Error when parsing the dynamic attributes expressions Error when parsing dynamic attributes expressions Jul 18, 2020
@ehrencrona
Copy link
Contributor

I could not reproduce this behavior. When I try formatting the above code, {texts} is preserved ([email protected] and [email protected]).

@eriandev
Copy link
Author

eriandev commented Aug 9, 2020

Maybe something in my .prettierrc file?

{
    "tabWidth": 4,
    "useTabs": false,
    "semi": false,
    "singleQuote": true,
    "trailingComma": "es5",
    "plugins": ["prettier-plugin-svelte"],
    "svelteSortOrder" : "scripts-markup-styles",
    "svelteStrictMode": true,
    "svelteBracketNewLine": false,
    "svelteAllowShorthand": false
}

issue prettier-svelte-plugin

@jesseskinner
Copy link
Contributor

jesseskinner commented Aug 12, 2020

This took me a while to figure out, but turns out it's due to the option you have in .prettierrc:

{
    "svelteAllowShorthand": false
}

I think you have discovered a bug, as I would expect prettier-plugin-svelte to rewrite the code to avoid using the shorthand when that setting is set to false, rather than turning it into a string attribute:

<script>
    import Typewritter from './Typewritter.svelte'
    const texts = ['text1', 'text2']
</script>

<div class="parallax-cover">
    <h1>Random Title</h1>
    <Typewritter texts="{texts}" />     <!-- I would expect this output -->
</div>

So I think it's just missing the curly braces inside the quotes. But in the meantime, you could set svelteAllowShorthand to true to fix your issue.

@Conduitry Conduitry added the bug Something isn't working label Aug 13, 2020
jesseskinner added a commit to jesseskinner/prettier-plugin-svelte that referenced this issue Aug 18, 2020
jesseskinner added a commit to jesseskinner/prettier-plugin-svelte that referenced this issue Aug 18, 2020
jesseskinner added a commit to jesseskinner/prettier-plugin-svelte that referenced this issue Aug 18, 2020
jesseskinner added a commit to jesseskinner/prettier-plugin-svelte that referenced this issue Aug 18, 2020
@jesseskinner
Copy link
Contributor

I've added a pull request which fixes this issue, #119.

@autoferrit
Copy link

I just updated, and restarted vscode to use this new version, and I am still having this issue. With this file:

<script>
  import List from '../../components/Articles/List.svelte';

  export let articles;
</script>

<svelte:head>
  <title>Articles</title>
</svelte:head>

<h1>Recent articles</h1>

<List {articles} />

The last component, gets formatted as this

<List articles="{articles}" />

.prettierrc.json, I also tried putting the rules in the overrides, but didn't change it.

{
  "plugins": ["prettier-plugin-svelte"],
  "printWidth": 88,
  "semi": true,
  "singleQuote": true,
  "svelteAllowShorthand": true,
  "svelteBracketNewLine": true,
  "svelteSortOrder": "scripts-markup-styles",
  "svelteStrictMode": true,
  "tabWidth": 2,
  "trailingComma": "es5",
  "useTabs": false,
  "overrides": [
    {
      "files": "*.svelte",
      "options": {
        "parser": "svelte",
        "svelteBracketNewLine": true,
        "svelteAllowShorthand": true,
        "singleQuote": true
      }
    }
  ]
}

package.json (relevant parts)

{
  "dependencies": {
    "@fullhuman/postcss-purgecss": "^2.3.0",
    "compression": "^1.7.4",
    "helmet": "^4.1.0",
    "sirv": "^1.0.6"
  },
  "devDependencies": {
    "@babel/core": "^7.11.4",
    "@babel/plugin-syntax-dynamic-import": "^7.8.3",
    "@babel/plugin-transform-runtime": "^7.11.0",
    "@babel/preset-env": "^7.11.0",
    "@babel/runtime": "^7.11.2",
    "@rollup/plugin-babel": "^5.2.0",
    "@rollup/plugin-commonjs": "^15.0.0",
    "@rollup/plugin-json": "^4.1.0",
    "@rollup/plugin-node-resolve": "^9.0.0",
    "@rollup/plugin-replace": "^2.3.3",
    "@tailwindcss/ui": "^0.5.0",
    "@types/compression": "^1.7.0",
    "@types/express": "^4.17.7",
    "@types/marked": "^1.1.0",
    "class-validator": "^0.12.2",
    "cssnano": "^4.1.10",
    "cypress": "^5.0.0",
    "eslint": "^7.7.0",
    "eslint-config-airbnb-base": "^14.2.0",
    "eslint-config-prettier": "^6.11.0",
    "eslint-plugin-cypress": "^2.11.1",
    "eslint-plugin-import": "^2.22.0",
    "eslint-plugin-node": "^11.1.0",
    "eslint-plugin-promise": "^4.2.1",
    "eslint-plugin-svelte3": "^2.7.3",
    "express": "^4.17.1",
    "gray-matter": "^4.0.2",
    "highlight.js": "^10.1.2",
    "husky": "^4.2.5",
    "lint-staged": "^10.2.13",
    "marked": "^1.1.1",
    "npm-run-all": "^4.1.5",
    "postcss-cli": "^7.1.1",
    "postcss-import": "^12.0.1",
    "postcss-load-config": "^2.1.0",
    "postcss-preset-env": "^6.7.0",
    "prettier": "^2.1.1",
    "prettier-plugin-svelte": "^1.2.0",
    "rollup": "^2.26.8",
    "rollup-plugin-svelte": "^6.0.0",
    "rollup-plugin-terser": "^7.0.1",
    "sapper": "^0.28.3",
    "svelte": "^3.24.1",
    "svelte-check": "^1.0.31",
    "svelte-fa": "^2.1.1",
    "svelte-preprocess": "^4.2.0"
  },
}

Perhaps there is some wrong configuration? or I have a conflicting package?
Here are my workspace settings:

{
  "settings": {
    "[svelte]": {
      "editor.defaultFormatter": "svelte.svelte-vscode",
      "editor.tabSize": 2
    },
    "editor.defaultFormatter": "esbenp.prettier-vscode",
    "editor.formatOnSave": true,
    "eslint.enable": true,
    "eslint.validate": ["javascript", "svelte"],
    "prettier.quoteProps": "consistent",
    "prettier.singleQuote": true
  }
}

@jesseskinner
Copy link
Contributor

@autoferrit this is correct, isn't it? svelteStrictMode: true enforces an HTML-compatible syntax.

@dummdidumm
Copy link
Member

I also so nothing wrong with the output. svelteStrictMode: true -> add the ". You pasted the output as <List articles="{articles}" /> which is correct. Before this fix it was <List articles="articles" />.

@autoferrit
Copy link

Ah. So then it is having svelteStrictMode: true that enforces expanding those to not be shorthand. If I change that to false, what are the effects other than what the Readme mentions of self-closed tags, quotes in attributes?

@dummdidumm
Copy link
Member

I updated the docs a little. Yes, it overrules allowShortHand.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
6 participants