Skip to content
This repository has been archived by the owner on Jul 11, 2018. It is now read-only.

question: Order of polyfills.js #126

Open
joewoodhouse opened this issue Jan 19, 2017 · 6 comments
Open

question: Order of polyfills.js #126

joewoodhouse opened this issue Jan 19, 2017 · 6 comments

Comments

@joewoodhouse
Copy link

The background to this question comes from danielsogl/awesome-cordova-plugins#505

Basically it appears there's an issue with how the FileReader API is patched by various agents, namely Zone.js, Ionic Native and the Cordova file plugin itself. The resulting behaviour made events like onloadend and similar not reliably fire from the FileReader. It pointed to a Zone.js related issue.

After a bit of exploring and experimenting I found that by moving the polyfills.js script tag to the top of my index.html, before the cordova.js tag, the issue went away. Presumably this is because polyfills.js contains zone.js in it, and so by this re-ordering somehow the issue is resolved.

It would be good to know if this is a safe thing to do. Presumably there was a reason why the polyfills.js was put after cordova.js originally.

Any information much appreciated.

@pdrosos
Copy link

pdrosos commented Jan 20, 2017

I am also interested in the answer and if this appears to be safe thing to do, it would be great if Ionic's base project could be updated to include it. This issue took me a lot of time and seems fixed now, so it's best to be initially fixed for other people in the base project. Thanks!

@mgaert
Copy link

mgaert commented Jan 30, 2017

I would know this as well. Thanks!

@joewoodhouse
Copy link
Author

Anyone out there?

@paulsouche
Copy link

Hi,

I found angular/zone.js/868 and I can't find a way to use @JiaLiPassion cordova patch properly. If anyone can help it would be great.

Thank you

@JiaLiPassion
Copy link

@paulsouche , if it is the same issue which angular/zone.js#868 resolved, you could just use the newest version of zone.js.

@paulsouche
Copy link

@JiaLiPassion I'm already on [email protected] and as I said, I was trying to use its cordova patch. But my issue is that if cordova.js script is loaded before zone.js one, sometimes (it depends on how cordova plugins are resolved) cordova FileReader is patched by zone.js instead of window FileReader. And as @ionic-native/file is using global FileReader, something is broken. import zone.js cordova patch do not fix things in this case.

BTW I think that cordova FileReader should not be global and we should not have this conversation but @joewoodhouse's workaround is more a hack than something reliable and that's why I'm asking for help of somebody who know more about cordova @ionic-native/file & zone.js than me.

Thank you for the great job anyway

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

6 participants