Ninety-nine Pitchers of Malt
Miss any of our Open RFC calls?Watch the recordings here! »

@toles/reactivity

2.1.10 • Public • Published

⚛ Reactivity

Reactivity is a simple component that makes tracking user activity easy and lets you decide how to act upon a users active state. It tracks user activity with a variety of DOM events.

💾 Installation

It is recommended to use yarn.

yarn add @toles/reactivity

or

npm install --save @toles/reactivity

⏳ Usage

Add the component right next to the element it will be tracking activity on. In this case, we're tracking user activity for the application in general so we add it at the root and attach it to the window.

import { useReactivity } from '@toles/reactivity';
 
function TrackIdle() {
    // Here, our grace period, or time before a user idles, is 10 minutes.
    const [onIdle, onActive] = useReactivity(10000);
 
    onIdle(() => {
        auth.logout();
    });
 
    onActive(() => {
        prompt('Welcome back!');
    });
}

Additional Options

with a specific element

const [onIdle, onActive] = useReactivity(10000, {
    element: () => document.getElementById('root'),
});

with React.createRef

// Pass a React ref
function Cmp() {
    const ref = React.createRef();
 
    const [onIdle, onActive] = useReactivity(10000, { ref });
 
    return <div ref={ref}>Tracked Div</div>;
}

📃Documentation

Props

  • element {EventTarget} - The target being tracked.
  • gracePeriod {number} - The amount of time allowed before being considered idle. (ms)

Return

useReactivity() => [onIdle, onActive]

  • onIdle {function} - Register a function to call on idle.
  • onActive {function} - Register a function to call on return from idle.

Default Events

  • click
  • mousedown
  • mousemove
  • mouseup
  • keypress
  • keyup
  • touchstart
  • touchend
  • touchmove
  • touchcancel
  • scroll
  • resize

Install

npm i @toles/reactivity

DownloadsWeekly Downloads

6

Version

2.1.10

License

MIT

Unpacked Size

85.6 kB

Total Files

20

Last publish

Collaborators

  • avatar