import _ from 'lodash'; import gzipSize from 'gzip-size'; import Module from './Module'; import BaseFolder from './BaseFolder'; import ConcatenatedModule from './ConcatenatedModule'; import {getModulePathParts} from './utils'; export default class Folder extends BaseFolder { get parsedSize() { return this.src ? this.src.length : 0; } get gzipSize() { if (!_.has(this, '_gzipSize')) { this._gzipSize = this.src ? gzipSize.sync(this.src) : 0; } return this._gzipSize; } addModule(moduleData) { const pathParts = getModulePathParts(moduleData); if (!pathParts) { return; } const [folders, fileName] = [pathParts.slice(0, -1), _.last(pathParts)]; let currentFolder = this; _.each(folders, folderName => { let childNode = currentFolder.getChild(folderName); if ( // Folder is not created yet !childNode || // In some situations (invalid usage of dynamic `require()`) webpack generates a module with empty require // context, but it's moduleId points to a directory in filesystem. // In this case we replace this `File` node with `Folder`. // See `test/stats/with-invalid-dynamic-require.json` as an example. !(childNode instanceof Folder) ) { childNode = currentFolder.addChildFolder(new Folder(folderName)); } currentFolder = childNode; }); const ModuleConstructor = moduleData.modules ? ConcatenatedModule : Module; const module = new ModuleConstructor(fileName, moduleData, this); currentFolder.addChildModule(module); } toChartData() { return { ...super.toChartData(), parsedSize: this.parsedSize, gzipSize: this.gzipSize }; } };