-
Notifications
You must be signed in to change notification settings - Fork 415
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
fix: added polyfill for ES Modules and import map #504
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM 👍 are there any tests that we need to add or update as well? Or do we usually just test these manually? I would imagine it is almost impossible to be automatic given that it is hardware dependent in this case.
I don't think we need any tests. We are just adding a polyfill, which provides a user implementation of a browser feature, and this should already be tested separately |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The shim is not huge but does add some weight (40K but unzipped).
We're adding it in all pages but so far it's only relevant for the request form.
Maybe we could add it only in the request page for now (not a strong opinion) but check first if it's needed? e.g.:
if (!HTMLScriptElement.supports('importmap')) {
// importmap not supported.
}
We actually need it on all pages, since we have a The conditional loading is a good idea, I didn't try it because it is not mentioned in the official documentation, but it is mentioned here: guybedford/es-module-shims#371 (comment). I will give it a try and see if it works |
This update makes the New Request Form compatible with old browsers that don't support ES modules or import maps
b44d74e
to
951bc0e
Compare
🎉 This PR is included in version 4.0.4 🎉 The release is available on GitHub release Your semantic-release bot 📦🚀 |
Description
This update makes the New Request Form compatible with old browsers that don't support ES modules or import maps.
Some old browsers don't support some features used in the new implementation of the request form. We officially support only the latest 2 versions of browsers on desktop and the latest version on mobile, but unfortunately there are still people using older versions, and so increasing the spectrum of supported browser can be a good thing. The drawback is that we are adding a 14kb script (gzipped) which is only needed for a very small number of browsers.
This PR adds https://github.com/guybedford/es-module-shims as an additional asset which is loaded in the
document_head
template. The official documentation suggests using a CDN, but I think it is better to include it directly in the theme as an asset to avoid external dependencies. I just copied the asset from the CDN and pasted it into the asset folder, I don't think it makes sense to install the library from NPM and add a build step for it since it is just a small script.Screenshots
Tested on iPhone 7 with iOS 15 on the XCode simulator.
Before:
After:
Checklist