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

wtc-modal-view

v3.4.0

Published

A simple, unopinionated modal class.

Downloads

243

Readme

wtc-modal-view 3.4.0

A simple, unopinionated modal class.

src/wtc-modal-view.js

new Modal()

A Modal class which can display programatically-generated content, or pull in content from an existing DOM node.

Examples
const myModal = new Modal();
const triggerButton = document.querySelector('trigger');

myModal.optionalClass = "modal--myModal";
myModal.content = '<p>Some sample content!</p>';
myModal.focusOnClose = triggerButton;

triggerButton.addEventListener('click', () => {
  myModal.open();
});
Returns
  • Void

Modal.close()

Closes modal.

If onCloseStartis defined that is called and waits for the callback. Otherwise it removes content and optional class, and shifts user focus back to triggering element, if specified.

Returns
  • Void

open()

Opens modal, adds content and optional CSS class

Returns
  • Void

focusFirstElement()

Shifts focus to the first element inside the content

Returns
  • Void

focusLastElement()

Shifts focus to the last element inside the content

Returns
  • Void

focusOnClose()

Gets the element that will be focused when the modal closes

Returns
  • HTMLElement

focusOnClose(element)

Sets the element that will be focused when the modal closes.
Setter. Usage: modalInstance.focusOnClose = myElement

Parameters

| Name | Type | Description | | | ---- | ---- | ----------- | -------- | | element | HTMLElement | Must be a focusable element |   |

Returns
  • Void

onOpen()

Gets the function that is called when the modal opens

Returns
  • Function

onOpen(callback)

Sets the function that is called when the modal opens. The function gets called with the modals DOM element. Setter. Usage: modalInstance.onOpen = (modalElement) => {}

Parameters

| Name | Type | Description | | | ---- | ---- | ----------- | -------- | | callback | Function | |   |

Returns
  • Void

onClose()

Get the function that is called when the modal closes

Returns
  • Function

onClose(callback)

Sets the function that is called when the modal closes.
Setter. Usage: modalInstance.onClose = myFunction

Parameters

| Name | Type | Description | | | ---- | ---- | ----------- | -------- | | callback | Function | |   |

Returns
  • Void

onCloseStart()

Get the function that is called just before the modal closes

Returns
  • Function

onCloseStart(callback)

Sets the function that is called just before the modal closes. If this is set, when modalInstance.close()` is called it will run the set function with a the modal DOM element and a callback. It will then wait for that callback to be run before completing the close function and calling onClose.

Setter. Usage: `modalInstance.onCloseStart = (modalElement, cb) => { // do some animation with modalElement cb();
}

modalInstance.close(); `

Parameters

| Name | Type | Description | | | ---- | ---- | ----------- | -------- | | callback | Function | |   |

Returns
  • Void

optionalClass(className)

Sets an optional class name on the modal for custom styling.
Setter. Usage: modalInstance.optionalClass = "modal--myclass"

Parameters

| Name | Type | Description | | | ---- | ---- | ----------- | -------- | | className | String Array | |   |

Returns
  • Void

optionalClass()

Gets the optional class name

Returns
  • String Array optionalClass

closeButtonContent(content)

Sets the content of the close button, useful for localizing.
Setter. Usage: modalInstance.closeButtonContent = "<String of HTML!>"

Parameters

| Name | Type | Description | | | ---- | ---- | ----------- | -------- | | content | string HTMLElement | |   |

Returns
  • Void

content(content)

Sets the content of the modal.
Setter. Usage: modalInstance.content = MyHTMLElement

Parameters

| Name | Type | Description | | | ---- | ---- | ----------- | -------- | | content | string HTMLElement | |   |

Returns
  • Void

Documentation generated with doxdox.