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

Feature suggestion: optional process.env polyfill #236

Open
Caleb-T-Owens opened this issue Jan 25, 2024 · 1 comment
Open

Feature suggestion: optional process.env polyfill #236

Caleb-T-Owens opened this issue Jan 25, 2024 · 1 comment

Comments

@Caleb-T-Owens
Copy link
Contributor

What's the issue

With #235 and rails/propshaft#181 I'm now able to successfully import all the files for the tippy.js library.

After getting all of this working, I've found that tippy.js unfortunately in its ESM bundle refers to the node property process.env to determine whether it's in a production environment. There is a closed but unresolved issue (atomiks/tippyjs#990) for that library but it seems like there has recently not been much activity over there at all.

Why bother?

Whilst there is always the suggestion of "just use a different library" I think that if we're to make this transition over to no-build as seamless as possible for rails developers, it would make sense to have optional polyfills that resolve these node-related issues.

My suggestion

I would suggest having an optional (default false) kwarg on javascript_importmap_tags called polyfill_nodeisms, resulting in something like <%= javascript_importmap_tags polyfill_nodeisms: true %>

Shouldn't we get the library maintainers to ensure that nodeisms aren't included in their esm builds?

Yes - I think a great endgame would be to have all the nodeisms removed from packages, but that is a process that could take a bit of time, and cause some friction for developers transferring.

I think that it would be great to still encourage developers to prompt their library maintainers to remove the reliance of nodeisms, so I'd suggest that our ployfills should provide "warn" logs when they're used:

For example

window.process = {
  get env() {
    console.warn("Nodeism process.env has been used; You should not rely on nodeisms to being in the browser. If process.env is being used by a 3rd party dependency, consider submitting an issue to the maintainer")
    return "production"
  }
}

Screenshot 2024-01-25 at 21 48 39

Request for comments

I've identified process.env as being problematic, but don't have a good sample size of libraries. So I'd be interested in hearing if there are any other problematic nodeisms that people have found getting left in their esm libraries

@dianedouglas-thrive
Copy link

dianedouglas-thrive commented Jan 6, 2025

Bumping this because I have hit this exact issue with tippy and would love at least a workaround. I'm using importmap-rails with no build. I'm using tippy and I have it and all of its dependencies pinned but have hit a brick wall at this browser error:

Uncaught ReferenceError: process is not defined
    at validation.ts:46:1

The line in question looks like this:

if (__DEV__) {

It seems like there still hasn't been any movement on the plugin side. @Caleb-T-Owens Could you walk me through adding a polyfill like you have until there is a resolution to this issue please?

Would be happy to help with a PR too.

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

No branches or pull requests

2 participants