Tracks the user's activity status. Calls your listeners when considered the user is idle or wakes up.
npm i @eseath/user-idle-observer
import { UserIdleObserver } from '@eseath/user-idle-observer';
const observer = new UserIdleObserver();
const listener = (isActive, event) => {
if (isActive) {
console.log('You have shown activity through a', event.type);
} else {
console.log('Wake up!');
}
};
observer.addListener(listener).observe();
With custom options:
import { UserIdleObserver, domEvents } from '@eseath/user-idle-observer';
const observer = new UserIdleObserver({
isActive: true,
timeout: 5000,
events: [...domEvents, 'keyup'],
});
In browser:
<script src="./dist/user-idle-observer.umd.js"></script>
<script>
document.addEventListener('DOMContentLoaded', function () {
const observer = new UserIdleObserver({
isActive: true,
timeout: 5000,
events: [...UserIdleObserver.domEvents, 'keyup'],
});
observer.addListener((isActive, event) => {
if (isActive) {
console.log('You have shown activity through a', event.type);
} else {
console.log('Wake up!');
}
});
observer.observe();
});
</script>
Name | Type | Default | Description |
---|---|---|---|
isActive |
boolean | false | The initial activity status of the user. |
timeout |
number | 10000 | Time after which the user is considered inactive (in milliseconds). |
events |
string[] | Array of DOM events, the occurrence of which indicates user activity. |