-
Notifications
You must be signed in to change notification settings - Fork 1.5k
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
Generate stylesheet_packs_with_chunks_tag for packs with style dependencies #2202
Comments
I would recommend putting all of the resources in a single
Webpacker does this already. Check your |
I’ve been using webpack for over 4 years, and I’m pretty sure I want 6-7 packs for this app, with common chunks split out.
Thanks,
Daniel Heath
… On 1 Aug 2019, at 4:40 am, Jake Niemiec ***@***.***> wrote:
<%= javascript_packs_with_chunks_tag ***@***.***_packs.uniq %>
I would recommend putting all of the resources in a single pack. The rest of your .js files should not be in /packs or else you will get inflated build times and file sizes:
You don't want to put anything inside packs directory that you do not want to be an entry file. As a rule of thumb, put all files you want to link in your views inside "packs" directory and keep everything else under app/javascript.
It would be safer to just register the JS entrypoints and automatically add CSS packs if there are any required by that JS.
Webpacker does this already. Check your webpacker.yml and ensure that extract_css is false. This will prevent webpacker from separating the 2 files.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub, or mute the thread.
|
As a 4-year webpack veteran, I would be happy to review a PR from you; but if there's a new feature that you want to see added, you'll need to write the code yourself. You can also send your feature idea in an email to the rails-core mailing list. |
Brilliant. I agree. It seems unfortunate that the developer even needs to remember to manually add a I guess that's what |
You don't want your styles to be bottle necked behind your js in production.
|
You might want your css to be loaded from a different part of the document from the js (eg head vs end of body). Any changes shouldn’t remove that as an option.
Thanks,
Daniel Heath
… On 1 Nov 2019, at 4:00 am, Jake Niemiec ***@***.***> wrote:
Why can't it just automatically add the CSS packs that it needs?
You don't want your styles to be bottle necked behind your js in production.
I guess that's what extract_css: false does, but why shouldn't it also work for extract_css: true?
extract_css: false does not give you a <link rel="stylesheet"..., meaning that your stylesheets are not cacheable by the browser. You will also run into FOUT.
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub, or unsubscribe.
|
I'm currently building up a list of which packs I'll need in ApplicationHelper and rendering them all at the end.
Some of my packs have CSS dependencies, some do not.
At the moment, each call site needs to log its JS dependencies and also its CSS dependencies. Forgetting to do so results in the CSS being dropped in production but not in development (so it's an easy mistake to make!).
It would be safer to just register the JS entrypoints and automatically add CSS packs if there are any required by that JS. I've worked around this in my application as follows:
This is alright, but it doesn't raise an error for packs that don't exist the way
stylesheet_packs_with_chunks_tag
does. However,stylesheet_packs_with_chunks_tag
raises an error if a pack exists but has no CSS dependencies.I propose the following options:
stylesheet_packs_for_javascript_chunks_tag
to render all CSS dependencies of the passed JS chunks, but not raise an error if you pass a valid JS chunk that has no CSS in it.stylesheet_packs_with_chunks_tag
silently ignore valid packs which have no CSS chunks.The text was updated successfully, but these errors were encountered: