Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

use-long-press

Package Overview
Dependencies
Maintainers
1
Versions
52
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

use-long-press

React hook for detecting click (or tap) and hold event. Easy to use, highly customizable options, thoroughly tested.

  • 1.0.4
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
28K
decreased by-14.89%
Maintainers
1
Weekly downloads
 
Created
Source

React Long Press Hook :point_down:

React hook for detecting click (or tap) and hold event.

Travis (.org) Codecov npm type definitions npm bundle size npm GitHub

  • Easy to use
  • Highly customizable options
  • Thoroughly tested

Install

yarn add use-long-press

or

npm install --save use-long-press

Basic Usage

import React from 'react';
import { useLongPress } from 'use-long-press';

const Example = () => {
    const bind = useLongPress(() => {
        console.log('Long pressed!');
    });

    return <button {...bind}>Press me</button>;
};

Live example

Edit useLongPress

Advanced usage

Hook first parameter, callback, can be either function or null (if you want to disable the hook).

Additionally you can supply options object as a second parameter.

As a result hook returns object with various handlers (depending on detect option), which can be spread to some element.

Definition

useLongPress(callback [, options]): handlers

Options

Long press hook can be adjusted using options object, which allow you to fit it to your needs.

NameTypeDefaultDescription
thresholdnumber400Time user need to hold click or tap before long press callback is triggered
captureEventbooleanfalseIf React MouseEvent (or TouchEvent) should be supplied as first argument to callbacks
detectEnum('mouse' | 'touch' | 'both')'both'Which event handlers should be returned in bind object. In TS this enum is accessible through LongPressDetectEvents
onStartFunction() => {}Called when element is initially pressed (before starting timer which detects long press).

Can accept mouse or touch event if captureEvents option is set to true.
onFinishFunction() => {}Called when press is released (after triggering callback).

Can accept mouse or touch event if captureEvents option is set to true.
onCancelFunction() => {}Called when press is released before threshold time elapses, therefore before long press occurs.

Can accept mouse or touch event if captureEvents option is set to true.

Example

import React, { useState, useCallback } from 'react';
import { useLongPress } from 'use-long-press';

export default function AdvancedExample() {
    const [enabled, setEnabled] = useState(true);
    const callback = useCallback(event => {
        alert('Long pressed!');
    }, []);
    const bind = useLongPress(enabled ? callback : null, {
        onStart: event => console.log('Press started'),
        onFinish: event => console.log('Long press finished'),
        onCancel: event => console.log('Press cancelled'),
        threshold: 500,
        captureEvent: true,
        detect: 'both',
    });

    return (
        <div>
            <button {...bind}>Press and hold</button>
            <div>
                <label htmlFor="enabled">
                    <input
                        type="checkbox"
                        id="enabled"
                        checked={enabled}
                        onChange={() => setEnabled(current => !current)}
                    />
                    Hook enabled
                </label>
            </div>
        </div>
    );
}

License

MIT © minwork

Keywords

FAQs

Package last updated on 01 May 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc