benlesh/event-target-polyfill

IE 11 and vite js

mfo opened this issue ยท 0 comments

mfo commented

Hi! ๐Ÿ‘‹

Firstly, thanks for your work on this project! ๐Ÿ™‚

Today I used patch-package to patch event-target-polyfill@0.0.3 for the project I'm working on.

After switching to vite-js as a build tool it appears this polyfill does not works with ie 11 for 3 reasons :

  1. template literals or backticks
  2. arrow function
  3. Map.entries

Some more info ; vite js polyfill system does not goes trough a transpiler.

Here is the diff that solved my problem:

diff --git a/node_modules/event-target-polyfill/index.js b/node_modules/event-target-polyfill/index.js
index 82f7f42..d198834 100644
--- a/node_modules/event-target-polyfill/index.js
+++ b/node_modules/event-target-polyfill/index.js

 if (typeof root.EventTarget === "undefined" || !isConstructor(root.Event)) {
   root.EventTarget = (function () {
     function EventTarget() {
@@ -40,7 +27,8 @@ if (typeof root.EventTarget === "undefined" || !isConstructor(root.Event)) {
     ) {
       if (arguments.length < 2) {
         throw new TypeError(
-          `TypeError: Failed to execute 'addEventListener' on 'EventTarget': 2 arguments required, but only ${arguments.length} present.`
+          "TypeError: Failed to execute 'addEventListener' on 'EventTarget': 2 arguments required, " +
+          "but only " + arguments.length.toString() + "present."
         );
       }
       const __listeners = this.__listeners;
@@ -62,7 +50,8 @@ if (typeof root.EventTarget === "undefined" || !isConstructor(root.Event)) {
     ) {
       if (arguments.length < 2) {
         throw new TypeError(
-          `TypeError: Failed to execute 'addEventListener' on 'EventTarget': 2 arguments required, but only ${arguments.length} present.`
+          "TypeError: Failed to execute 'addEventListener' on 'EventTarget': 2 arguments required, " +
+          "but only " + arguments.length.toString() + "present."
         );
       }
       const __listeners = this.__listeners;
@@ -78,14 +67,14 @@ if (typeof root.EventTarget === "undefined" || !isConstructor(root.Event)) {
     EventTarget.prototype.dispatchEvent = function (event) {
       if (!(event instanceof Event)) {
         throw new TypeError(
-          `Failed to execute 'dispatchEvent' on 'EventTarget': parameter 1 is not of type 'Event'.`
+          "Failed to execute 'dispatchEvent' on 'EventTarget': parameter 1 is not of type 'Event'."
         );
       }
       const type = event.type;
       const __listeners = this.__listeners;
       const listenersForType = __listeners.get(type);
       if (listenersForType) {
-        for (const [listener, options] of listenersForType.entries()) {
+        listenersForType.forEach(function(options, listener) {
           try {
             if (typeof listener === "function") {
               // Listener functions must be executed with the EventTarget as the `this` context.
@@ -100,7 +89,7 @@ if (typeof root.EventTarget === "undefined" || !isConstructor(root.Event)) {
             // Unfortunately, this is the best we can do, which isn't great, because the
             // native EventTarget will actually do this synchronously before moving to the next
             // event in the loop.
-            setTimeout(() => {
+            setTimeout(function() {
               throw err;
             });
           }
@@ -109,7 +98,7 @@ if (typeof root.EventTarget === "undefined" || !isConstructor(root.Event)) {
             // to remove it now.
             listenersForType.delete(listener);
           }
-        }
+        })
       }
       // Since there are no cancellable events on a base EventTarget,
       // this should always return true.

This issue body was partially generated by patch-package.