mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-10-26 16:46:12 +01:00 
			
		
		
		
	fix: #12044, only load notifications when opening dropdown
update code to use bs5 class "show"
This commit is contained in:
		| @@ -1,25 +1,24 @@ | ||||
| 'use strict'; | ||||
|  | ||||
| define('forum/header/notifications', ['components'], function (components) { | ||||
| define('forum/header/notifications', function () { | ||||
| 	const notifications = {}; | ||||
|  | ||||
| 	notifications.prepareDOM = function () { | ||||
| 		const notifContainer = components.get('notifications'); | ||||
| 		const notifTrigger = notifContainer.children('a'); | ||||
| 		const notifList = components.get('notifications/list'); | ||||
|  | ||||
| 		notifTrigger.on('click', function (e) { | ||||
| 			e.preventDefault(); | ||||
| 			if (notifContainer.hasClass('open')) { | ||||
| 		const notifTrigger = $('[component="notifications"] [data-bs-toggle="dropdown"]'); | ||||
| 		if (!notifTrigger.length) { | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 			requireAndCall('loadNotifications', notifList); | ||||
| 		notifTrigger.on('show.bs.dropdown', (ev) => { | ||||
| 			requireAndCall('loadNotifications', $(ev.target).parent().find('[component="notifications/list"]')); | ||||
| 		}); | ||||
|  | ||||
| 		if (notifTrigger.parents('.dropdown').hasClass('open')) { | ||||
| 			requireAndCall('loadNotifications', notifList); | ||||
| 		notifTrigger.each((index, el) => { | ||||
| 			const dropdownEl = $(el).parent().find('.dropdown-menu'); | ||||
| 			if (dropdownEl.hasClass('show')) { | ||||
| 				requireAndCall('loadNotifications', dropdownEl.find('[component="notifications/list"]')); | ||||
| 			} | ||||
| 		}); | ||||
|  | ||||
| 		socket.removeListener('event:new_notification', onNewNotification); | ||||
| 		socket.on('event:new_notification', onNewNotification); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user