diff --git a/files/assets/js/chat.js b/files/assets/js/chat.js index 6beae1bef..c758a7700 100644 --- a/files/assets/js/chat.js +++ b/files/assets/js/chat.js @@ -188,7 +188,7 @@ ta.addEventListener("keydown", function(e) { }) socket.on('online', function(data){ - const online_li = Object.entries(data[0]) + const online_li = data[0] const muted_li = Object.keys(data[1]) document.getElementsByClassName('board-chat-count')[0].innerHTML = online_li.length @@ -196,17 +196,17 @@ socket.on('online', function(data){ const admin_level = parseInt(document.getElementById('admin_level').value) let online = '' let online2 = 'Users Online' - for (const [k, val] of online_li) + for (const u of online_li) { let patron = '' - if (val[3]) - patron = ` class="patron" style="background-color:#${val[2]}"` + if (u[3]) + patron = ` class="patron" style="background-color:#${u[2]}"` online += `
  • ` - if (admin_level && muted_li.includes(val[1].toLowerCase())) + if (admin_level && muted_li.includes(u[1].toLowerCase())) online += 'X ' - online += `${val[1]}
  • ` - online2 += `
    @${val[1]}` + online += `${u[1]}` + online2 += `
    @${u[1]}` } const online_el = document.getElementById('online') diff --git a/files/routes/chat.py b/files/routes/chat.py index c3d0a315c..de7d724b3 100644 --- a/files/routes/chat.py +++ b/files/routes/chat.py @@ -139,14 +139,14 @@ def speak(data, v): self_only = True else: del muted[vname] - emit("online", [online[g.referrer], muted], room=g.referrer, broadcast=True) + refresh_online() if SITE == 'rdrama.net' and v.admin_level < PERMS['BYPASS_ANTISPAM_CHECKS']: def shut_up(): self_only = True muted_until = int(time.time() + 600) muted[vname] = muted_until - emit("online", [online[g.referrer], muted], room=g.referrer, broadcast=True) + refresh_online() if not self_only: identical = [x for x in list(messages[g.referrer].values())[-5:] if v.id == x['user_id'] and text == x['text']] @@ -182,7 +182,7 @@ def speak(data, v): username = i.group(1).lower() muted_until = int(int(i.group(2)) * 60 + time.time()) muted[username] = muted_until - emit("online", [online[g.referrer], muted], room=g.referrer, broadcast=True) + refresh_online() self_only = True if self_only or v.shadowbanned or execute_blackjack(v, None, text, "chat"): @@ -204,7 +204,8 @@ def refresh_online(): if val[1] in typing[g.referrer]: typing[g.referrer].remove(val[1]) - emit("online", [online[g.referrer], muted], room=g.referrer, broadcast=True) + data = [list(online[g.referrer].values()), muted] + emit("online", data, room=g.referrer, broadcast=True) cache.set('loggedin_chat', len(online[f'{SITE_FULL}/chat']), timeout=0) @socketio.on('connect') @@ -251,7 +252,7 @@ def heartbeat(v): if g.referrer not in ALLOWED_REFERRERS: return '', 400 expire_utc = int(time.time()) + 3610 - online[g.referrer][v.id] = (expire_utc, v.username, v.name_color, v.patron) + online[g.referrer][v.id] = (expire_utc, v.username, v.name_color, v.patron, v.id) refresh_online() return '', 204