hexapod
hexapod copied to clipboard
Optimize: Reduce Bundle Size Further
Using only a partial bundle of Plotly reduced the bundle size by 50%. Right now, Plotly still occupies 75% of the bundle. https://github.com/mithi/hexapod/issues/54
Other things that we can try:
- [x] Remove
MathJS
as dependency and just write all the matrix multiplications from scratch - [x] Remove
ReactMarkdown
and just write them in html - [x] Figure out if
react-icons
is taking up more space than it should - [x] Check if it's a good idea to use
preact
andeject
Related Links
Eject
- https://codeburst.io/how-i-cut-my-react-javascript-bundle-size-in-half-with-three-lines-of-code-fe7798ecbd3f
Preact
- https://preactjs.com/guide/v10/switching-to-preact
Codesplitting
- https://reactjs.org/docs/code-splitting.html
- https://www.emgoto.com/react-bundles-and-code-splitting/
Importing only one icon from react-icon
- https://hackernoon.com/lets-make-our-bundle-size-even-smaller-7a5727bb110
Bundle-size reduced by about 10 percent when mathjs was removed
See https://github.com/mithi/hexapod/issues/77
Started with
data:image/s3,"s3://crabby-images/c6d9c/c6d9c6242a1668024fd07ed8fb4ac60fc2caa2c6" alt="84758276-d3000c00-aff7-11ea-8b5e-ddf4540929f2"
data:image/s3,"s3://crabby-images/a0673/a067361592e7c5eee5f7e154a8e6821f10e5f17f" alt="84758285-d72c2980-aff7-11ea-9181-d84dc7d1fab8"
After using partial plotly bundle
data:image/s3,"s3://crabby-images/e719a/e719a178cd4f18b1a8ad6a7c60eb35d8d103f305" alt="85318791-2b9d4080-b4f3-11ea-862a-6b21a6108429"
After removing mathjs
data:image/s3,"s3://crabby-images/18f16/18f1621899cbb6e16540ee14fd9f3c4799b0ed6d" alt="85318826-3952c600-b4f3-11ea-9dd5-960619d5d6c5"
data:image/s3,"s3://crabby-images/2b1d3/2b1d3099ce4fb38a6c631228abaaf2f6eefc4d77" alt="85318883-538ca400-b4f3-11ea-9afa-63b2fbbcf2de"
I have a branch where React Markdown has been removed and the Pages are split into a bundle of its own.
Which ends up at roughly 1.76 MB, as follows, with 7.3ea032e0.chunk.js
being Plotly D3, which is dynamically loaded, so it doesn't block first paint. The other main bundle 6.3db6acf1.chunk.js
is the react-plotly.js/factory
module, also dynamically loaded.
4096 build/precache-manifest.9260a653dee23e8e967e8f2a9c3bc098.js
4096 build/static/js/Landing.da6e3571.chunk.js
4096 build/static/js/FwdKinematics.f7b1e2d0.chunk.js
4096 build/static/js/runtime-main.7c59d658.js
4096 build/static/js/InvKinematics.1f0dbfd6.chunk.js
1474560 build/static/js/7.3ea032e0.chunk.js
188416 build/static/js/6.3db6acf1.chunk.js
4096 build/static/js/LegPattern.65248188.chunk.js
49152 build/static/js/main.0d6601bf.chunk.js
8192 build/static/js/8.e4f8fe4a.chunk.js
8192 build/static/css/main.1739d554.chunk.css
4096 build/service-worker.js
4096 build/index.html
1761280 total
Compared to running on master as of now, which ends up at 1.79MB, big win yay!
4096 build/precache-manifest.2b3e83a9c10cab01a0fa7334d2b6b0bf.js
1724416 build/static/js/2.2d4e33b3.chunk.js
4096 build/static/js/runtime-main.d4e56be3.js
49152 build/static/js/main.384eb958.chunk.js
8192 build/static/css/main.25fbfe7e.chunk.css
4096 build/service-worker.js
4096 build/index.html
1798144 total
The biggest win is that you can paint the first screen faster. Next step, though not blocked by this, would be to enable the service worker and have a sound offline mode.
I still need to do some work on the PR, but might come up soon.
@icyJoseph , thanks! Because I've merged your PR multiple times, I'll like to add you at the bottom of this repo's README as one of the main contributors. I'd do this if that's alright with you :)
Oh thank you! Like I said before I really like this project! So yeah, that's alright!