Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor: optimize bundling performance, pre-transpile client code so that sites don't have to #10062

Closed
wants to merge 11 commits into from

Conversation

slorber
Copy link
Collaborator

@slorber slorber commented Apr 19, 2024

Motivation

The idea is that sites should not need to transpile official Docusaurus client code, saving time when bundling.

We can ship those client libs pre-transpiled by default so that they can be excluded from our JS loader.

There are some challenges to resolve:

  • Does it have a significant perf impact?
  • What's the ideal config for transpiling our client code?
  • Is it safe regarding browserlist config?
  • We should ensure swizzled JS components are still readable (is preserve JSX)
  • Will ESM-only libs be a problem?
  • Translation extraction should still work, and currently assume JSX (<Translate> is preserved)
  • Should we still transpile third-party client code?

Test Plan

tests + CI + dogfood

Test links

https://deploy-preview-10062--docusaurus-2.netlify.app/

@slorber slorber added the pr: performance This PR does not add a new behavior, but existing behaviors will be more memory- / time-efficient. label Apr 19, 2024
@facebook-github-bot facebook-github-bot added the CLA Signed Signed Facebook CLA label Apr 19, 2024
Copy link

netlify bot commented Apr 19, 2024

[V2]

Name Link
🔨 Latest commit 7f4dbef
🔍 Latest deploy log https://app.netlify.com/sites/docusaurus-2/deploys/662a9aa31c7dc4000898aa5c
😎 Deploy Preview https://deploy-preview-10062--docusaurus-2.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

Copy link

github-actions bot commented Apr 19, 2024

⚡️ Lighthouse report for the deploy preview of this PR

URL Performance Accessibility Best Practices SEO PWA Report
/ 🟠 70 🟢 98 🟢 96 🟢 100 🟠 88 Report
/docs/installation 🟠 59 🟢 96 🟢 100 🟢 100 🟠 88 Report
/docs/category/getting-started 🟠 77 🟢 100 🟢 100 🟢 90 🟠 88 Report
/blog 🟠 67 🟢 100 🟢 100 🟢 90 🟠 88 Report
/blog/preparing-your-site-for-docusaurus-v3 🟠 63 🟢 96 🟢 100 🟢 100 🟠 88 Report
/blog/tags/release 🟠 69 🟢 100 🟢 100 🟠 80 🟠 88 Report
/blog/tags 🟠 73 🟢 100 🟢 100 🟢 90 🟠 88 Report

Copy link

github-actions bot commented Apr 19, 2024

Size Change: -39.8 kB (-2%)

Total Size: 1.55 MB

Filename Size Change
website/build/assets/js/main.********.js 770 kB -39.8 kB (-5%)
ℹ️ View Unchanged
Filename Size
website/.docusaurus/codeTranslations.json 2 B
website/.docusaurus/docusaurus.config.mjs 26.7 kB
website/.docusaurus/globalData.json 91.2 kB
website/.docusaurus/i18n.json 930 B
website/.docusaurus/registry.js 247 kB
website/.docusaurus/routes.js 156 kB
website/.docusaurus/routesChunkNames.json 109 kB
website/.docusaurus/site-metadata.json 2.17 kB
website/build/assets/css/styles.********.css 113 kB
website/build/index.html 38 kB

compressed-size-action

@slorber
Copy link
Collaborator Author

slorber commented Apr 25, 2024

I decided to stop investigating this optimization for now, because the impact is not significant enough compared to the extra complexity it involves.

Here's the result on my computer (Mac M3)

Bundling the initial template (contains few docs, mostly the theme code):

  • Before: bundles in 6.7s
  • After: bundles in 6.2s

Bundling our website (more docs):

  • Before: bundles in 45s
  • After: bundles in 44s

So:

  • We save less than 1sec (on a fast computer though)
  • This saving does not scale with the size of a site, this only applies to our theme files, and the number of files does not grow over time
  • It mostly impacts cold builds, and not incremental build using Webpack cache
  • It slows down the DX by requiring to emit our theme code in 2 variants (pretranspiled + beautiful JSX for sizzling purpose)

For that reason, let's close this for now

@slorber slorber closed this Apr 25, 2024
@Josh-Cena Josh-Cena deleted the slorber/perf-pretranspile-client-libs branch April 25, 2024 19:00
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
CLA Signed Signed Facebook CLA pr: performance This PR does not add a new behavior, but existing behaviors will be more memory- / time-efficient.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants