mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-10-26 08:36:12 +01:00 
			
		
		
		
	fix: #7142
due to no refresh on login socket listeners were added more than once, so remove them before adding the listeners
This commit is contained in:
		| @@ -18,19 +18,28 @@ define('forum/header/chat', ['components'], function (components) { | ||||
| 			requireAndCall('loadChatsDropdown', chatsListEl); | ||||
| 		} | ||||
|  | ||||
| 		socket.on('event:chats.receive', function (data) { | ||||
| 			requireAndCall('onChatMessageReceived', data); | ||||
| 		}); | ||||
| 		socket.removeListener('event:chats.receive', onChatMessageReceived); | ||||
| 		socket.on('event:chats.receive', onChatMessageReceived); | ||||
|  | ||||
| 		socket.on('event:user_status_change', function (data) { | ||||
| 			requireAndCall('onUserStatusChange', data); | ||||
| 		}); | ||||
| 		socket.removeListener('event:user_status_change', onUserStatusChange); | ||||
| 		socket.on('event:user_status_change', onUserStatusChange); | ||||
|  | ||||
| 		socket.on('event:chats.roomRename', function (data) { | ||||
| 			requireAndCall('onRoomRename', data); | ||||
| 		}); | ||||
| 		socket.removeListener('event:chats.roomRename', onRoomRename); | ||||
| 		socket.on('event:chats.roomRename', onRoomRename); | ||||
| 	}; | ||||
|  | ||||
| 	function onChatMessageReceived(data) { | ||||
| 		requireAndCall('onChatMessageReceived', data); | ||||
| 	} | ||||
|  | ||||
| 	function onUserStatusChange(data) { | ||||
| 		requireAndCall('onUserStatusChange', data); | ||||
| 	} | ||||
|  | ||||
| 	function onRoomRename(data) { | ||||
| 		requireAndCall('onRoomRename', data); | ||||
| 	} | ||||
|  | ||||
| 	function requireAndCall(method, param) { | ||||
| 		require(['chat'], function (chat) { | ||||
| 			chat[method](param); | ||||
|   | ||||
| @@ -21,15 +21,21 @@ define('forum/header/notifications', ['components'], function (components) { | ||||
| 			requireAndCall('loadNotifications', notifList); | ||||
| 		} | ||||
|  | ||||
| 		socket.on('event:new_notification', function (data) { | ||||
| 			requireAndCall('onNewNotification', data); | ||||
| 		}); | ||||
| 		socket.removeListener('event:new_notification', onNewNotification); | ||||
| 		socket.on('event:new_notification', onNewNotification); | ||||
|  | ||||
| 		socket.on('event:notifications.updateCount', function (data) { | ||||
| 			requireAndCall('updateNotifCount', data); | ||||
| 		}); | ||||
| 		socket.removeListener('event:notifications.updateCount', onUpdateCount); | ||||
| 		socket.on('event:notifications.updateCount', onUpdateCount); | ||||
| 	}; | ||||
|  | ||||
| 	function onNewNotification(data) { | ||||
| 		requireAndCall('onNewNotification', data); | ||||
| 	} | ||||
|  | ||||
| 	function onUpdateCount(data) { | ||||
| 		requireAndCall('updateNotifCount', data); | ||||
| 	} | ||||
|  | ||||
| 	function requireAndCall(method, param) { | ||||
| 		require(['notifications'], function (notifications) { | ||||
| 			notifications[method](param); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user