You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
First off, thanks for the polyfill. It seems to work.
Motive: my app is organized around custom elements, many of which are instantiated directly with new. I'm not concerned with tag name compatibility such as <dialog is=some-dialog> vs <some-dialog>. What's important is simply having the base class available.
I hacked together the following and it seems to work, but having it provided by the library would be better. Hopefully without increasing the size of the polyfill.
importdpfrom'https://cdn.jsdelivr.net/npm/dialog-polyfill@0.5.6/dist/dialog-polyfill.esm.min.js'constHTMLDialogElement=window.HTMLDialogElement||classHTMLDialogElementextendsHTMLElement{constructor(){super()// Hack for the polyfill.this.showModal=undefined// Actual polyfill.dp.forceRegisterDialog(this)this.showPoly=this.showthis.showModalPoly=this.showModalthis.closePoly=this.closedeletethis.showdeletethis.showModaldeletethis.close}// Allows `super.X` in subclasses.show(...args){returnthis.showPoly(...args)}showModal(...args){returnthis.showModalPoly(...args)}close(...args){returnthis.closePoly(...args)}// Hack for the polyfill.getlocalName(){return`dialog`}}
The text was updated successfully, but these errors were encountered:
I second this. However, I think the polyfill should define window.HTMLDialogElement accordingly by itself, not just export it. I ran into this exact problem and a polyfill should polyfill the missing functionality - HTMLDialogElement is part of this missing functionality.
Note that this is a somewhat rare use-case right now, since Safari does not support it (requires a tiny polyfill). But extending built-in elements is extremely useful in a certain web programming style and could spread ...
"a somewhat rare use-case right now" The GitHub web interface uses it now, and the user navigation will now break on any web browser that doesn't have HTMLDialogElement natively (most worringly, Firefox versions below 98).
First off, thanks for the polyfill. It seems to work.
Motive: my app is organized around custom elements, many of which are instantiated directly with
new
. I'm not concerned with tag name compatibility such as<dialog is=some-dialog>
vs<some-dialog>
. What's important is simply having the base class available.I hacked together the following and it seems to work, but having it provided by the library would be better. Hopefully without increasing the size of the polyfill.
The text was updated successfully, but these errors were encountered: