prettier/CHANGELOG.unreleased.md

3.8 KiB

  • CLI: Honor stdin-filepath when outputting error messages.

  • Markdown: Do not align table contents if it exceeds the print width and --prose-wrap never is set ([#5701] by [@chenshuai2144])

    The aligned table is less readable than the compact one if it's particularly long and the word wrapping is not enabled in the editor so we now print them as compact tables in these situations.

    <!-- Input -->
    | Property | Description | Type | Default |
    | -------- | ----------- | ---- | ------- |
    | bordered | Toggles rendering of the border around the list | boolean | false |
    | itemLayout | The layout of list, default is `horizontal`, If a vertical list is desired, set the itemLayout property to `vertical` | string | - |
    
    <!-- Output (Prettier stable, --prose-wrap never) -->
    | Property   | Description                                                                                                           | Type    | Default |
    | ---------- | --------------------------------------------------------------------------------------------------------------------- | ------- | ------- |
    | bordered   | Toggles rendering of the border around the list                                                                       | boolean | false   |
    | itemLayout | The layout of list, default is `horizontal`, If a vertical list is desired, set the itemLayout property to `vertical` | string  | -       |
    
    <!-- Output (Prettier master, --prose-wrap never) -->
    | Property | Description | Type | Default |
    | --- | --- | --- | --- |
    | bordered | Toggles rendering of the border around the list | boolean | false |
    | itemLayout | The layout of list, default is `horizontal`, If a vertical list is desired, set the itemLayout property to `vertical` | string | - |
    
  • LWC: Add support for Lightning Web Components ([#5800] by [@ntotten])

    Supports Lightning Web Components (LWC) template format for HTML attributes by adding a new parser called lwc.

    // Input
    <my-element data-for={value}></my-element>
    
    // Output (Prettier stable)
    <my-element data-for="{value}"></my-element>
    
    // Output (Prettier master)
    <my-element data-for={value}></my-element>
    
  • JavaScript: Fix parens logic for optional chaining expressions and closure type casts ([#5843] by [@yangsu])

    Logic introduced in #4542 will print parens in the wrong places and produce invalid code for optional chaining expressions (with more than 2 nodes) or closure type casts that end in function calls.

    // Input
    (a?.b[c]).c();
    let value = /** @type {string} */ (this.members[0]).functionCall();
    
    // Output (Prettier stable)
    a(?.b[c]).c();
    let value = /** @type {string} */ this(.members[0]).functionCall();
    
    // Output (Prettier master)
    (a?.b[c]).c();
    let value = /** @type {string} */ (this.members[0]).functionCall();