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

Compatiblity issue with Create React App not allow import outside of src/ #37

Open
bwv850 opened this issue Sep 14, 2022 · 4 comments
Open

Comments

@bwv850
Copy link

bwv850 commented Sep 14, 2022

Background: Create React App comes with a ModuleScopePlugin which ensures that relative imports from app's source directories don't reach outside of it, meaning whatever you're importing has to be either in src/ or node_modules.

But our plugin node-polyfill-webpack-plugin uses webpack require.resolve, which returns the absolute path of packages

image

If we trying to use console or path polyfill with CRA

function App() {
  console.log('Hello world');
  path.join('./assets/img', 'logo.png');
  
  return (
    <div className="App">
    ....
    </div>
  );
}

CRA would report error

image

I created a reproduce repository here node-polyfill-webpack-plugin-cra-reproduce

Some other info

  • yarn version: 1.22.15
  • node version: v16.16.0
@bwv850
Copy link
Author

bwv850 commented Sep 14, 2022

If I am right, what would be a good approach to address this issue? I am thinking

  • If you're using CRA, then after eject, you need to delete ModuleScopePlugin from webpack configuration. We can add this to README

image

code

  • Delete ModuleScopePlugin in NodePolyfillPlugin code automatically, if possible. Since one contradicts the other.

  • I am no Webpack expert, is there a require.resolve alternative that can return relative path instead of absolute path?

@UncleJart
Copy link

UncleJart commented Jan 27, 2024

This issue is relevant for Linux or Unix platforms (e.g. Ubuntu, Mac OS), on Windows everything works properly. This is not node-polyfill-webpack-plugin or ModuleScopePlugin problem.

There is open issue on the topic in enhanced-resolve library repo - webpack/enhanced-resolve#308 Fallback node module been resolved with absolute path which starts with / (filesystem root) on Linux/Unix. On Windows it also resolves with absolute path, but it starts with drive letter, and so there everything works properly.

Edit: Actually it may be ModuleScopePlugin problem, because webpack documentation states that On non-Windows systems these requests are resolved as an absolute path first, so enhanced-resolve works as intended which means that ModuleScopePlugin just does not handle properly this case as it was written before roots option was introduced in webpack 4.44.

@yashspr
Copy link

yashspr commented Sep 4, 2024

Any solution for this without having to eject from CRA?

@zdu-strong
Copy link

Maybe you can refer to my project(https://github.com/zdu-strong/Technical_Backup/tree/master/react).
It uses both react-app-rewired and node-polyfill-webpack-plugin to make the configuration effective.

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

4 participants