css-loader 0.25.0 → 0.26.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/css-base.js CHANGED
@@ -1,50 +1,50 @@
1
- /*
2
- MIT License http://www.opensource.org/licenses/mit-license.php
3
- Author Tobias Koppers @sokra
4
- */
5
- // css base code, injected by the css-loader
6
- module.exports = function() {
7
- var list = [];
8
-
9
- // return the list of modules as css string
10
- list.toString = function toString() {
11
- var result = [];
12
- for(var i = 0; i < this.length; i++) {
13
- var item = this[i];
14
- if(item[2]) {
15
- result.push("@media " + item[2] + "{" + item[1] + "}");
16
- } else {
17
- result.push(item[1]);
18
- }
19
- }
20
- return result.join("");
21
- };
22
-
23
- // import a list of modules into the list
24
- list.i = function(modules, mediaQuery) {
25
- if(typeof modules === "string")
26
- modules = [[null, modules, ""]];
27
- var alreadyImportedModules = {};
28
- for(var i = 0; i < this.length; i++) {
29
- var id = this[i][0];
30
- if(typeof id === "number")
31
- alreadyImportedModules[id] = true;
32
- }
33
- for(i = 0; i < modules.length; i++) {
34
- var item = modules[i];
35
- // skip already imported module
36
- // this implementation is not 100% perfect for weird media query combinations
37
- // when a module is imported multiple times with different media queries.
38
- // I hope this will never occur (Hey this way we have smaller bundles)
39
- if(typeof item[0] !== "number" || !alreadyImportedModules[item[0]]) {
40
- if(mediaQuery && !item[2]) {
41
- item[2] = mediaQuery;
42
- } else if(mediaQuery) {
43
- item[2] = "(" + item[2] + ") and (" + mediaQuery + ")";
44
- }
45
- list.push(item);
46
- }
47
- }
48
- };
49
- return list;
50
- };
1
+ /*
2
+ MIT License http://www.opensource.org/licenses/mit-license.php
3
+ Author Tobias Koppers @sokra
4
+ */
5
+ // css base code, injected by the css-loader
6
+ module.exports = function() {
7
+ var list = [];
8
+
9
+ // return the list of modules as css string
10
+ list.toString = function toString() {
11
+ var result = [];
12
+ for(var i = 0; i < this.length; i++) {
13
+ var item = this[i];
14
+ if(item[2]) {
15
+ result.push("@media " + item[2] + "{" + item[1] + "}");
16
+ } else {
17
+ result.push(item[1]);
18
+ }
19
+ }
20
+ return result.join("");
21
+ };
22
+
23
+ // import a list of modules into the list
24
+ list.i = function(modules, mediaQuery) {
25
+ if(typeof modules === "string")
26
+ modules = [[null, modules, ""]];
27
+ var alreadyImportedModules = {};
28
+ for(var i = 0; i < this.length; i++) {
29
+ var id = this[i][0];
30
+ if(typeof id === "number")
31
+ alreadyImportedModules[id] = true;
32
+ }
33
+ for(i = 0; i < modules.length; i++) {
34
+ var item = modules[i];
35
+ // skip already imported module
36
+ // this implementation is not 100% perfect for weird media query combinations
37
+ // when a module is imported multiple times with different media queries.
38
+ // I hope this will never occur (Hey this way we have smaller bundles)
39
+ if(typeof item[0] !== "number" || !alreadyImportedModules[item[0]]) {
40
+ if(mediaQuery && !item[2]) {
41
+ item[2] = mediaQuery;
42
+ } else if(mediaQuery) {
43
+ item[2] = "(" + item[2] + ") and (" + mediaQuery + ")";
44
+ }
45
+ list.push(item);
46
+ }
47
+ }
48
+ };
49
+ return list;
50
+ };
@@ -1,14 +1,14 @@
1
- /*
2
- MIT License http://www.opensource.org/licenses/mit-license.php
3
- Author Tobias Koppers @sokra
4
- */
5
- module.exports = function getImportPrefix(loaderContext, query) {
6
- if(query.importLoaders === false)
7
- return "";
8
- var importLoaders = parseInt(query.importLoaders, 10) || 0;
9
- var loadersRequest = loaderContext.loaders.slice(
10
- loaderContext.loaderIndex,
11
- loaderContext.loaderIndex + 1 + importLoaders
12
- ).map(function(x) { return x.request; }).join("!");
13
- return "-!" + loadersRequest + "!";
14
- };
1
+ /*
2
+ MIT License http://www.opensource.org/licenses/mit-license.php
3
+ Author Tobias Koppers @sokra
4
+ */
5
+ module.exports = function getImportPrefix(loaderContext, query) {
6
+ if(query.importLoaders === false)
7
+ return "";
8
+ var importLoaders = parseInt(query.importLoaders, 10) || 0;
9
+ var loadersRequest = loaderContext.loaders.slice(
10
+ loaderContext.loaderIndex,
11
+ loaderContext.loaderIndex + 1 + importLoaders
12
+ ).map(function(x) { return x.request; }).join("!");
13
+ return "-!" + loadersRequest + "!";
14
+ };
@@ -1,16 +1,16 @@
1
- /*
2
- MIT License http://www.opensource.org/licenses/mit-license.php
3
- Author Tobias Koppers @sokra
4
- */
5
- var loaderUtils = require("loader-utils");
6
- var path = require("path");
7
-
8
- module.exports = function getLocalIdent(loaderContext, localIdentName, localName, options) {
9
- if(!options.context)
10
- options.context = loaderContext.options && typeof loaderContext.options.context === "string" ? loaderContext.options.context : loaderContext.context;
11
- var request = path.relative(options.context, loaderContext.resourcePath);
12
- options.content = options.hashPrefix + request + "+" + localName;
13
- localIdentName = localIdentName.replace(/\[local\]/gi, localName);
14
- var hash = loaderUtils.interpolateName(loaderContext, localIdentName, options);
15
- return hash.replace(new RegExp("[^a-zA-Z0-9\\-_\u00A0-\uFFFF]", "g"), "-").replace(/^((-?[0-9])|--)/, "_$1");
16
- };
1
+ /*
2
+ MIT License http://www.opensource.org/licenses/mit-license.php
3
+ Author Tobias Koppers @sokra
4
+ */
5
+ var loaderUtils = require("loader-utils");
6
+ var path = require("path");
7
+
8
+ module.exports = function getLocalIdent(loaderContext, localIdentName, localName, options) {
9
+ if(!options.context)
10
+ options.context = loaderContext.options && typeof loaderContext.options.context === "string" ? loaderContext.options.context : loaderContext.context;
11
+ var request = path.relative(options.context, loaderContext.resourcePath);
12
+ options.content = options.hashPrefix + request + "+" + localName;
13
+ localIdentName = localIdentName.replace(/\[local\]/gi, localName);
14
+ var hash = loaderUtils.interpolateName(loaderContext, localIdentName, options);
15
+ return hash.replace(new RegExp("[^a-zA-Z0-9\\-_\u00A0-\uFFFF]", "g"), "-").replace(/^((-?[0-9])|--)/, "_$1");
16
+ };
package/lib/loader.js CHANGED
@@ -1,124 +1,119 @@
1
- /*
2
- MIT License http://www.opensource.org/licenses/mit-license.php
3
- Author Tobias Koppers @sokra
4
- */
5
- var path = require("path");
6
- var loaderUtils = require("loader-utils");
7
- var processCss = require("./processCss");
8
- var getImportPrefix = require("./getImportPrefix");
9
- var compileExports = require("./compile-exports");
10
-
11
-
12
- module.exports = function(content, map) {
13
- if(this.cacheable) this.cacheable();
14
- var callback = this.async();
15
- var query = loaderUtils.parseQuery(this.query);
16
- var root = query.root;
17
- var moduleMode = query.modules || query.module;
18
- var camelCaseKeys = query.camelCase || query.camelcase;
19
-
20
- if(map !== null && typeof map !== "string") {
21
- map = JSON.stringify(map);
22
- }
23
-
24
- processCss(content, map, {
25
- mode: moduleMode ? "local" : "global",
26
- from: loaderUtils.getRemainingRequest(this),
27
- to: loaderUtils.getCurrentRequest(this),
28
- query: query,
29
- minimize: this.minimize,
30
- loaderContext: this
31
- }, function(err, result) {
32
- if(err) return callback(err);
33
-
34
- var cssAsString = JSON.stringify(result.source);
35
-
36
- // for importing CSS
37
- var importUrlPrefix = getImportPrefix(this, query);
38
-
39
- var alreadyImported = {};
40
- var importJs = result.importItems.filter(function(imp) {
41
- if(!imp.mediaQuery) {
42
- if(alreadyImported[imp.url])
43
- return false;
44
- alreadyImported[imp.url] = true;
45
- }
46
- return true;
47
- }).map(function(imp) {
48
- if(!loaderUtils.isUrlRequest(imp.url, root)) {
49
- return "exports.push([module.id, " +
50
- JSON.stringify("@import url(" + imp.url + ");") + ", " +
51
- JSON.stringify(imp.mediaQuery) + "]);";
52
- } else {
53
- var importUrl = importUrlPrefix + imp.url;
54
- return "exports.i(require(" + loaderUtils.stringifyRequest(this, importUrl) + "), " + JSON.stringify(imp.mediaQuery) + ");";
55
- }
56
- }, this).join("\n");
57
-
58
- function importItemMatcher(item) {
59
- var match = result.importItemRegExp.exec(item);
60
- var idx = +match[1];
61
- var importItem = result.importItems[idx];
62
- var importUrl = importUrlPrefix + importItem.url;
63
- return "\" + require(" + loaderUtils.stringifyRequest(this, importUrl) + ").locals" +
64
- "[" + JSON.stringify(importItem.export) + "] + \"";
65
- }
66
-
67
- cssAsString = cssAsString.replace(result.importItemRegExpG, importItemMatcher.bind(this));
68
- if(query.url !== false) {
69
- cssAsString = cssAsString.replace(result.urlItemRegExpG, function(item) {
70
- var match = result.urlItemRegExp.exec(item);
71
- var idx = +match[1];
72
- var urlItem = result.urlItems[idx];
73
- var url = urlItem.url;
74
- idx = url.indexOf("?#");
75
- if(idx < 0) idx = url.indexOf("#");
76
- var urlRequest;
77
- if(idx > 0) { // idx === 0 is catched by isUrlRequest
78
- // in cases like url('webfont.eot?#iefix')
79
- urlRequest = url.substr(0, idx);
80
- return "\" + require(" + loaderUtils.stringifyRequest(this, urlRequest) + ") + \"" +
81
- url.substr(idx);
82
- }
83
- urlRequest = url;
84
- return "\" + require(" + loaderUtils.stringifyRequest(this, urlRequest) + ") + \"";
85
- }.bind(this));
86
- }
87
-
88
-
89
- var exportJs = compileExports(result, importItemMatcher.bind(this), camelCaseKeys);
90
- if (exportJs) {
91
- exportJs = "exports.locals = " + exportJs + ";";
92
- }
93
-
94
- var moduleJs;
95
- if(query.sourceMap && result.map) {
96
- // add a SourceMap
97
- map = result.map;
98
- if(map.sources) {
99
- map.sources = map.sources.map(function(source) {
100
- source = source.split("!").pop();
101
- var p = path.relative(query.context || this.options.context, source).replace(/\\/g, "/");
102
- if(p.indexOf("../") !== 0)
103
- p = "./" + p;
104
- return "/" + p;
105
- }, this);
106
- map.sourceRoot = "webpack://";
107
- }
108
- map.file = map.file.split("!").pop();
109
- map = JSON.stringify(map);
110
- moduleJs = "exports.push([module.id, " + cssAsString + ", \"\", " + map + "]);";
111
- } else {
112
- moduleJs = "exports.push([module.id, " + cssAsString + ", \"\"]);";
113
- }
114
-
115
- // embed runtime
116
- callback(null, "exports = module.exports = require(" + loaderUtils.stringifyRequest(this, require.resolve("./css-base.js")) + ")();\n" +
117
- "// imports\n" +
118
- importJs + "\n\n" +
119
- "// module\n" +
120
- moduleJs + "\n\n" +
121
- "// exports\n" +
122
- exportJs);
123
- }.bind(this));
124
- };
1
+ /*
2
+ MIT License http://www.opensource.org/licenses/mit-license.php
3
+ Author Tobias Koppers @sokra
4
+ */
5
+ var loaderUtils = require("loader-utils");
6
+ var processCss = require("./processCss");
7
+ var getImportPrefix = require("./getImportPrefix");
8
+ var compileExports = require("./compile-exports");
9
+
10
+
11
+ module.exports = function(content, map) {
12
+ if(this.cacheable) this.cacheable();
13
+ var callback = this.async();
14
+ var query = loaderUtils.getOptions(this) || {};
15
+ var root = query.root;
16
+ var moduleMode = query.modules || query.module;
17
+ var camelCaseKeys = query.camelCase || query.camelcase;
18
+
19
+ if(map !== null && typeof map !== "string") {
20
+ map = JSON.stringify(map);
21
+ }
22
+
23
+ processCss(content, map, {
24
+ mode: moduleMode ? "local" : "global",
25
+ from: loaderUtils.getRemainingRequest(this),
26
+ to: loaderUtils.getCurrentRequest(this),
27
+ query: query,
28
+ minimize: this.minimize,
29
+ loaderContext: this
30
+ }, function(err, result) {
31
+ if(err) return callback(err);
32
+
33
+ var cssAsString = JSON.stringify(result.source);
34
+
35
+ // for importing CSS
36
+ var importUrlPrefix = getImportPrefix(this, query);
37
+
38
+ var alreadyImported = {};
39
+ var importJs = result.importItems.filter(function(imp) {
40
+ if(!imp.mediaQuery) {
41
+ if(alreadyImported[imp.url])
42
+ return false;
43
+ alreadyImported[imp.url] = true;
44
+ }
45
+ return true;
46
+ }).map(function(imp) {
47
+ if(!loaderUtils.isUrlRequest(imp.url, root)) {
48
+ return "exports.push([module.id, " +
49
+ JSON.stringify("@import url(" + imp.url + ");") + ", " +
50
+ JSON.stringify(imp.mediaQuery) + "]);";
51
+ } else {
52
+ var importUrl = importUrlPrefix + imp.url;
53
+ return "exports.i(require(" + loaderUtils.stringifyRequest(this, importUrl) + "), " + JSON.stringify(imp.mediaQuery) + ");";
54
+ }
55
+ }, this).join("\n");
56
+
57
+ function importItemMatcher(item) {
58
+ var match = result.importItemRegExp.exec(item);
59
+ var idx = +match[1];
60
+ var importItem = result.importItems[idx];
61
+ var importUrl = importUrlPrefix + importItem.url;
62
+ return "\" + require(" + loaderUtils.stringifyRequest(this, importUrl) + ").locals" +
63
+ "[" + JSON.stringify(importItem.export) + "] + \"";
64
+ }
65
+
66
+ cssAsString = cssAsString.replace(result.importItemRegExpG, importItemMatcher.bind(this));
67
+ if(query.url !== false) {
68
+ cssAsString = cssAsString.replace(result.urlItemRegExpG, function(item) {
69
+ var match = result.urlItemRegExp.exec(item);
70
+ var idx = +match[1];
71
+ var urlItem = result.urlItems[idx];
72
+ var url = urlItem.url;
73
+ idx = url.indexOf("?#");
74
+ if(idx < 0) idx = url.indexOf("#");
75
+ var urlRequest;
76
+ if(idx > 0) { // idx === 0 is catched by isUrlRequest
77
+ // in cases like url('webfont.eot?#iefix')
78
+ urlRequest = url.substr(0, idx);
79
+ return "\" + require(" + loaderUtils.stringifyRequest(this, urlRequest) + ") + \"" +
80
+ url.substr(idx);
81
+ }
82
+ urlRequest = url;
83
+ return "\" + require(" + loaderUtils.stringifyRequest(this, urlRequest) + ") + \"";
84
+ }.bind(this));
85
+ }
86
+
87
+
88
+ var exportJs = compileExports(result, importItemMatcher.bind(this), camelCaseKeys);
89
+ if (exportJs) {
90
+ exportJs = "exports.locals = " + exportJs + ";";
91
+ }
92
+
93
+ var moduleJs;
94
+ if(query.sourceMap && result.map) {
95
+ // add a SourceMap
96
+ map = result.map;
97
+ if(map.sources) {
98
+ map.sources = map.sources.map(function(source) {
99
+ return source.split("!").pop();
100
+ }, this);
101
+ map.sourceRoot = "";
102
+ }
103
+ map.file = map.file.split("!").pop();
104
+ map = JSON.stringify(map);
105
+ moduleJs = "exports.push([module.id, " + cssAsString + ", \"\", " + map + "]);";
106
+ } else {
107
+ moduleJs = "exports.push([module.id, " + cssAsString + ", \"\"]);";
108
+ }
109
+
110
+ // embed runtime
111
+ callback(null, "exports = module.exports = require(" + loaderUtils.stringifyRequest(this, require.resolve("./css-base.js")) + ")();\n" +
112
+ "// imports\n" +
113
+ importJs + "\n\n" +
114
+ "// module\n" +
115
+ moduleJs + "\n\n" +
116
+ "// exports\n" +
117
+ exportJs);
118
+ }.bind(this));
119
+ };
@@ -1,46 +1,46 @@
1
- /*
2
- MIT License http://www.opensource.org/licenses/mit-license.php
3
- Author Tobias Koppers @sokra
4
- */
5
- var loaderUtils = require("loader-utils");
6
- var processCss = require("./processCss");
7
- var getImportPrefix = require("./getImportPrefix");
8
- var compileExports = require("./compile-exports");
9
-
10
-
11
- module.exports = function(content) {
12
- if(this.cacheable) this.cacheable();
13
- var callback = this.async();
14
- var query = loaderUtils.parseQuery(this.query);
15
- var moduleMode = query.modules || query.module;
16
- var camelCaseKeys = query.camelCase || query.camelcase;
17
-
18
- processCss(content, null, {
19
- mode: moduleMode ? "local" : "global",
20
- query: query,
21
- minimize: this.minimize,
22
- loaderContext: this
23
- }, function(err, result) {
24
- if(err) return callback(err);
25
-
26
- // for importing CSS
27
- var importUrlPrefix = getImportPrefix(this, query);
28
-
29
- function importItemMatcher(item) {
30
- var match = result.importItemRegExp.exec(item);
31
- var idx = +match[1];
32
- var importItem = result.importItems[idx];
33
- var importUrl = importUrlPrefix + importItem.url;
34
- return "\" + require(" + loaderUtils.stringifyRequest(this, importUrl) + ")" +
35
- "[" + JSON.stringify(importItem.export) + "] + \"";
36
- }
37
-
38
- var exportJs = compileExports(result, importItemMatcher.bind(this), camelCaseKeys);
39
- if (exportJs) {
40
- exportJs = "module.exports = " + exportJs + ";";
41
- }
42
-
43
-
44
- callback(null, exportJs);
45
- }.bind(this));
46
- };
1
+ /*
2
+ MIT License http://www.opensource.org/licenses/mit-license.php
3
+ Author Tobias Koppers @sokra
4
+ */
5
+ var loaderUtils = require("loader-utils");
6
+ var processCss = require("./processCss");
7
+ var getImportPrefix = require("./getImportPrefix");
8
+ var compileExports = require("./compile-exports");
9
+
10
+
11
+ module.exports = function(content) {
12
+ if(this.cacheable) this.cacheable();
13
+ var callback = this.async();
14
+ var query = loaderUtils.getOptions(this) || {};
15
+ var moduleMode = query.modules || query.module;
16
+ var camelCaseKeys = query.camelCase || query.camelcase;
17
+
18
+ processCss(content, null, {
19
+ mode: moduleMode ? "local" : "global",
20
+ query: query,
21
+ minimize: this.minimize,
22
+ loaderContext: this
23
+ }, function(err, result) {
24
+ if(err) return callback(err);
25
+
26
+ // for importing CSS
27
+ var importUrlPrefix = getImportPrefix(this, query);
28
+
29
+ function importItemMatcher(item) {
30
+ var match = result.importItemRegExp.exec(item);
31
+ var idx = +match[1];
32
+ var importItem = result.importItems[idx];
33
+ var importUrl = importUrlPrefix + importItem.url;
34
+ return "\" + require(" + loaderUtils.stringifyRequest(this, importUrl) + ")" +
35
+ "[" + JSON.stringify(importItem.export) + "] + \"";
36
+ }
37
+
38
+ var exportJs = compileExports(result, importItemMatcher.bind(this), camelCaseKeys);
39
+ if (exportJs) {
40
+ exportJs = "module.exports = " + exportJs + ";";
41
+ }
42
+
43
+
44
+ callback(null, exportJs);
45
+ }.bind(this));
46
+ };