[webpack-model]
- temporary revert long-module-id
[cli]
- add inject-extension into cli
[cli]
- addinject-extension
command that injects custom stats extension[cli]
- addvrules
command that shows available validation rules that plugins instatoscope.config.js
provides (#192 by @denisbalyko)
[report-writer]
- fix decompression bug (closes #202)[webpack-model]
- fix assets collection when CompressionWebpackPlugin is used[webpack-model]
- fix trimming long module ids[webpack-ui]
- module search now works only for first 500 chars in module name (performance issue)[webpack-ui]
- fix incorrect badge for asset modules
[webpack-plugin]
- super-huge (up to 30 times) decrease of html-report size[cli]
- super-huge (up to 30 times) decrease of html-report size
[webpack-model]
- trim long module identifier (closes #200)[webpack-ui]
- fix descending modules sort on instant lists (related #162)
-
[webpack-ui]
- replacehighcharts
by chart.jsUsage example:
{ "view": "box", "options": { "height": "400px" }, "content": { "view": "chart", "data": "{ any chart.js options here }" } }
-
[webpack-ui]
- adderror
-view:{ "view": "error", "message": "Some error message" }
-
[cli]
- js-files can be used incustomReport
-arg -
[helpers]
- addoptions
-parameter intoformatData
-helper just like Date.toLocaleString
[webpack-model]
- remove stats validation (increase startup performance)
[helpers]
- updatejora
to 1.0.0-beta.7[webpack-ui]
- update@discoveryjs/discovery
to 1.0.0-beta.66[webpack-ui]
- updatehighcharts
to 10.2.0
[webpack-model]
- refactor chunk graph building (fixes bugs of chunks relations accuracy)
This is 5.21 actually 🤦
[cli]
- add--custom-report
and--config
args forgenerate
andserve
commands (#157 by @amalitsky)[config]
- addgenerate.reports
field (#157 by @amalitsky)[webpack-model]
- added helpers:asset_getSize(asset: NormalizedAsset, hash: string, useCompressed: boolean): Size
assets_getTotalSize(assets: NormalizedAsset[], hash: string, useCompressed: boolean): Size
entrypoint_getChunks(entry: NormalizedEntrypointItem): NormalizedChunk[]
entrypoint_getInitialChunks(entry: NormalizedEntrypointItem): NormalizedChunk[]
entrypoint_getInitialSize(entry: NormalizedEntrypointItem, hash: string, useCompressed: boolean): Size
entrypoint_getAsyncChunks(entry: NormalizedEntrypointItem): NormalizedChunk[]
entrypoint_getAsyncSize(entry: NormalizedEntrypointItem, hash: string, useCompressed: boolean): Size
entrypoint_getAssets(entry: NormalizedEntrypointItem): NormalizedAsset[]
entrypoint_getInitialAssets(entry: NormalizedEntrypointItem): NormalizedAsset[]
entrypoint_getAsyncAssets(entry: NormalizedEntrypointItem): NormalizedAsset[]
resolveCompilationByAsset(asset: NormalizedAsset, filename: string): NormalizedCompilation | null
resolveCompilationByChunk(chunk: NormalizedChunk, filename: string): NormalizedCompilation | null
resolveCompilationByModule(module: NormalizedModule, filename: string): NormalizedCompilation | null
resolveCompilationByEntrypoint(entry: NormalizedEntrypointItem, filename: string): NormalizedCompilation | null
[webpack-ui]
- fix dashboard data[webpack-model]
- fix handling chunks with no files (#158 by @amalitsky)
[webpack-model]
- move @types/webpack into dev deps
[webpack-model]
- huge performance improvement for stats normalization
[webpack-plugin]
- addnormalizeStats
that reduces stats size[webpack-ui]
-options
anddata
props forchart
-view as jora-query
[cli]
- minor fix forgenerate
-command output
[webpack-ui]
- use the brand new Statoscope logo[report-writer]
- use logo as loading spinner
[stats-extension-package-info]
- collect more package versions[webpack-stats-extension-package-info]
- collect more package versions
[webpack-ui]
- fix chunk modules delta
[webpack-stats-extension-package-info]
- collect more package versions
[webpack-model]
- smart handling for concat modules container id This improves modules diff.[helpers]
- add id modifier to indexer[cli]
- addinit
andcreate
commands (#139 by @wildOrlik)
[config]
- more useful error message if any of plugins or reporters from statoscope config is not installed (#137 by @amalitsky)
[webpack-model]
- fix d.ts
[webpack-model]
- support grouped modules (stats: { all: true }
in webpack 5)[webpack-model]
- improvedchunkName
helper NowchunkName
helper returns more accurate chunk name[webpack-model]
- addassetChunkName
helper
[webpack-model]
- total stats preparing refactoring
[cli]
- Supportreference
-arg forgenerate
andserve
commands (#134)[webpack-ui]
- Useinput
andreference
files by default for diff page (#134)[webpack-ui]
- Add details to chunks-tab (Added/Removed/Changed modules) at diff page. (#133 by @andreygmc)
[stats-validator-plugin-webpack]
- adddescription
andalternatives
forrestricted-packages
rule (#129 by @amalitsky)
Republish all the packages because of npm bug
No changes
[cli]
- addquery
command (#130)[cli]
- addinject-report
command
[webpack-ui]
- use report id when no report name specified
[stats-extension-custom-reports]
- handleReport returns boolean instead of throw an error
[types]
- rename .ts to .d.ts
-
[webpack-ui]
- update highcharts to v9 -
[webpack-ui]
- addbox
-view to build flex layout[{ view: 'box', content: [ { view: 'box', content: 'struct' }, { view: 'box', content: 'struct' }, { view: 'box', content: 'struct' }, ] }, { view: 'box', options: { direction: 'column' }, content: [ { view: 'box', content: 'struct' }, { view: 'box', content: 'struct' }, ] }]
There are some supported options:
display
direction
shrink
grow
alignItems
justifyItems
alignContent
justifyContent
width
height
padding
margin
-
[webpack-model]
- addresolveExtensionByCompilation
-helper - resolves extension by id and compilation -
[webpack-model]
-resolveExtension*
resolves extension even if the extension has no API (not warning anymore) -
[webpack-model]
- add StatsExtensionWebpackAdapter type -
[webpack-plugin]
- addextensions
-options (see plugin readme for more info)
[webpack-model]
-resolveExtension
resolves extension by its name and filename that the extension attached to[webpack-stats-extension-compressed]
- implement webpack stats extension interface[webpack-stats-extension-package-info]
- implement webpack stats extension interface
[types]
- add types into package
[cli]
- output is no longer a required argument (tmp directory is used by default) (#119 by @wildOrlik)
[webpack-model]
- fix crash when unknown extension is used[webpack-model]
- fix crash with regenerator runtime
-
[webpack-ui]
- fixshouldExcludeResource
-helperNow returns true if no regexp specified
[webpack-ui]
- use default target for babel-env (support more browsers)
-
[webpack-ui]
- add new options to specify a regexpAll assets matched the regexp will be ignored from download size/time calculation
-
[stats-validator-plugin-webpack]
- add asset-type exclude todiff-entry-download-size-limits
-rule -
[stats-validator-plugin-webpack]
- add asset-type exclude todiff-entry-download-time-limits
-rule -
[stats-validator-plugin-webpack]
- add asset-type exclude toentry-download-size-limits
-rule -
[stats-validator-plugin-webpack]
- add asset-type exclude toentry-download-time-limits
-rule
[webpack-ui]
- improve settings popup
[cli]
- use>=12.0.0
instead of^12.0.0
in engines.node
[stats-validator-plugin-webpack]
- use compilation hash instead of compilation name
[webpack-stats-extension-package-info]
- fix crash if there is no context in stats config
[stats-validator-plugin-webpack]
- fixdiff-deprecated-packages
rule[stats-validator-plugin-webpack]
- fixdiff-deprecated-modules
rule
[webpack-ui]
- addchart
-view (based on highcharts){ view: 'chart, options: [/* any highcharts options */] }
[webpack-plugin]
- fix crash if there is no context in stats config
-
[stats-extension-custom-reports]
- add package for passing custom reports to the UI (#108) -
[webpack-plugin]
- support custom reports (#108) -
[webpack-ui]
- support custom reports (#108) -
[helpers]
- supportlock
/unlock
forResolver
(#107) By default, all the resolvers is locked (no items can be added to resolver storage)const resolver = makeResolver(modules, m => m.identifier); modules.push(fooModule); resolver('foo'); // null resolver.unlock(); // allow to fetch resolver storage for new elements modules.push(fooModule); resolver('foo'); // fooModule
In other words, locked resolver remembers its source items and ignores any source changes.
It is useful for performance.
-
[helpers]
- addIndexer
to build an index (#108) Index is more complex of resolver. It provides some API to manipulate its storage:const moduleIndex = makeIndex(module => module.identifier); // no source needed moduleIndex.add(fooModule); moduleIndex.get('foo'); // fooModule moduleIndex.get('bar'); // null moduleIndex.add(barModule); moduleIndex.get('bar'); // barModule moduleIndex.getAll(); // [fooModule, barModule]
-
[stats-extension-compressed]
- support indexer (#108) -
[stats-extension-package-info]
- support indexer (#108) -
[stats-extension-stats-validation-result]
- support indexer (#108) -
[config]
- addrequireConfig
(#108) -
[cli]
- supportrequireConfig
(#108) -
[cli]
- addmakeReplacer
helper to create json replacer (#107) -
[webpack-model]
- add__statoscope.context
field (#107) -
[report-writer]
- remove context path from stats (it makes all the path relative from context) (#107) -
[webpack-plugin]
- remove context path from stats (it makes all the path relative from context) (#107) -
[webpack-stats-extension-package-info]
- remove context path from stats (it makes all the path relative from context) (#107)
-
[webpack-model]
- use module.identifier to resolve a module (#107) -
[webpack-model]
- decouple extension and compilation (#108)Extensions have attached to files, not to compilations
-
[webpack-ui]
- usemodule.identifier
to resolve a module (#107) -
[webpack-stats-extension-compressed]
- usemodule.identifier
to resolve a module (#107) -
[stats-validator-plugin-webpack]
- usemodule.identifier
to resolve a module (#107)
[webpack-model]
- not fail when incomplete stats have used
[stats-validator-plugin-webpack]
- fix chunk resolving indiff-entry-download-size-limits
rule (#106)[stats-validator-plugin-webpack]
- fix chunk resolving indiff-entry-download-time-limits
rule (#106)
[cli, webpack-plugin, stats-validator-reporter-stats-report]
- generate UI-reports with normalized stats (#104) It reduces generated UI-report size (sometimes it is more than 10x smaller)[webpack-model, webpack-ui]
- support normalized UI-reports (#104)[stats-validator-plugin-webpack]
- show changed reasons in diff-deprecated-modules/packages rules
[webpack-model]
- merge modules chunks info to collect more truthy info about modules chunks (#104)
[webpack-ui]
- remove modules duplicates from modules list
[webpack-ui]
- improve performance ofentries
andmodules
tabs on the main page
[webpack-ui]
- correct set of modules inInitial Chunks
tab on theentry
page (closes #102)
[config]
- improve error message
[webpack-model]
- add missed json into the package
[stats-validator]
- add package for validating stats[stats-validator-plugin-webpack]
- add stats-validator plugin with webpack-rules[stats-validator-reporter-console]
- add stats-validator reporter to output results into console[stats-validator-reporter-stats-report]
- add stats-validator reporter to output results into descovery-based UI[stats-extension-stats-validation-result]
- add stats extension to pass validation messages info descovery-based UI[config]
- add package that contains config-helpers[webpack-ui]
- support new validation results- support
stats-extension-stats-validation-result
- show badge in the main page
- new page with validation results
- new page with details of a validation message
- mark entities (modules, chunks, packages, etc.) that have messages from the validator
- show validation messages of the entities pages (modules, chunks, packages, etc.)
- support
[webpack-ui]
- add some jora-helpersresolveEntrypoint(id: string, hash: string): NormalizedEntrypointItem | null
Resolve entrypoint by its nameresolveFile(id: string): NormalizedFile | null
Resolve file by its nameresolveInputFile(): NormalizedFile | null
Resolve file withinput.json
resolveReferenceFile(): NormalizedFile | null
Resolve file withreference.json
validation_getItems(hash?: string, relatedType?: RelatedItem['type'] | null, relatedId?: string | number): Item[]
Get validation messagesvalidation_getItem(id?: number, hash?: string): Item | null
Get validation messagevalidation_resolveRelatedItem(item?: RelatedItem, hash?: string): ResolvedRelatedItem
Resolve an entity (module, chunk, etc.) that related with some messagevalidation_resolveRule(name?: string, hash?: string): RuleDescriptor | null
Resolve detail info about a rule
[cli]
- support new validators invalidate
command- add
reference
-parameter - add
config
-parameter - use
stats-validator
package
- add
[types]
- add package with statoscope ts-types[helpers]
- addget
-parameter intomakeResolver
-function[helpers]
- addasciiTree
-helper that generate ASCII tree from object-tree (useful for TTY-reporters)[helpers]
- add a bunch of useful jora-helpers-
typeof(value: unknown): string
works like native
typeof
operator -
isNullish(value: unknown): boolean
returns
true
ifvalue
isnull
orundefined
-
isArray(value: unknown): boolean
returns
true
ifvalue
is array -
useNotNullish<T>(values: readonly T[]): T | null
return first not-nullish element from
values
-array ornull
([null, 123].useNotNullish() = 123
) -
serializeStringOrRegexp(value?: string | RegExp): SerializedStringOrRegexp | null
transform string or regexp into json-compatible format
-
deserializeStringOrRegexp(value?: SerializedStringOrRegexp | null): string | RegExp | null
reverse the result of
serializeStringOrRegexp
-
semverSatisfies(version: string | SemVer, range: string | Range): boolean
returns
true
ifversion
satisfied of range -
isMatch(a?: string, b?: string | RegExp): boolean
returns
true
ifa
matchesb
-
exclude<T>( items: readonly T[], params?: { exclude?: Array<string | RegExp>; get?: (arg: T) => string | undefined; } ): T[]
Helps to exclude elements. Examples:
['foo', 'bar', 'foo'].exclude({exclude: 'foo'}) = ['bar']
[fooCompilation, barCompilation, bazCompilation].exclude({exclude: /foo|bar/, get: <name>}) = [bazCompilation]
-
diff_normalizeLimit(limit?: number | Limit | null): Limit | null
Normalize thelimit
-
diff_isLTETheLimit(valueDiff: ValueDiff, limit?: number | Limit | null): boolean
Returnstrue
ifvalueDiff
has not been exceeded thelimit
-
[report-writer]
- movetransform
function fromcli
[report-writer]
-to
-parameter oftransform
function now is required[report-writer]
-from
-parameter oftransform
might be file name or stats object[cli]
- usetransform
fromreport-writer
[helpers]
- moveprepareWithJora
fromwebpack-model
[webpck-model]
- useprepareWithJora
fromhelpers
[helpers]
- fixmax
-parameter bug ingraph_findPaths
-helper
[cli]
-validator
parameter invalidate
command (use statoscope config with rules instead)
[webpack-model]
- calculating modules size onfoam-tree
-helper[webpack-ui]
- show modules size on foam-tree map
[helpers]
fix handlingmax
-property inGraph.findPaths
-
[webpack-ui]
add entrypoint tab into the module page. How it's possible to inspect all the paths from specific module to an entrypoint -
[webpack-ui]
add entrypoint into issuer path -
[helpers]
addGraph
,Node
andSolutionPath
classes to solve the graph-specific tasks. Add a few jora-helpers:graph_getNode(id, graph)
- get a node by its idgraph_getPaths(from, graph, to, max)
- get all ormax
possible paths fromfrom
node toto
node
-
[webpack-model]
adddeps
for every module. There are all the modules that the module requires -
[webpack-model]
adddep
for every entrypoint. There is a module that an entrypoint requires -
[webpack-model]
addresolvedEntry
andresolvedEntryName
for entrypoint-reasons -
[webpack-model]
add a few jora-helpers:getModuleGraph(hash)
- get module graph for specified compilationmoduleGraph_getEntrypoints(module, graph, entrypoints, max)
- get all ormax
entrypoints ofmodule
moduleGraph_getPaths(from, graph, to, max)
- get all ormax
possible paths fromfrom
module toto
module
[webpack-ui]
fix settings error when multiple tabs opened
[report-writer]
rollback to sync stream polling model[webpack-plugin]
broken html report
- clean all the packages from dev-files
[webpack-plugin]
add new propertysaveOnlyStats
[webpack-plugin]
add new propertysaveReportTo
(as a replacement forsaveTo
)
[webpack-plugin]
refactoring to make code more flexible[report-writer]
refactor work with the streams
[webpack-ui]
handle unresolved module reasons for a package[webpack-stats-extension-package-info]
match package version for webpack 4
[webpack-plugin]
sometimes a report was opening before it written to the disk[webpack-stats-extension-compressed]
fix fails on reexport usage on webpack 4[webpack-stats-extension-package-info]
taking into account that webpack 4 uses absolute path for some module names
[webpack-model]
stats extensions now works for child compilations
[ui-webpack]
use as an alias to webpack-ui and webpack-plugin[webpack-plugin]
create directory before write the stats and report[webpack-ui]
add package version-diff Adds the badges like:major upgrade from x.x.x
[helpers]
addsemverGT
-helper[helpers]
addsemverGTE
-helper[helpers]
addsemverLT
-helper[helpers]
addsemverLTE
-helper[helpers]
addsemverEQ
-helper[helpers]
addsemverDiff
-helper[helpers]
addsemverParse
-helper[webpack-model]
addcontext
-param to jora query-method (#82)[cli]
addcontext
-param to jora query-method (#82)
[webpack-stats-extension-compressed]
fix CssModule handling[webpack-stats-extension-compressed]
fix temporary assets handling
[helpers]
moveformatDiff
-helper fromwebpack-ui
[report-writer]
returnoptions.scripts
asArray<stirng, Item>
- fix all @statoscope-deps version for not to old versions
-
[webpack-plugin]
collect compressed (e.g. gzip) size of the resources (assets and modules)There is a new
compressor
- option that can befalse | 'gzip' | ['gzip', ZlibOptions] | CompressFunction
:-
'gzip'
(default) - compress all the resources with gzip (compression level - 6) and collect the compressed sizes -
['gzip', ZlibOptions]
- the same asgzip
but with custom zlib settings -
CompressFunction
- a function that takes source as an input and should return compressed size for this resource (useful if you want to use a non-gzip compressor) -
false
- don't collect compressed sizes
It uses
webpack-stats-extension-compressed
under the hood -
-
[webpack-plugin]
collect packages versionsIt uses
webpack-stats-extension-package-info
under the hood -
[webpack-ui]
taking compressed (e.g. gzip) size of the resources into accountThere is a new setting to taking resources compressed size into account.
If enabled then all the sizes will be shown as compressed.
New jora-helpers:
getModuleSize(module, hash)
return compressed or normal module sizegetAssetSize(asset, hash)
return compressed or normal asset size
It uses
stats-extension-compressed
under the hood and works only when the stats-file was taken fromwebpack-plugin@>=5.3
or any source that usesstats-extension-compressed
-
[webpack-ui]
taking packages versions into account and output these in all the package itemsAlso, added instance version into
compilations.nodeModules.instance
It uses
stats-extension-package-info
under the hood and works only when the stats-file was taken fromwebpack-plugin@>=5.3
or any source that usesstats-extension-package-info
-
[webpack-ui]
download time measureThere are two new settings to select network speed and assets inject type. A download time for assets/chunks/entrypoints will be calculated based on specified network speed and assets inject type.
There are two assets inject types:
-
sync
: download time =sum(downloadTime(assets))
Download time is a sum of the download time of all the assets -
async
: download time =max(downloadTime(assets))
Download time is a download time of most heavy asset (usefull ifasync
/defer
used to inject your assets)
The default network type is
3G Fast (1.37 MBit/s)
(like in Chromium).Assets inject type is
sync
by default. -
-
[webpack-ui]
addcompact
-property toasset/chunk/module/entry-item
-widgetThis property removes all the badges from the entity item
-
[webpack-ui]
addEntrypoints
tab ondiff
-pageHonestly, I just forgot to enable this tab a few releases ago 🙈
-
[stats-extension-compressed]
extension for collecting compressed resource sizesIt allows compressing specified resource content (
string
orBuffer
) withgzip
or any other compressor.Also, it contains the API to generate and extract this info.
-
[webpack-stats-extension-compressed]
webpack adapter forstats-extension-compressed
It allows collecting compressed resource sizes from webpack compilation
-
[stats-extension-package-info]
extension for collecting packages versionsIt allows compressing specified resource content (
string
orBuffer
) withgzip
or any other compressor.Also, it contains the API to generate and extract this info.
-
[webpack-stats-extension-package-info]
webpack adapter forstats-extension-package-info
It allows collecting package versions from webpack compilation
-
[webpack-model]
addedresolveExtension(name)
jora-helper that returns extension API -
[webpack-model]
supportstats-extension-package-info
extensionThere is a new jora-helpers:
getPackageInstanceInfo(package, instancePath, hash)
that returns a package instance information
-
[webpack-model]
supportstats-extension-compressed
extensionThere are new jora-helpers:
getModuleSize(module, compressed?, hash?)
returns compressed or normal module sizegetAssetSize(asset, compressed?, hash?)
returns compressed or normal asset size
-
[webpack-model]
added jora-helpers to getting network type and download speed:getNetworkTypeInfo(networkType: string)
return full info about specified network by its name (full list of type you can find at network-type-list.ts)getNetworkTypeName(networkType: Item)
return full name for specified networkgetDownloadTime(size: number, networkType: string)
calculate download time based on selected network type
-
[helpers]
addlocale
-parameter toformatDate
-helper -
[cli]
(validate): useinfo
-type for messages by default -
[stats]
a new package that contains Statoscope own stats format (extension-entity for now, but there are will be more entities) -
[extensions]
a new package that contains Statoscope extensions toolkit -
[report-writer]
add Piper - a proxy to ensure that all stream consumers have got a chunk
-
[webpack-model]
fix cases in normalization when nocompilation.modules
-
[webpack-model]
fix normalization ofchunk.children
-
[webpack-model]
fixisRoot
-field for node-modules instancesisRoot
was falsy positive if the module name not starts from.
-
[webpack-plugin]
fixsaveStatsTo
Now it works
-
[webpack-ui]
fix packages instances list ondiff
-pageThere was
undefined
instead of instances links -
[webpack-ui]
fix modules diff calculation -
[cli]
(validate): use console.info forinfo
-type messages
-
[webpack-ui]
better sorting of package instancesRoot-instances goes first
-
[webpack-ui]
fix loading-styles
[webpack-ui]
refactor diff-page to make it more flexible and extendable
[webpack-ui]
showasset module
badge for asset modules (#72)[webpack-model]
usechunk.name
inchunkName
-helper[webpack-plugin]
makeoptions
-parameter as optional
[webpack-plugin]
(crit) broken html report[webpack-plugin]
(crit) fix takingadditionalStats
into account[webpack-model]
makecontext
-parameter inPrepared.query
as optional (types)[webpack-model]
makestats
-parameter instatName
-helper as optional (types)
[webpack-ui]
fix popup positioning when page was scrolled
[cli]
migrate to typescript[webpack-plugin]
migrate to typescript[webpack-ui]
migrate to typescript[webpack-model]
migrate to typescript[report-writer]
migrate to typescript[helpers]
migrate to typescript
[cli]
fixgenerate
command[cli]
fix readme[webpack-plugin]
npm audit fix[webpack-ui]
npm audit fix
[ui-webpack]
BREAKING: deprecated in favor of new packagewebpack-ui
[cli]
new package with CLI tools (validate, generate, serve)[webpack-plugin]
new package with webpack plugin that generated statoscope report
[ui-webpack]
Module page: dependencies-block
[ui-webpack]
Diff modules bug
-
[ui-webpack]
Use modulename
instead ofidentifier
to more accuracy diff -
[ui-webpack]
Hide useless tabs at the diff page (#2130c74)For example, if there is no diff in the modules, then no Modules-tab will be shown
[ui-webpack]
Improve starting up performance at 25% (#6966139)[ui-webpack]
Huge improvement of diff performance (#1b8f346)
-
[ui-webpack]
BREAKING: remove separated-styles build -
[ui-webpack]
Handle all child compilations (#46d813c)Now Statoscope will handle all child compilation. It's useful for cases like GoogleChrome/workbox#2785 By default, Statoscope doesn't show any child compilation, but there is a setting
Hide child compilations
to change it. -
[ui-webpack]
Show chunk file size (#47)Now Statoscope shows a little more info about a chunk
[ui-webpack]
Update discovery[ui-webpack]
Update build stack (webpack/babel/etc) (#3371565)[ui-webpack]
Update foamtree (#9fb2116)
[plugin-webpack]
Improve stats normalization performance (#43)
[plugin-webpack]
Huge improvement for HTML-report loading time (#9b58295)
[ui-webpack]
Useelement
parameter on Statoscope init-function (#42)
-
[plugin, ui]
Support stats with any size.JS engines have a string size limit (e.g. 512mb for V8). It means that JSON with a size bigger than this limitation can't be parsed with JSON.parse
Now Statoscope uses a streaming JSON parsing (thanks to json-ext) to ignore this limitation.
-
[plugin-webpack]
AddsaveStatsTo: string
optionYou can save a webpack stats with
saveStatsTo: '/abs/path/to/stats.json'
Use
[name]
and[hash]
placeholders to replace these bycompilation.name
andcompilation.hash
-
[plugin-webpack]
AddadditionalStats: string[]
optionYou can load any stats to Statoscope to switch between them or diff these on the Diff page.
additionalStats: ['/abs/path/to/previous/stats.json']
-
[plugin-webpack]
AddstatsOptions: Object
optionYou can override your webpack-config
stats
option bystatsOptions
optionstatsOptions: { all: true, source: false }
All stats-options see at docs -
[plugin-webpack]
AddwatchMode:boolean
optionBy default, Statoscode does not generate a report if webpack run in watch-mode. Set
watchMode: true
to generate a report in watch-mode -
[plugin-webpack]
Add[name]
and[hash]
placeholders tostaveTo
option to replace these bycompilation.name
andcompilation.hash
[ui-webpack]
Fix resolving module resource that starts with..
-
Added webpack plugin
Now you could use Statoscope as a webpack plugin:
webpack.config.js:
const StatoscopeWebpackPlugin = require('@statoscope/ui-webpack'); config.plugins.push(new StatoscopeWebpackPlugin());
See the readme for more information.
- Update @discoveryjs/discovery to 1.0.0-beta.52
- Goto first compilation when load multiple stats or a stat with multiple compilations
-
[Breaking]: Change data structure
Now, Statoscope normalize the stats to a specific standardized structure.
You can see it at Make report page.
Every stat has some basic info (filename, webpack version) and a list of the compilations.
The modules/chunks/assets are resolved now
Statoscope init-function argument also changed:
import init from '@statoscope/ui-webpack'; import stats from 'path/to/stats.json'; init({ name: 'stats.json', data: stats, });
-
Stats diff
Statoscope provides a tool to diff the stats. Load two or more stats to diff it.
-
Support multiple stat files
Now you can load multiple stats and switch between them.
-
Support multi-config projects
If you have a multi-config project (e.g. client and server described in one config) then it will be splitter into a few compilations with possibility to switching between them.
-
Rework main page dashboard
Add some indicators:
Total size
- size of all the assets of your bundleInitial size
- size of all the initial assets of your bundlePackages size
- size of allDuplicate modules
- total modules with the same sourceBuild Time
Remove chunk groups indicator
-
Add duplicate module info
Now you can see all the modules with the same source
-
Add stats validation
-
Add deopt block to a module page
-
Add module issuer path
-
improve filtration speed
- Fix error in chunk packages list
- Fix incorrect chunks and modules filtration
- Fix packages list items limit
- ctrl + click on foam-tree opens a package or module detail page,
- improved popup markup
- allow passing custom root element to init the UI
- add style-less dist
- correct parsing modules name with absolute path
- ignore top-level modules in stats and collect these by the chunks
- use original module name if can't normalize it
- fix exception when mouse leave a foam-tree
- add modules reasons to the package tree
- fix module page when module id is number
- brand new webpack analyzer, webpack-runtime-analyzer was deprecated