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

build: skip bundling fonts #779

Merged

Conversation

aloisklink
Copy link
Member

📑 Summary

Compile JavaScript code as an IIFE, allowing us to avoid needing to inline anything.

This makes the code about 10% faster for me (tests run in 105s instead of 120s), and the size on the bundle went from 4MiB to 3.5MiB.

Additionally, I've finally figured out the issue that was sometimes causing the FontAwesome icons to load incorrectly: sometimes Puppeteer was parsing the CSS FontAwesome as Latin-1 instead of UTF-8! Explicitly setting the script to have charset="utf-8" seems to fix this!

Resolves #699. Resolves #700

📏 Design Decisions

Instead of bundling everything into a single giant index.html file, it's more efficient to have separate files, as otherwise, some files (e.g. the .woff2 font files), need to be base64 encoding in the .html.

However, since file:// is only supported for IIFE JavaScript files (not ESM), I've written a tiny custom IIFE-converter plugin for Vite that creates IIFE files instead.

FontAwesome issues fixed

These Percy errors should now be fixed:

image

It turns out that FontAwesome v6's car icon is the following character: (e.g. the UTF-8 bytes are 0xef86b9). However, when Puppeteer was parsing the CSS, it was sometimes parsing it as Latin-1 instead of UTF-8, which instead resulted in the following characters:  (the Latin-1 bytes are still 0xef3fb9!). And since the font-file didn't have an entry for these three characters, it didn't display anything.

📋 Tasks

Make sure you

  • 📖 have read the contribution guidelines
  • 💻 have added unit/e2e tests (if appropriate)
  • 🔖 targeted master branch

Compile JavaScript code as an IIFE, allowing us to avoid needing to
inline anything.

This makes the code about 10% faster for me
(tests run in 105s instead of 120s), and the size on the bundle went
from 4MiB to 3.5MiB.

Additionally, I think I've finally figured out the issue that was
sometimes causing the FontAwesome icons to load incorrectly: sometimes
Puppeteer was parsing the CSS FontAwesome as Latin-1 instead of UTF-8!
Explicility setting the script to have `charset="utf-8"` seems to fix
this!
Copy link
Member

@MindaugasLaganeckas MindaugasLaganeckas left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Very nice work! Thank you! :)

@MindaugasLaganeckas MindaugasLaganeckas merged commit 202d0b5 into mermaid-js:master Nov 12, 2024
5 of 6 checks passed
@aloisklink aloisklink deleted the perf/skip-inlining-fonts branch November 12, 2024 12:27
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants