npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

pop-modal-dialog

v1.1.1

Published

A modern custom element to create dialogs

Downloads

11

Readme

Pop Modal

NPM Downloads

A modern custom element to create modals and dialogs

Nice features

  • Use native dialog when available, and load a polyfill automatically for safari < 15.4 and firefox < 98
  • Compatible with any framework
  • Fully standalone
  • Fully accessible
  • Binds button automatically with data-dialog
  • Light dismiss
  • No layout jumps due to scrollbars
  • Nice animations
  • Nested form support

Why use dialogs ?

Modern dialogs have super powers that cannot be easily replicated with userland javascript.

  • Inert background
  • Trapping focus

Why use a custom element

Because dialogs are not supported in safari < 15.4 and firefox < 98. Binding the polyfill is tricky.

Also, you might want to have your buttons bound without custom js (onclick="this.closest('dialog').close('cancel')" anyone?) or inline scripts. And you might even enjoy some nice styling :-)

How to use

Using simple html:

<body>
  <!-- including using type module because it's an esm module -->
  <script type="module" src="/path/to/pop-modal.styled.min.js"></script>

  ...

  <pop-modal id="myModal"> Hi there! </pop-modal>

  <button data-dialog="myModal">Open it</button>
  <!-- no js was used :-) -->

  <!-- adding the dialog tag is optional but recommended if you want to avoid swapping nodes -->
  <pop-modal id="myModal"><dialog> Hi there! </dialog></pop-modal>

  ...
</body>

More examples

Using a mega modal that goes to the bottom in mobile view:

<pop-modal id="megaModal" mega> ... </pop-modal>

Disabling backdrop

<pop-modal id="modalWithoutBackdrop" backdrop="false"> ... </pop-modal>

No light dismiss

<pop-modal id="noLightDismissModal" dismissible="false"> ... </pop-modal>

Self opening (for example on load)

<pop-modal id="autoModal" auto> ... </pop-modal>

Positioning

<pop-modal id="autoModal" auto position="end"> ... </pop-modal>

Callback that gets the button that has been clicked

<pop-modal id="returnModal" output="#someselector" outputfn="some.function"> ... </pop-modal>

Your own dialog tag

<pop-modal id="dialogModal"><dialog id="somecustomid"> ... </dialog></pop-modal>

Nested forms

<pop-modal id="returnModal"><nested-form action="/some/endpoint"> ... </nested-form></pop-modal>

Config

Simply call the static configure method.

customElements.whenDefined("pop-modal").then(() => {
  customElements.get("pop-modal").configure({});
});

| Name | Type | Description | | ------------- | ------------------- | ----------------------------- | | closeSelector | String | Selector to find close button |

Demo

Check out demo.html or a simple code pen below

https://codepen.io/lekoalabe/pen/yLwYEQV

Browser supports

Modern browsers (edge, chrome, firefox, safari... not IE11). Add a warning if necessary.