-
Notifications
You must be signed in to change notification settings - Fork 35
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
Should we support all asset pipeline options? #10
Comments
It seems |
@pranavbabu thanks! Do you have a use case where it's imperative we publish to npm? Or where the current setup doesn't work out of the box? I think many (most?) apps that use jsbundling with esbuild, bun, etc would use sprockets for css. Because this library already precompiles its JS in the manifest, sprockets should take care of importing it. Even if its intended purpose is to handle css. The exception here might be webpack. Because it can also bundle css, I'm sure many apps used it to replace sprockets entirely. And so this gem would not work out of the box because its automatic methods of importing JS only work for importmaps and sprockets. But then those apps are probably using a front-end framework like react and probably wouldn't reach for this gem. And can simply add the importmaps gem if they really wanted to. Would love some input from the community here. I'd like to avoid publishing to npm unless enough people have a need for it. |
Sharing my +1 vote for NPM, but my use-case is non-standard outside of Rails (I use Hotwire with Elixir). |
Thanks for sharing that use case @sevab! A large part of this gem is the affordances it brings due to being a Rails engine. It's a large part of why it's easy to use. The JS alone can't provide as smooth an experience. So that's one reason I don't want to publish it to npm — it's not meant to be a standalone JS library. Not today, anyway. I'm not opposed to a future where it is, but the initiative would most likely not come from me personally. |
I've switched our apps to propshaft & importmaps with dartsass. will it work with that setup? it seems that will be the default eventually for rails (minus dartsass but i'm not letting go yet) |
@asecondwill it should! Please reach out if it doesn't (with as much information as possible) and I'll get it sorted. Any setups that include importmaps and/or sprockets should work out of the box just by installing the gem. |
You are correct about css, but I'm talking about having bundled js code like controller and other logic you use, which is not possible ATM. Thing is I have
which makes impossible to link all js files that sprockets generates for your gem, unfortunately. |
@pranavbabu Ah you're right, we're missing a helper like the one we have for including stylesheets. I thought we had one! I'll add one today and include in the readme. EDIT: Ran out of time to implement this week. I'll come back to it later. Would also welcome a PR for this, I think we'll have to bundle all the JS for inclusion. And probably separate the css and js manifest so they can be required separately. |
This would solve a major pain point for me. Most of my apps are using propshaft, jsbundling-rails, and esbuild. Would that be supported? |
I had initially forgotten to mention Propshaft. As things are, we need additional helpers and config to handle JS with Sprockets and Propshaft. Definitely want to support both. I'm not programming for a couple of weeks, but I will be reviewing on my phone. So a PR for this would be very welcome. Also happy to tackle this when I'm back. |
There's actually multiple ways to handle this. for Rails + ESBuild users with the gem installed, you can add a "node_path" to ESBuild to search within the "hotwire_combobox" gem location. https://esbuild.github.io/api/#node-paths the other option for those either who don't want to use gem lookup paths or are not using Rails (unsupported I know, but we all commit crimes here right?) is https://docs.npmjs.com/cli/v7/configuring-npm/package-json#github-urls EDIT: as I'm poking through the source code because imports are done using "bare specifiers" you'll probably need to add NODE_PATH lookup if you install from Git |
Gave this another go today and I gotta say I'm stuck. Would appreciate some help here. Here's why things currently work with importmaps:
I really like this because it requires zero configuration on the user's end. I'd like whatever solution we end up with for other pipeline backends to be as zero-config as possible. Now, the engine already adds its assets (CSS and JS) to We still need to import the stimulus controller and add it to the host One thing we could do is bundle all the JS and upload it to npm. Host apps could then download it as a node_module, require the controller in their JS, and register it in their But it feels like we should be able to sidestep npm being that all the assets are available through the gem already. Any ideas how we could do this? Finally, I wonder if it'd be so bad to just require importmaps as a hard dependency. For any non-importmaps users, we could just instruct them to use the I admittedly don't often tinker with the asset pipeline's plumbing. Feels like every time I do I have to re-learn everything 😅. Appreciate y'alls help on this. @pranavbabu, @KonnorRogers, @excid3, et al. hate to cc you on this wall of text but I'm hoping you could share your impressions given that you've expressed interest in using this with esbuild and propshaft. |
The |
But that's just esbuild right? Or would that work for other bundlers as well? If it's the latter then I might've been overcomplicating things and we can just use that everywhere. Shelling out seems acceptable to me. |
Seems like I couldn't find any official deprecation notice but it seems like the node community in general doesn't recommend using Looks like I'd like to rely on a more universal foundation so we can use the same approach everywhere. I think that means unless someone knows how to require the stimulus controller from the precompiled assets in the gem then we need to publish to npm. Oh, well. Guess I'll get started on that. |
@josefarias Rollup is pretty bare bones, although if you're using NPM, chances are you're using The https://www.npmjs.com/package/@rollup/plugin-node-resolve#modulepaths For Vite, you're probably looking at setting a |
@KonnorRogers so would that mean providing instructions for each bundler with something akin to this? {
"name": "app",
"private": true,
"dependencies": {
"@hotwired/stimulus": "^3.2.2",
"@hotwired/turbo-rails": "^8.0.3",
"esbuild": "^0.20.1"
},
"scripts": {
"build": "NODE_PATH=$(bundle show hotwire_combobox) esbuild app/javascript/*.* --bundle --sourcemap --format=esm --outdir=app/assets/builds --public-path=/assets"
}
} (using package.json for brevity – but we'd provide examples for bundler config files, too) I tried the above and esbuild can't seem to resolve the internal import statements in the stimulus controller, although it does load the stimulus controller at the very least. I'm thinking let's just publish to npm. Everyone should know how to make that work for their setups and if we're going to require some config then I'd like us to stick to the norm here. Otherwise we risk getting into hairy situations on deployment or strange local setups. |
Here's a PR where I've set up bundling for publishing on npm. Would love some eyes on it if anyone has a spare minute. Thanks! |
The package is up on npm now so if anyone following this wants to give it a go they can follow the instructions in #69 |
The two PRs are merged. And with that, we now support all JS backends for the asset pipeline, including esbuild, rollup, webpack, etc. No release is needed. The readme is updated with the instructions and that's enough to run the current version which is v0.1.37. |
I know importmaps are well supported.
Sprockets and propshaft need some work.
I haven't tested webpack at all.
The text was updated successfully, but these errors were encountered: