Skip to content

Commit

Permalink
fix: respected style field from package.json
Browse files Browse the repository at this point in the history
  • Loading branch information
cap-Bernardito committed Jul 3, 2020
1 parent e2205af commit 4ae4e5c
Show file tree
Hide file tree
Showing 9 changed files with 164 additions and 9 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -16,3 +16,4 @@ Thumbs.db
.vscode
*.sublime-project
*.sublime-workspace
/test/fixtures/import/import-absolute.css
1 change: 1 addition & 0 deletions src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,7 @@ export default function loader(content, map, meta) {
plugins.push(
importParser({
context: this.context,
rootContext: this.rootContext,
filter: getFilter(options.import, this.resourcePath),
resolver,
urlHandler,
Expand Down
23 changes: 20 additions & 3 deletions src/plugins/postcss-import-parser.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import postcss from 'postcss';
import valueParser from 'postcss-value-parser';
import { isUrlRequest } from 'loader-utils';
import { isUrlRequest, urlToRequest } from 'loader-utils';

import { normalizeUrl, resolveRequests } from '../utils';

Expand Down Expand Up @@ -77,6 +77,13 @@ export default postcss.plugin(pluginName, (options) => (css, result) => {
return;
}

let request;

// May be url is server-relative url, but not //example.com
if (url.charAt(0) === '/' && url.charAt(1) !== '/') {
request = urlToRequest(url, options.rootContext);
}

const isRequestable = isUrlRequest(url);

if (isRequestable) {
Expand Down Expand Up @@ -107,7 +114,7 @@ export default postcss.plugin(pluginName, (options) => (css, result) => {

tasks.push(
Promise.resolve(index).then(async (currentIndex) => {
if (isRequestable) {
if (isRequestable || request) {
const importKey = url;
let importName = importsMap.get(importKey);

Expand All @@ -117,10 +124,20 @@ export default postcss.plugin(pluginName, (options) => (css, result) => {

const { resolver, context } = options;

const possibleRequest = [url];

if (request) {
possibleRequest.push(request);
}

let resolvedUrl;

try {
resolvedUrl = await resolveRequests(resolver, context, [url]);
resolvedUrl = await resolveRequests(
resolver,
context,
possibleRequest
);
} catch (error) {
throw error;
}
Expand Down
12 changes: 6 additions & 6 deletions src/utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -73,13 +73,17 @@ function getLocalIdent(loaderContext, localIdentName, localName, options) {
}

function normalizeUrl(url, isStringValue) {
const matchNativeWin32Path = /^[A-Z]:[/\\]|^\\\\/i;

let normalizedUrl = url;

if (isStringValue && /\\[\n]/.test(normalizedUrl)) {
normalizedUrl = normalizedUrl.replace(/\\[\n]/g, '');
}

return urlToRequest(decodeURIComponent(unescape(normalizedUrl)));
return matchNativeWin32Path.test(url)
? urlToRequest(url, true)
: urlToRequest(decodeURIComponent(unescape(normalizedUrl)));
}

function getFilter(filter, resourcePath, defaultFilter = null) {
Expand Down Expand Up @@ -423,10 +427,6 @@ function getExportCode(
}

async function resolveRequests(resolve, context, possibleRequests) {
if (possibleRequests.length === 0) {
return Promise.reject();
}

return resolve(context, possibleRequests[0])
.then((result) => {
return result;
Expand All @@ -438,7 +438,7 @@ async function resolveRequests(resolve, context, possibleRequests) {
throw error;
}

return this.resolveRequests(context, tailPossibleRequests);
return resolveRequests(resolve, context, tailPossibleRequests);
});
}

Expand Down
82 changes: 82 additions & 0 deletions test/__snapshots__/import-option.test.js.snap
Original file line number Diff line number Diff line change
Expand Up @@ -152,6 +152,88 @@ Array [

exports[`"import" option should keep original order: warnings 1`] = `Array []`;

exports[`"import" option should resolve absolute path: errors 1`] = `Array []`;

exports[`"import" option should resolve absolute path: module 1`] = `
"// Imports
var ___CSS_LOADER_API_IMPORT___ = require(\\"../../../src/runtime/api.js\\");
var ___CSS_LOADER_AT_RULE_IMPORT_0___ = require(\\"-!../../../src/index.js??[ident]!./test.css\\");
exports = ___CSS_LOADER_API_IMPORT___(false);
exports.i(___CSS_LOADER_AT_RULE_IMPORT_0___);
// Module
exports.push([module.id, \\"\\", \\"\\"]);
// Exports
module.exports = exports;
"
`;

exports[`"import" option should resolve absolute path: result 1`] = `
Array [
Array [
"../../src/index.js?[ident]!./import/test.css",
".test {
a: a;
}
",
"",
],
Array [
"./import/import-absolute.css",
"",
"",
],
]
`;

exports[`"import" option should resolve absolute path: warnings 1`] = `Array []`;

exports[`"import" option should resolve server-relative url relative rootContext: errors 1`] = `Array []`;

exports[`"import" option should resolve server-relative url relative rootContext: module 1`] = `
"// Imports
var ___CSS_LOADER_API_IMPORT___ = require(\\"../../../src/runtime/api.js\\");
var ___CSS_LOADER_AT_RULE_IMPORT_0___ = require(\\"-!../../../src/index.js??[ident]!./test.css\\");
exports = ___CSS_LOADER_API_IMPORT___(false);
exports.i(___CSS_LOADER_AT_RULE_IMPORT_0___);
exports.i(___CSS_LOADER_AT_RULE_IMPORT_0___);
// Module
exports.push([module.id, \\".class {\\\\n a: b c d;\\\\n}\\\\n\\", \\"\\"]);
// Exports
module.exports = exports;
"
`;

exports[`"import" option should resolve server-relative url relative rootContext: result 1`] = `
Array [
Array [
"../../src/index.js?[ident]!./import/test.css",
".test {
a: a;
}
",
"",
],
Array [
"../../src/index.js?[ident]!./import/test.css",
".test {
a: a;
}
",
"",
],
Array [
"./import/import-server-relative-url.css",
".class {
a: b c d;
}
",
"",
],
]
`;

exports[`"import" option should resolve server-relative url relative rootContext: warnings 1`] = `Array []`;

exports[`"import" option should respect stype field in package.json: errors 1`] = `Array []`;

exports[`"import" option should respect stype field in package.json: module 1`] = `
Expand Down
5 changes: 5 additions & 0 deletions test/fixtures/import/import-absolute.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import css from './import-absolute.css';

__export__ = css;

export default css;
6 changes: 6 additions & 0 deletions test/fixtures/import/import-server-relative-url.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
@import url(/import/test.css);
@import "/import/test.css";

.class {
a: b c d;
}
5 changes: 5 additions & 0 deletions test/fixtures/import/import-server-relative-url.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import css from './import-server-relative-url.css';

__export__ = css;

export default css;
38 changes: 38 additions & 0 deletions test/import-option.test.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
import path from 'path';
import fs from 'fs';

import {
compile,
getCompiler,
Expand Down Expand Up @@ -100,4 +103,39 @@ describe('"import" option', () => {
expect(getWarnings(stats)).toMatchSnapshot('warnings');
expect(getErrors(stats)).toMatchSnapshot('errors');
});

it('should resolve server-relative url relative rootContext', async () => {
const compiler = getCompiler('./import/import-server-relative-url.js');
const stats = await compile(compiler);

expect(
getModuleSource('./import/import-server-relative-url.css', stats)
).toMatchSnapshot('module');
expect(getExecutedCode('main.bundle.js', compiler, stats)).toMatchSnapshot(
'result'
);
expect(getWarnings(stats)).toMatchSnapshot('warnings');
expect(getErrors(stats)).toMatchSnapshot('errors');
});

it('should resolve absolute path', async () => {
// Create the file with absolute path
const fileDirectory = path.resolve(__dirname, 'fixtures', 'import');
const file = path.resolve(fileDirectory, 'import-absolute.css');
const absolutePath = path.resolve(fileDirectory, 'test.css');

fs.writeFileSync(file, `@import "${absolutePath}";`);

const compiler = getCompiler('./import/import-absolute.js');
const stats = await compile(compiler);

expect(
getModuleSource('./import/import-absolute.css', stats)
).toMatchSnapshot('module');
expect(getExecutedCode('main.bundle.js', compiler, stats)).toMatchSnapshot(
'result'
);
expect(getWarnings(stats)).toMatchSnapshot('warnings');
expect(getErrors(stats)).toMatchSnapshot('errors');
});
});

0 comments on commit 4ae4e5c

Please sign in to comment.