idlejs
Execute a function only when certain events on certain target element have or have not occured within given timeout.
It's simple, configurable, typescript friendly and has an easy chainable API.
Install
yarn add idlejs
npm install --save idlejs
v2 to v3
Change imports from idlejs/dist
to idlejs
import { ... } from 'idjejs'
Idle
Excutes the callback function (do
) when none of the specified events have occurred within given time, in other words when user is idle.
Usage
import { Idle } from 'idlejs';
const idle = new Idle()
.whenNotInteractive()
.within(5)
.do(() => logoutUser())
.start();
const idle = new Idle()
.whenNot([{
events: ['click', 'hover'],
target: buttonEl,
},
{
events: ['click', 'input'],
target: inputEl,
},
])
.whenNotInteractive()
.within(10)
.do(logoutUser)
.start();
For more features or examples please check the tests and source code.
NotIdle
Executes the callback function (do
), if at least one of the specified events have occured within given time, in other words when user is not idle or interactive.
Usage
import { NotIdle } from 'idlejs';
const idle = new Idle()
.whenInteractive()
.within(10)
.do(() => log('user was active in the last 10 minutes'))
.start();
const notIdle = new NotIdle()
.when([{
events: ['click', 'hover'],
target: buttonEl,
},
{
events: ['click', 'input'],
target: inputEl,
},
])
.whenInteractive()
.within(10)
.do(() => log('user was active in the last 10 minutes'))
.start();
For more features or examples please check the tests and source code.
Setting time
Second parameter of within
is time unit in miliseconds, by default 60000 (a minute).
new Idle()
.within(5)
new Idle()
.within(5, 1000)