Skip to content

Commit

Permalink
fix(formatter): trim CSS raw values (#4108)
Browse files Browse the repository at this point in the history
Co-authored-by: Carson McManus <dyc3@users.noreply.github.com>
  • Loading branch information
ematipico and dyc3 authored Sep 27, 2024
1 parent 2583e48 commit 011a709
Show file tree
Hide file tree
Showing 7 changed files with 55 additions and 46 deletions.
13 changes: 13 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,18 @@ our [guidelines for writing a good changelog entry](https://github.com/biomejs/b
#### Bug fixes

- Fix [#3924](https://github.com/biomejs/biome/issues/3924) where GraphQL formatter panics in block comments with empty line. Contributed by @vohoanglong0107

- Fix a case where raw values inside `url()` functions weren't properly trimmed.
```diff
.value {
- background: url(
- whitespace-around-string
- );
+ background: url(whitespace-around-string);
}
```
Contributed by @ematipico

- Fixed [#4076](https://github.com/biomejs/biome/issues/4076), where a media query wasn't correctly formatted:
```diff
.class {
Expand All @@ -54,6 +66,7 @@ our [guidelines for writing a good changelog entry](https://github.com/biomejs/b
}
```
Contributed by @blaze-d83

### JavaScript API

### Linter
Expand Down
11 changes: 9 additions & 2 deletions crates/biome_css_formatter/src/css/value/url_value_raw.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,14 @@ pub(crate) struct FormatCssUrlValueRaw;
impl FormatNodeRule<CssUrlValueRaw> for FormatCssUrlValueRaw {
fn fmt_fields(&self, node: &CssUrlValueRaw, f: &mut CssFormatter) -> FormatResult<()> {
let CssUrlValueRawFields { value_token } = node.as_fields();

write!(f, [value_token.format()])
let value_token = value_token?;
let text = value_token.token_text();
write!(
f,
[format_replaced(
&value_token,
&dynamic_text(text.trim(), value_token.text_trimmed_range().start())
)]
)
}
}
6 changes: 4 additions & 2 deletions crates/biome_css_formatter/src/utils/component_value_list.rs
Original file line number Diff line number Diff line change
Expand Up @@ -39,9 +39,11 @@ where
// Consider the CSS example: `font: first , second;`
// The desired format is: `font: first, second;`
// A separator should not be added before the comma because the comma acts as a `CssGenericDelimiter`.
let is_comma = CssGenericDelimiter::cast_ref(element.syntax())
let token_kind = CssGenericDelimiter::cast_ref(element.syntax())
.and_then(|node| node.value().ok())
.map_or(false, |node| node.kind() == CssSyntaxKind::COMMA);
.map(|token| token.kind());

let is_comma = matches!(token_kind, Some(CssSyntaxKind::COMMA));

if !is_comma {
if matches!(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -218,11 +218,10 @@ Quote style: Double Quotes
@import url("test.css");
@import url(test.css);
@import url(test.css);
@import url(test.css );
@import url(test.css);
@import url(test.css );
@import url(test.css
);
@import url(test.css);
@import url(test.css);
@import url(test.css);
@import url();
@import url("");
@import url("");
Expand Down Expand Up @@ -287,7 +286,7 @@ st.css");
@import url("./t\65st%20test.css");
@import "./t\65st%20test.css";
@import "./t\65st%20test.css";
@import url(test.css );
@import url(test.css);
@import "\
\
\
Expand All @@ -304,7 +303,7 @@ st.css");

@import " ./test.css ";
@import url(" ./test.css ");
@import url(./test.css );
@import url(./test.css);

@import "./my.scss";

Expand Down Expand Up @@ -378,7 +377,7 @@ st.css");

# Lines exceeding max width of 80 characters
```
103: @import url("!!../../helpers/string-loader.js?esModule=false!~package/tilde.css");
121: @import url(" !!../../helpers/string-loader.js?esModule=false!~package/tilde.css ");
122: @import url(data:text/css;charset=utf-8,a%20%7B%0D%0A%20%20color%3A%20red%3B%0D%0A%7D);
102: @import url("!!../../helpers/string-loader.js?esModule=false!~package/tilde.css");
120: @import url(" !!../../helpers/string-loader.js?esModule=false!~package/tilde.css ");
121: @import url(data:text/css;charset=utf-8,a%20%7B%0D%0A%20%20color%3A%20red%3B%0D%0A%7D);
```
2 changes: 1 addition & 1 deletion crates/biome_css_formatter/tests/specs/css/url.css.snap
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ div {

a {
content: url(https://example.com/a.jpg);
content: url(https://example.com/f.jpg );
content: url(https://example.com/f.jpg);

background: no-repeat
url(RobotoFlex-VariableFont_GRAD,XTRA,YOPQ,YTAS,YTDE,YTFI,YTLC,YTUC,opsz,slnt,wdth,wght.ttf);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -65,17 +65,7 @@ info: css/inline-url/inline_url.css
```diff
--- Prettier
+++ Biome
@@ -7,7 +7,8 @@
}

.validUnquotedUrls {
- background: url(whitespace-around-string);
+ background: url(whitespace-around-string
+ );
background-image: url(/images/product/simple_product_manager/breadcrumb/chevron_right.png);
background-image: url();
background-image: url(data:application/font-woff;charset=utf-8;base64,ThisIsNormalBut/+0ThisIsLowerCased);
@@ -42,7 +43,7 @@
@@ -42,7 +42,7 @@
background-image: url(http://123.com);
background: url(path/to/123.jpg);
background: url(#123.foo);
Expand All @@ -100,8 +90,7 @@ info: css/inline-url/inline_url.css
}

.validUnquotedUrls {
background: url(whitespace-around-string
);
background: url(whitespace-around-string);
background-image: url(/images/product/simple_product_manager/breadcrumb/chevron_right.png);
background-image: url();
background-image: url(data:application/font-woff;charset=utf-8;base64,ThisIsNormalBut/+0ThisIsLowerCased);
Expand Down Expand Up @@ -164,10 +153,10 @@ inline_url.css:29:19 parse ━━━━━━━━━━━━━━━━━

# Lines exceeding max width of 80 characters
```
12: background-image: url(/images/product/simple_product_manager/breadcrumb/chevron_right.png);
13: background-image: url();
14: background-image: url(data:application/font-woff;charset=utf-8;base64,ThisIsNormalBut/+0ThisIsLowerCased);
15: background: url()
17: background: url(data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20width=%229%22%20height=%229%22%3E%3Cpath%20d=%22M0%203h3%22%20stroke=%22red%22/%3E%3C/svg%3E);
24: @import url(https://fonts.googleapis.com/css?family=Roboto:100,300,400,500,700,900&display=swap);
11: background-image: url(/images/product/simple_product_manager/breadcrumb/chevron_right.png);
12: background-image: url();
13: background-image: url(data:application/font-woff;charset=utf-8;base64,ThisIsNormalBut/+0ThisIsLowerCased);
14: background: url()
16: background: url(data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20width=%229%22%20height=%229%22%3E%3Cpath%20d=%22M0%203h3%22%20stroke=%22red%22/%3E%3C/svg%3E);
23: @import url(https://fonts.googleapis.com/css?family=Roboto:100,300,400,500,700,900&display=swap);
```
Original file line number Diff line number Diff line change
Expand Up @@ -51,22 +51,21 @@ a {
content: url(https://example.com/\ \ .jpg);
- content: url( https://example.com/\)\).jpg );
- content: url( https://example.com/\(\(.jpg );
- content: url(https://example.com/\ \ .jpg);
+ content: url(https://example.com/\)\).jpg );
+ content: url(https://example.com/\(\(.jpg );
+ content: url(https://example.com/\ \ .jpg );
+ content: url(https://example.com/\)\).jpg);
+ content: url(https://example.com/\(\(.jpg);
content: url(https://example.com/\ \ .jpg);

- background: no-repeat url(https://example.com/\)\).jpg),
+ background:
+ no-repeat url(https://example.com/\)\).jpg),
+ no-repeat url(https://example.com/\(\(.jpg),
+ no-repeat url(https://example.com/\ \ .jpg),
+ no-repeat url(https://example.com/\)\).jpg),
no-repeat url(https://example.com/\(\(.jpg),
no-repeat url(https://example.com/\ \ .jpg),
- no-repeat url( https://example.com/\)\).jpg ),
- no-repeat url( https://example.com/\(\(.jpg ),
- no-repeat url( https://example.com/\ \ .jpg ),
+ no-repeat url(https://example.com/\)\).jpg ),
+ no-repeat url(https://example.com/\(\(.jpg ),
+ no-repeat url(https://example.com/\ \ .jpg ),
no-repeat url(foo.ttf?query=foo,bar,),
no-repeat url(foo.woff2?foo=rgb\(255,255,0\))
no-repeat url(RobotoFlex-VariableFont_GRAD,XTRA,YOPQ,YTAS,YTDE,YTFI,YTLC,YTUC,opsz,slnt,wdth,wght.ttf);
Expand All @@ -92,17 +91,17 @@ a {
content: url(https://example.com/\)\).jpg);
content: url(https://example.com/\(\(.jpg);
content: url(https://example.com/\ \ .jpg);
content: url(https://example.com/\)\).jpg );
content: url(https://example.com/\(\(.jpg );
content: url(https://example.com/\ \ .jpg );
content: url(https://example.com/\)\).jpg);
content: url(https://example.com/\(\(.jpg);
content: url(https://example.com/\ \ .jpg);

background:
no-repeat url(https://example.com/\)\).jpg),
no-repeat url(https://example.com/\(\(.jpg),
no-repeat url(https://example.com/\ \ .jpg),
no-repeat url(https://example.com/\)\).jpg ),
no-repeat url(https://example.com/\(\(.jpg ),
no-repeat url(https://example.com/\ \ .jpg ),
no-repeat url(https://example.com/\)\).jpg),
no-repeat url(https://example.com/\(\(.jpg),
no-repeat url(https://example.com/\ \ .jpg),
no-repeat url(foo.ttf?query=foo,bar,),
no-repeat url(foo.woff2?foo=rgb\(255,255,0\))
no-repeat url(RobotoFlex-VariableFont_GRAD,XTRA,YOPQ,YTAS,YTDE,YTFI,YTLC,YTUC,opsz,slnt,wdth,wght.ttf);
Expand Down

0 comments on commit 011a709

Please sign in to comment.