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 🙏

© 2025 – Pkg Stats / Ryan Hefner

stimulus-use

v0.52.3

Published

A collection of standard controllers and utilities for Stimulus

Downloads

259,641

Readme

A collection of composable behaviors for your Stimulus Controllers

npm version minified + gzip size types included license Sauce test status

  • New lifecycle behaviors: adds new standard behaviors to your Stimulus controllers.
  • Composable: compose at will different behaviors in a single controller with mixins.
  • Modular: built as ES6 modules, just import what you need and tree shaking will remove the rest.
  • Typescript: Types available, better autocompletion.
  • Tiny: 3k gzip + tree shaking 🌳🌳🌳

Getting Started

Stimulus 3

If you want to use stimulus-use with Stimulus 3 you can use the version 0.50.0+. This and all future versions are designed to work with the @hotwired/stimulus npm package.

Note: If other packages still depend on the stimulus npm package you can safely keep that in your package.json, this won't break the stimulus-use compability.

Using npm

npm i stimulus-use @hotwired/stimulus

Using yarn

yarn add stimulus-use @hotwired/stimulus

Stimulus 2 and below

If you want to use stimulus-use with Stimulus 2 (or below) you can use version 0.41.0. This version is designed to work with the stimulus npm package.

Using npm

npm i [email protected] [email protected]

Using yarn

yarn add [email protected] [email protected]

Documentation

We got you covered 👉 stimulus-use.github.io/stimulus-use

Mixins

Observers

This set of mixins is built around the Observer APIs and custom events to enhance your controllers with new behaviors.

| Mixin | Description | NEW Callbacks | |-----------------------|-------------|---------------------| |useClickOutside|Tracks the clicks outside of the element and adds a new lifecycle callback clickOutside.|clickOutside| |useHotkeys|Registers hotkeys using the hotkeys-js library and binds them to handler methods|| |useHover|Tracks the user's mouse movements over an element and adds mouseEnter and mouseLeave callbacks to your controller.|mouseEnter mouseLeave| |useIdle| Tracks if the user is idle on your page and adds away and back callbacks to your controller.|away back| |useIntersection | Tracks the element's intersection and adds appear, disappear callbacks to your controller.|appear disappear| |useMatchMedia | Tracks if the window matches a media query string.| is[Name], not[Name] and [name]Changed| |useMutation | Tracks mutations on an element, its attributes and/or subtree. Adds a mutate callback to your controller.|mutate| |useResize|Tracks the element's size and adds a new lifecycle callback resize.|resize| |useTargetMutation | Tracks when targets are added or removed from the controller's scope, or their contents changed. Adds [target]TargetAdded , [target]TargetRemoved and [target]TargetChanged callback to your controller for each specified target.| [target]TargetAdded [target]TargetRemoved [target]TargetChanged| |useVisibility | Tracks the page visibility and adds visible, invisible callbacks to your controller.|visible invisible| |useWindowFocus | Tracks the window focus and adds focus, unfocus callbacks to your controller.|focus unfocus| |useWindowResize| Tracks the size of the window object and adds a new lifecycle callback windowResize.|windowResize|

Optimization

A set of mixin to optimize performances.

| Mixin| Description | |------|-------------| |useDebounce|Adds the ability to specify an array "debounces" of functions to debounce.| |useMemo|Memoize expensive getters by mixing in useMemo and adding a static memos array.| |useThrottle|Adds the ability to specify an array "throttles" of functions to throttle.|

Animation

A set of mixin and controllers to build animations.

| Mixin| Description | |------|-------------| |useTransition|Mixin or controller to apply classes to various stages of an element's transition.|

Application

| Mixin | Description | |------|-------------| |useApplication, ApplicationController| supercharged controller for your application.| |useDispatch|Adds a dispatch helper function to emit custom events. Useful to communicate between different controllers.| |useMeta|Adds getters to easily access meta values.|

Extend or compose

Stimulus-use can be used in two ways: composing with mixins or extending built-in controllers

Composing with mixins

This is the prefered approach as it bring the most flexibility. Simply import a mixin and apply it in the connect or initialize to adds new behaviors to you controller. You can combine several mixins within the same controller.

import { Controller } from '@hotwired/stimulus'
import { useIntersection, useResize } from 'stimulus-use'

export default class extends Controller {
  connect() {
    useIntersection(this)
    useResize(this)
  }

  appear(entry) {
    // triggered when the element appears within the viewport
  }

  resize({ height, width }) {
    // trigered when the element is resized
  }
}

Extending built-in controllers

You can create your Stimulus controller from a pre-built Stimulus-use controller which offers the new behavior you're looking for. This method works perfectly when you only need a single behavior for your controller.

import { IntersectionController } from 'stimulus-use'

export default class extends IntersectionController {
  appear(entry) {
    // triggered when the element appears within the viewport
  }
}

Development

  • Fork the project locally
  • yarn install
  • yarn start - to run the local dev server with examples
  • yarn test - to run the unit tests
  • yarn lint - to run the linter with ESLint
  • yarn format - to format changes with Prettier
  • yarn build - to bundle the app into static files for production

Contributors ✨

Made with :heart: by @adrienpoly, @marcoroth and all these wonderful contributors (emoji key):

This project follows the all-contributors specification. Contributions of any kind welcome!

Acknowledgments

Continuous integration and cross browser testing is generously provided Sauce Labs.

Testing Powered By SauceLabs