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

fix: minify injected CSS in prod mode #14006

Merged
merged 1 commit into from
Oct 30, 2024
Merged

fix: minify injected CSS in prod mode #14006

merged 1 commit into from
Oct 30, 2024

Conversation

dummdidumm
Copy link
Member

When CSS is externalized we rightfully rely on the following tooling chain to properly minify CSS. When we inject the CSS however, that tooling won't be able to do that, so we gotta do it ourselves. This PR brings back most of that logic that existed in Svelte 4. Fixes #13716

Before submitting the PR, please make sure you do the following

  • It's really useful if your PR references an issue where it is discussed ahead of time. In many cases, features are absent for a reason. For large changes, please create an RFC: https://github.com/sveltejs/rfcs
  • Prefix your PR title with feat:, fix:, chore:, or docs:.
  • This message body should clearly illustrate what problems it solves.
  • Ideally, include a test that fails without this PR but passes with it.

Tests and linting

  • Run the tests with pnpm test and lint the project with pnpm lint

Sorry, something went wrong.

Verified

This commit was signed with the committer’s verified signature. The key has expired.
Moser-ss Stephane Moser
When CSS is externalized we rightfully rely on the following tooling chain to properly minify CSS. When we inject the CSS however, that tooling won't be able to do that, so we gotta do it ourselves.
This PR brings back most of that logic that existed in Svelte 4. Fixes #13716
Copy link

changeset-bot bot commented Oct 28, 2024

🦋 Changeset detected

Latest commit: 1fcc210

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 1 package
Name Type
svelte Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@dummdidumm dummdidumm changed the title fix: minify inject CSS in prod mode fix: minify injected CSS in prod mode Oct 28, 2024
Copy link

pkg-pr-new bot commented Oct 28, 2024

pnpm add https://pkg.pr.new/svelte@14006

commit: 1fcc210

Copy link
Member

@Conduitry Conduitry left a comment

Choose a reason for hiding this comment

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

Is it reasonable to extract all of this minification code out to its own file, so we're not sprinkling a bunch of rarely used code throughout the style scoping code?

@dummdidumm
Copy link
Member Author

I think that would make things worse, because I would need to recreate some of the logic around pruning that's already there (like "is this selector used").

@dummdidumm dummdidumm merged commit 0106204 into main Oct 30, 2024
10 checks passed
@dummdidumm dummdidumm deleted the minify-css branch October 30, 2024 10:47
@github-actions github-actions bot mentioned this pull request Oct 30, 2024
dummdidumm added a commit that referenced this pull request Oct 30, 2024

Verified

This commit was signed with the committer’s verified signature. The key has expired.
Moser-ss Stephane Moser
immediately after merging #14006 I noticed there's a bug when pruning one selector in a list of several; this fixes it

no changeset because not released yet
dummdidumm added a commit that referenced this pull request Oct 30, 2024

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
immediately after merging #14006 I noticed there's a bug when pruning one selector in a list of several; this fixes it

no changeset because not released yet
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Svelte 5: CSS output not minified when mounting into shadow root
3 participants