I'm trying to implement a code that shows the list of online users in a site and their last activity time. But a issue I'm facing is that, when the tab is inactive or the user isn't performing any action on the tab, the socket gets disconnected automatically. How can I keep the socket alive if the tab is open regardless active or not.
app.js
...
io.on('connection', function(socket){
let userName
socket.on('user viewing', function(user){
let inActiveUsers = false
for(var x = 0; x < activeUsers.length; x++) {
if(activeUsers[x].username == user) {
inActiveUsers = true
activeUsers[x].last_activity = MDate.getDateTime()
break
}
}
if(!inActiveUsers) {
activeUsers.push({"username": user, "last_activity": MDate.getDateTime()})
}
userName = user
io.emit('active users', activeUsers)
})
socket.on('disconnect', function(){
let userIndex = -1
for(var x = 0; x < activeUsers.length; x++) {
if(activeUsers[x].username == userName) {
userIndex = x
break
}
}
if(userIndex != -1) {
activeUsers[x].last_activity = 'NULL'
}
io.emit('active users', activeUsers)
})
})
...
Client side code
<script src="/socket.io/socket.io.js"></script>
<script>
var socket = io();
socket.emit('user viewing', '<%= user.username %>');
</script>