Skip to content

Commit

Permalink
Merge pull request #5098 from KTruong888/4099_es6_refactor_dep_depblo…
Browse files Browse the repository at this point in the history
…ckhelpers

Issue #4099: ES6 Refactor for depdendencies/DepBlockHelpers.js
  • Loading branch information
sokra committed Jul 1, 2017
2 parents 53944e8 + 98951d1 commit 42cdfed
Showing 1 changed file with 16 additions and 19 deletions.
35 changes: 16 additions & 19 deletions lib/dependencies/DepBlockHelpers.js
Expand Up @@ -2,41 +2,38 @@
MIT License http://www.opensource.org/licenses/mit-license.php
Author Tobias Koppers @sokra
*/
var DepBlockHelpers = exports;
"use strict";

DepBlockHelpers.getLoadDepBlockWrapper = function(depBlock, outputOptions, requestShortener, name) {
var promiseCode = DepBlockHelpers.getDepBlockPromise(depBlock, outputOptions, requestShortener, name);
const DepBlockHelpers = exports;

DepBlockHelpers.getLoadDepBlockWrapper = (depBlock, outputOptions, requestShortener, name) => {
const promiseCode = DepBlockHelpers.getDepBlockPromise(depBlock, outputOptions, requestShortener, name);
return [
promiseCode + ".then(",
").catch(",
")"
];
};

DepBlockHelpers.getDepBlockPromise = function(depBlock, outputOptions, requestShortener, name) {
DepBlockHelpers.getDepBlockPromise = (depBlock, outputOptions, requestShortener, name) => {
if(depBlock.chunks) {
var chunks = depBlock.chunks.filter(function(chunk) {
return !chunk.hasRuntime() && chunk.id !== null;
});
const chunks = depBlock.chunks.filter(chunk => !chunk.hasRuntime() && chunk.id !== null);
const pathChunkCheck = outputOptions.pathinfo && depBlock.chunkName;
const shortChunkName = requestShortener.shorten(depBlock.chunkName);
const chunkReason = asComment(depBlock.chunkReason);
const requireChunkId = chunk => "__webpack_require__.e(" + JSON.stringify(chunk.id) + ")";
name = asComment(name);
if(chunks.length === 1) {
var chunk = chunks[0];
return "__webpack_require__.e" + asComment(name) + "(" + JSON.stringify(chunk.id) + "" +
(outputOptions.pathinfo && depBlock.chunkName ? "/*! " + requestShortener.shorten(depBlock.chunkName) + " */" : "") +
asComment(depBlock.chunkReason) + ")";
const chunkId = JSON.stringify(chunks[0].id);
return `__webpack_require__.e${name}(${chunkId}${pathChunkCheck ? "/*! " + shortChunkName + " */" : ""}${chunkReason})`;
} else if(chunks.length > 0) {
return "Promise.all" + asComment(name) + "(" +
(outputOptions.pathinfo && depBlock.chunkName ? "/*! " + requestShortener.shorten(depBlock.chunkName) + " */" : "") +
"[" +
chunks.map(function(chunk) {
return "__webpack_require__.e(" + JSON.stringify(chunk.id) + ")";
}).join(", ") +
"])";
return `Promise.all${name}(${pathChunkCheck ? "/*! " + shortChunkName + " */" : ""}[${chunks.map(requireChunkId).join(", ")}])`;
}
}
return "new Promise(function(resolve) { resolve(); })";
};

function asComment(str) {
if(!str) return "";
return "/* " + str + " */";
return `/* ${str} */`;
}

0 comments on commit 42cdfed

Please sign in to comment.