import BaseFolder from './BaseFolder'; import ConcatenatedModule from './ConcatenatedModule'; import Module from './Module'; import {getModulePathParts} from './utils'; export default class Folder extends BaseFolder { get parsedSize() { return this.src ? this.src.length : 0; } get gzipSize() { if (!Object.prototype.hasOwnProperty.call(this, '_gzipSize')) { this._gzipSize = this.src ? 999999 : 0; // TODO - fix this } return this._gzipSize; } addModule(moduleData) { const pathParts = getModulePathParts(moduleData); if (!pathParts) { return; } const [folders, fileName] = [pathParts.slice(0, -1), pathParts[pathParts.length - 1]]; let currentFolder = this; folders.forEach(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, }; } }