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

apollo-client broken #2

Open
stubailo opened this issue Mar 30, 2017 · 4 comments
Open

apollo-client broken #2

stubailo opened this issue Mar 30, 2017 · 4 comments

Comments

@stubailo
Copy link

https://packd.now.sh/bundle/[email protected]

I think this package works fine in Angular apps with Rollup.

@Rich-Harris
Copy link
Owner

Thanks. Looks like this is caused by rollup-plugin-node-resolve being overzealous. It's trying to import whatwg-fetch from transport/networkInterface.js, and that's failing because whatwg-fetch doesn't have a pkg.module.

This will presumably happen for any ES015 module that imports a non-ES2015 package. Best thing to do is probably to remove the skip option and associated behaviour from node-resolve altogether — I can't think of any good it's doing, to be honest.

@Rich-Harris
Copy link
Owner

I made a couple of changes to rollup-plugin-node-resolve that I thought would fix this (rollup/rollup-plugin-node-resolve#90, rollup/rollup-plugin-node-resolve#91), but it didn't. The difference now is that it's no longer our fault 😀 The culprit is this file, which is imported by this one and which isn't an ES2015 module.

I don't quite understand why it looks like that, when if I build it locally it looks like this:

export var version = 'local';

Does that mean anything to you?

@stubailo
Copy link
Author

stubailo commented Apr 4, 2017

Yeah, this is something we use to try to make the version available, and is kinda broken anyway.

It's set in the publish script, I think it's deploy.sh in the repository.

Is that code not a valid ES2015 module?

@Rich-Harris
Copy link
Owner

Ah, right — this line is the culprit:

fs.writeFileSync('./npm/version.js', 'exports.version = \"' + package.version + '\"'); \

It needs to reflect the code that TypeScript generates (export var version = [pkg.version]) in order to work correctly. That shouldn't break your pkg.main, since it's a UMD (though that contains the hardcoded 'local' version).

I don't know if this helps in a TS workflow, but with rollup-plugin-json you can do this...

export { version } from './package.json';`

...and the rest of package.json will get tree-shaken. Maybe then you don't need that line in the deploy script at all?

gluck pushed a commit to gluck/packd that referenced this issue Jun 21, 2019
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