Skip to content

Commit

Permalink
preserve original url in style
Browse files Browse the repository at this point in the history
  • Loading branch information
Ivan Radonov authored and Ivan Radonov committed Nov 10, 2024
1 parent f3c9b9a commit 6acc952
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -384,11 +384,13 @@ export default class CSSStyleDeclarationValueParser {

let url = result[1].trim();

if ((url[0] === '"' || url[0] === "'") && url[0] !== url[url.length - 1]) {
const hasQuotes = url[0] === '"' || url[0] === "'";

if (hasQuotes && url[0] !== url[url.length - 1]) {
return null;
}

if (url[0] === '"' || url[0] === "'") {
if (hasQuotes) {
url = url.substring(1, url.length - 1);
}

Expand All @@ -408,7 +410,11 @@ export default class CSSStyleDeclarationValueParser {
}
}

return `url("${url}")`;
if (hasQuotes) {
url = `"${url}"`;
}

return `url(${url})`;
}

/**
Expand Down
6 changes: 3 additions & 3 deletions packages/happy-dom/test/css/CSSParser.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ describe('CSSParser', () => {
expect((<CSSStyleRule>cssRules[1]).parentStyleSheet).toBe(cssStyleSheet);
expect((<CSSStyleRule>cssRules[1]).selectorText).toBe('.container');
expect((<CSSStyleRule>cssRules[1]).cssText).toBe(
'.container { flex-grow: 1; display: flex; flex-direction: column; overflow: hidden; --css-variable: 1px; background-image: url(""), url("test.jpg"); }'
'.container { flex-grow: 1; display: flex; flex-direction: column; overflow: hidden; --css-variable: 1px; background-image: url(""), url(test.jpg); }'
);
expect((<CSSStyleRule>cssRules[1]).style.length).toBe(6);
expect((<CSSStyleRule>cssRules[1]).style.parentRule).toBe(cssRules[1]);
Expand All @@ -57,10 +57,10 @@ describe('CSSParser', () => {
expect((<CSSStyleRule>cssRules[1]).style.overflow).toBe('hidden');
expect((<CSSStyleRule>cssRules[1]).style.getPropertyValue('--css-variable')).toBe('1px');
expect((<CSSStyleRule>cssRules[1]).style.backgroundImage).toBe(
'url(""), url("test.jpg")'
'url(""), url(test.jpg)'
);
expect((<CSSStyleRule>cssRules[1]).style.cssText).toBe(
'flex-grow: 1; display: flex; flex-direction: column; overflow: hidden; --css-variable: 1px; background-image: url(""), url("test.jpg");'
'flex-grow: 1; display: flex; flex-direction: column; overflow: hidden; --css-variable: 1px; background-image: url(""), url(test.jpg);'
);

// CSSMediaRule
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2019,19 +2019,19 @@ describe('CSSStyleDeclaration', () => {

element.setAttribute('style', 'background-image: url(test.jpg)');

expect(declaration.backgroundImage).toBe('url("test.jpg")');
expect(declaration.backgroundImage).toBe('url(test.jpg)');

element.setAttribute('style', 'background-image: url(test.jpg), url(test2.jpg)');

expect(declaration.backgroundImage).toBe('url("test.jpg"), url("test2.jpg")');
expect(declaration.backgroundImage).toBe('url(test.jpg), url(test2.jpg)');

element.setAttribute(
'style',
'background-image: url()'
);

expect(declaration.backgroundImage).toBe(
'url("")'
'url()'
);
});
});
Expand Down

0 comments on commit 6acc952

Please sign in to comment.