| 'use strict'; | 
|   | 
| const toposort = require('toposort'); | 
| const _ = require('lodash'); | 
|   | 
| /** | 
|   Sorts dependencies between chunks by their "parents" attribute. | 
|   | 
|   This function sorts chunks based on their dependencies with each other. | 
|   The parent relation between chunks as generated by Webpack for each chunk | 
|   is used to define a directed (and hopefully acyclic) graph, which is then | 
|   topologically sorted in order to retrieve the correct order in which | 
|   chunks need to be embedded into HTML. A directed edge in this graph is | 
|   describing a "is parent of" relationship from a chunk to another (distinct) | 
|   chunk. Thus topological sorting orders chunks from bottom-layer chunks to | 
|   highest level chunks that use the lower-level chunks. | 
|   | 
|   @param {Array} chunks an array of chunks as generated by the html-webpack-plugin. | 
|   - For webpack < 4, It is assumed that each entry contains at least the properties | 
|   "id" (containing the chunk id) and "parents" (array containing the ids of the | 
|   parent chunks). | 
|   - For webpack 4+ the see the chunkGroups param for parent-child relationships | 
|   | 
|   @param {Array} chunks an array of ChunkGroups that has a getParents method. | 
|   Each ChunkGroup contains a list of chunks in order. | 
|   | 
|   @return {Array} A topologically sorted version of the input chunks | 
| */ | 
| module.exports.dependency = (chunks, options, compilation) => { | 
|   const chunkGroups = compilation.chunkGroups; | 
|   if (!chunks) { | 
|     return chunks; | 
|   } | 
|   | 
|   // We build a map (chunk-id -> chunk) for faster access during graph building. | 
|   const nodeMap = {}; | 
|   | 
|   chunks.forEach(chunk => { | 
|     nodeMap[chunk.id] = chunk; | 
|   }); | 
|   | 
|   // Next, we add an edge for each parent relationship into the graph | 
|   let edges = []; | 
|   | 
|   if (chunkGroups) { | 
|     // Add an edge for each parent (parent -> child) | 
|     edges = chunkGroups.reduce((result, chunkGroup) => result.concat( | 
|       Array.from(chunkGroup.parentsIterable, parentGroup => [parentGroup, chunkGroup]) | 
|     ), []); | 
|     const sortedGroups = toposort.array(chunkGroups, edges); | 
|     // flatten chunkGroup into chunks | 
|     const sortedChunks = sortedGroups | 
|       .reduce((result, chunkGroup) => result.concat(chunkGroup.chunks), []) | 
|       .map(chunk => // use the chunk from the list passed in, since it may be a filtered list | 
|     nodeMap[chunk.id]) | 
|       .filter((chunk, index, self) => { | 
|         // make sure exists (ie excluded chunks not in nodeMap) | 
|         const exists = !!chunk; | 
|         // make sure we have a unique list | 
|         const unique = self.indexOf(chunk) === index; | 
|         return exists && unique; | 
|       }); | 
|     return sortedChunks; | 
|   } else { | 
|     // before webpack 4 there was no chunkGroups | 
|     chunks.forEach(chunk => { | 
|       if (chunk.parents) { | 
|         // Add an edge for each parent (parent -> child) | 
|         chunk.parents.forEach(parentId => { | 
|           // webpack2 chunk.parents are chunks instead of string id(s) | 
|           const parentChunk = _.isObject(parentId) ? parentId : nodeMap[parentId]; | 
|           // If the parent chunk does not exist (e.g. because of an excluded chunk) | 
|           // we ignore that parent | 
|           if (parentChunk) { | 
|             edges.push([parentChunk, chunk]); | 
|           } | 
|         }); | 
|       } | 
|     }); | 
|     // We now perform a topological sorting on the input chunks and built edges | 
|     return toposort.array(chunks, edges); | 
|   } | 
| }; | 
|   | 
| /** | 
|  * Sorts the chunks based on the chunk id. | 
|  * | 
|  * @param  {Array} chunks the list of chunks to sort | 
|  * @return {Array} The sorted list of chunks | 
|  */ | 
| module.exports.id = chunks => chunks.sort(function orderEntryLast (a, b) { | 
|   if (a.entry !== b.entry) { | 
|     return b.entry ? 1 : -1; | 
|   } else { | 
|     return b.id - a.id; | 
|   } | 
| }); | 
|   | 
| /** | 
|  * Performs identity mapping (no-sort). | 
|  * @param  {Array} chunks the chunks to sort | 
|  * @return {Array} The sorted chunks | 
|  */ | 
| module.exports.none = chunks => chunks; | 
|   | 
| /** | 
|  * Sort manually by the chunks | 
|  * @param  {Array} chunks the chunks to sort | 
|  * @return {Array} The sorted chunks | 
|  */ | 
| module.exports.manual = (chunks, options) => { | 
|   const specifyChunks = options.chunks; | 
|   const chunksResult = []; | 
|   let filterResult = []; | 
|   if (Array.isArray(specifyChunks)) { | 
|     for (var i = 0; i < specifyChunks.length; i++) { | 
|       filterResult = chunks.filter(chunk => { | 
|         if (chunk.names[0] && chunk.names[0] === specifyChunks[i]) { | 
|           return true; | 
|         } | 
|         return false; | 
|       }); | 
|       filterResult.length > 0 && chunksResult.push(filterResult[0]); | 
|     } | 
|   } | 
|   return chunksResult; | 
| }; | 
|   | 
| /** | 
|  * Defines the default sorter. | 
|  */ | 
| module.exports.auto = module.exports.id; | 
|   | 
| // In webpack 2 the ids have been flipped. | 
| // Therefore the id sort doesn't work the same way as it did for webpack 1 | 
| // Luckily the dependency sort is working as expected | 
| if (Number(require('webpack/package.json').version.split('.')[0]) > 1) { | 
|   module.exports.auto = module.exports.dependency; | 
| } |