react-outside-click-hook
v1.2.0
Published
A React hook that handles clicks outside of a given element and calls a provided function.
Downloads
127
Maintainers
Readme
react-outside-click-hook
A React hook that handles clicks outside of a given element and calls a provided function.
Install
// Install the package
npm install react-outside-click-hook
Usage
Arguments
Structure:
useOutsideClick(element, onOutsideClick, active)
- inside: This accepts a React ref to a DOM element, or an Array of React refs for multiple "inside" elements (ie. a button for a select dropdown and a container for the dropdown itself)
- onOutsideClick : Accepts a callback function that will be called on click outside of the bounds of the element provided. When called this will return a truthy value as to wether a click was inside or outside of the provided element (
true
if inside,false
if outside). - active: This accepts a boolean that tells the hook wether to be listening for clicks or not, ture is actively listening for clicks, false is inactive/disabled. (If you want it to always be active, just set this value to
true
)
Modal Example (typescript)
import React, { useState, useRef, RefObject } form "react";
import useOutsideClick from "react-outside-click-hook";
const [show, updateShow] = useState(false); // Modal open/close state
const modalContainer: RefObject<HTMLDivElement> = useRef(null); // React ref to be applied to the container element
useOutsideClick(
modalContainer, // Ref to the container element (this can be an array of refs for multiple "inside" elements)
updateShow, // Callback function to be called on outside click
show // When to disable the outside click handler, ie. when the modal is closed.
);
Dropdown Example (javascript)
import React, { useState, useRef } from "react";
import useOutsideClick from "react-outside-click-hook";
const [show, updateShow] = useState(false); // Modal open/close state
const dropdownContainer = useRef(null); // React ref to be applied to the container element
const dropdownButton = useRef(null); // React ref to be applied to the container element
useOutsideClick(
[dropdownContainer, dropdownButton], // Ref to the container element (this can be an array of refs for multiple "inside" elements)
updateShow, // Callback function to be called on outside click
show // When to disable the outside click handler, ie. when the modal is closed.
);