Skip to content

Commit

Permalink
fix: correctly resolve file imports with query params (#148)
Browse files Browse the repository at this point in the history
Resolves #132
  • Loading branch information
rchl authored Oct 7, 2020
1 parent 7532971 commit 71bfe87
Show file tree
Hide file tree
Showing 4 changed files with 31 additions and 3 deletions.
12 changes: 12 additions & 0 deletions __tests__/__snapshots__/index.test.ts.snap
Original file line number Diff line number Diff line change
Expand Up @@ -177,6 +177,10 @@ exports[`basic resolvers: css 1`] = `
);
background-image: image-set(\\"/pubpath/cat.png\\" 1x);
}
.foo3 {
background-image: url(\\"/pubpath/bg.png?query\\");
}
.bar {
background-image: url(\\"/pubpath/bg1.png\\");
background-image: url(\\"/pubpath/bg2.testing.regex.png\\"); }
Expand Down Expand Up @@ -215,6 +219,10 @@ exports[`basic resolvers-hash: css 1`] = `
);
background-image: image-set(\\"/pubpath/cat-ef753cf2.png\\" 1x);
}
.foo3 {
background-image: url(\\"/pubpath/bg-bd25d3fd.png?query\\");
}
.bar {
background-image: url(\\"/pubpath/bg-cc57d19a.png\\");
background-image: url(\\"/pubpath/bg.testing.regex-e13f1639.png\\"); }
Expand Down Expand Up @@ -253,6 +261,10 @@ exports[`basic resolvers-url-inline: css 1`] = `
);
background-image: image-set(\\"\\" 1x);
}
.foo3 {
background-image: url(\\"\\");
}
.bar {
background-image: url(\\"\\");
background-image: url(\\"\\"); }
Expand Down
4 changes: 4 additions & 0 deletions __tests__/fixtures/resolvers/features/foo.css
Original file line number Diff line number Diff line change
Expand Up @@ -12,3 +12,7 @@
);
background-image: image-set("cat/cat.png" 1x);
}

.foo3 {
background-image: url("./bg.png?query");
}
8 changes: 6 additions & 2 deletions src/loaders/postcss/url/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -156,7 +156,7 @@ const plugin: postcss.Plugin<UrlOptions> = postcss.plugin(
continue;
}

const { source, from } = resolved;
const { source, from, urlQuery } = resolved;
if (!(source instanceof Uint8Array) || typeof from !== "string") {
decl.warn(res, `Incorrectly resolved URL \`${url}\` in \`${decl.toString()}\``);
continue;
Expand All @@ -180,7 +180,11 @@ const plugin: postcss.Plugin<UrlOptions> = postcss.plugin(
usedNames.set(to, from);

node.type = "string";
node.value = publicPath + (/[/\\]$/.test(publicPath) ? "" : "/") + path.basename(to);
node.value =
publicPath +
(/[/\\]$/.test(publicPath) ? "" : "/") +
path.basename(to) +
(urlQuery ?? "");

to = normalizePath(assetDir, to);
res.messages.push({ plugin: name, type: "asset", to, source });
Expand Down
10 changes: 9 additions & 1 deletion src/loaders/postcss/url/resolve.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@ export interface UrlFile {
from: string;
/** File source */
source: Uint8Array;
/** Original query extracted from the input path */
urlQuery?: string;
}

/** URL resolver */
Expand All @@ -16,12 +18,18 @@ export type UrlResolve = (url: string, basedir: string) => Promise<UrlFile>;
const resolve: UrlResolve = async (url, basedir) => {
const options = { basedir };
let from: string;
const urlWithQueryMatch = /([^?]*)(\?.*)/.exec(url);
let urlQuery = "";
if (urlWithQueryMatch) {
url = urlWithQueryMatch[1];
urlQuery = urlWithQueryMatch[2];
}
try {
from = await resolveAsync(url, options);
} catch {
from = await resolveAsync(`./${url}`, options);
}
return { from, source: await fs.readFile(from) };
return { from, source: await fs.readFile(from), urlQuery };
};

export default resolve;

0 comments on commit 71bfe87

Please sign in to comment.