mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-10-26 16:46:12 +01:00 
			
		
		
		
	feat(topic-events): client-side handling on topic event log
This commit is contained in:
		| @@ -5,8 +5,9 @@ define('forum/topic/threadTools', [ | |||||||
| 	'components', | 	'components', | ||||||
| 	'translator', | 	'translator', | ||||||
| 	'handleBack', | 	'handleBack', | ||||||
|  | 	'forum/topic/posts', | ||||||
| 	'api', | 	'api', | ||||||
| ], function (components, translator, handleBack, api) { | ], function (components, translator, handleBack, posts, api) { | ||||||
| 	var ThreadTools = {}; | 	var ThreadTools = {}; | ||||||
|  |  | ||||||
| 	ThreadTools.init = function (tid, topicContainer) { | 	ThreadTools.init = function (tid, topicContainer) { | ||||||
| @@ -271,6 +272,8 @@ define('forum/topic/threadTools', [ | |||||||
| 		$('.topic-header [component="topic/locked"]').toggleClass('hidden', !data.isLocked); | 		$('.topic-header [component="topic/locked"]').toggleClass('hidden', !data.isLocked); | ||||||
| 		$('[component="post/tools"] .dropdown-menu').html(''); | 		$('[component="post/tools"] .dropdown-menu').html(''); | ||||||
| 		ajaxify.data.locked = data.isLocked; | 		ajaxify.data.locked = data.isLocked; | ||||||
|  |  | ||||||
|  | 		posts.addTopicEvents(data.events); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	ThreadTools.setDeleteState = function (data) { | 	ThreadTools.setDeleteState = function (data) { | ||||||
| @@ -302,6 +305,8 @@ define('forum/topic/threadTools', [ | |||||||
|  |  | ||||||
| 		threadEl.toggleClass('deleted', data.isDelete); | 		threadEl.toggleClass('deleted', data.isDelete); | ||||||
| 		ajaxify.data.deleted = data.isDelete ? 1 : 0; | 		ajaxify.data.deleted = data.isDelete ? 1 : 0; | ||||||
|  |  | ||||||
|  | 		posts.addTopicEvents(data.events); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -322,6 +327,8 @@ define('forum/topic/threadTools', [ | |||||||
| 			); | 			); | ||||||
| 		} | 		} | ||||||
| 		ajaxify.data.pinned = data.pinned; | 		ajaxify.data.pinned = data.pinned; | ||||||
|  |  | ||||||
|  | 		posts.addTopicEvents(data.events); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| 	function setFollowState(state) { | 	function setFollowState(state) { | ||||||
|   | |||||||
| @@ -44,7 +44,7 @@ module.exports = function (Topics) { | |||||||
| 		} else { | 		} else { | ||||||
| 			await Topics.restore(data.topicData.tid); | 			await Topics.restore(data.topicData.tid); | ||||||
| 		} | 		} | ||||||
| 		await Topics.events.log(tid, { type: isDelete ? 'delete' : 'restore', uid }); | 		const events = await Topics.events.log(tid, { type: isDelete ? 'delete' : 'restore', uid }); | ||||||
|  |  | ||||||
| 		data.topicData.deleted = data.isDelete ? 1 : 0; | 		data.topicData.deleted = data.isDelete ? 1 : 0; | ||||||
|  |  | ||||||
| @@ -60,6 +60,7 @@ module.exports = function (Topics) { | |||||||
| 			isDelete: data.isDelete, | 			isDelete: data.isDelete, | ||||||
| 			uid: data.uid, | 			uid: data.uid, | ||||||
| 			user: userData, | 			user: userData, | ||||||
|  | 			events, | ||||||
| 		}; | 		}; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -95,7 +96,7 @@ module.exports = function (Topics) { | |||||||
| 			throw new Error('[[error:no-privileges]]'); | 			throw new Error('[[error:no-privileges]]'); | ||||||
| 		} | 		} | ||||||
| 		await Topics.setTopicField(tid, 'locked', lock ? 1 : 0); | 		await Topics.setTopicField(tid, 'locked', lock ? 1 : 0); | ||||||
| 		await Topics.events.log(tid, { type: lock ? 'lock' : 'unlock', uid }); | 		topicData.events = await Topics.events.log(tid, { type: lock ? 'lock' : 'unlock', uid }); | ||||||
| 		topicData.isLocked = lock; // deprecate in v2.0 | 		topicData.isLocked = lock; // deprecate in v2.0 | ||||||
| 		topicData.locked = lock; | 		topicData.locked = lock; | ||||||
|  |  | ||||||
| @@ -175,10 +176,11 @@ module.exports = function (Topics) { | |||||||
| 			topicData.pinExpiryISO = undefined; | 			topicData.pinExpiryISO = undefined; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		await Promise.all(promises); | 		const results = await Promise.all(promises); | ||||||
|  |  | ||||||
| 		topicData.isPinned = pin; // deprecate in v2.0 | 		topicData.isPinned = pin; // deprecate in v2.0 | ||||||
| 		topicData.pinned = pin; | 		topicData.pinned = pin; | ||||||
|  | 		topicData.events = results[1]; | ||||||
|  |  | ||||||
| 		plugins.hooks.fire('action:topic.pin', { topic: _.clone(topicData), uid }); | 		plugins.hooks.fire('action:topic.pin', { topic: _.clone(topicData), uid }); | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user