mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-10-26 16:46:12 +01:00 
			
		
		
		
	refactor: post-queue frontend logic
This commit is contained in:
		| @@ -100,7 +100,7 @@ | |||||||
|         "nodebb-plugin-ntfy": "1.0.15", |         "nodebb-plugin-ntfy": "1.0.15", | ||||||
|         "nodebb-plugin-spam-be-gone": "2.0.6", |         "nodebb-plugin-spam-be-gone": "2.0.6", | ||||||
|         "nodebb-rewards-essentials": "0.2.2", |         "nodebb-rewards-essentials": "0.2.2", | ||||||
|         "nodebb-theme-harmony": "1.0.0-beta.80", |         "nodebb-theme-harmony": "1.0.0-beta.81", | ||||||
|         "nodebb-theme-lavender": "7.0.9", |         "nodebb-theme-lavender": "7.0.9", | ||||||
|         "nodebb-theme-peace": "2.0.19", |         "nodebb-theme-peace": "2.0.19", | ||||||
|         "nodebb-theme-persona": "13.0.51", |         "nodebb-theme-persona": "13.0.51", | ||||||
|   | |||||||
| @@ -6,6 +6,7 @@ | |||||||
| 	"enabling-help": "To enable this feature, go to <a href=\"%1\">Settings → Post → Post Queue</a> and enable <strong>Post Queue</strong>.", | 	"enabling-help": "To enable this feature, go to <a href=\"%1\">Settings → Post → Post Queue</a> and enable <strong>Post Queue</strong>.", | ||||||
| 	"back-to-list": "Back to Post Queue", | 	"back-to-list": "Back to Post Queue", | ||||||
| 	"user": "User", | 	"user": "User", | ||||||
|  | 	"when": "When", | ||||||
| 	"category": "Category", | 	"category": "Category", | ||||||
| 	"title": "Title", | 	"title": "Title", | ||||||
| 	"content": "Content", | 	"content": "Content", | ||||||
|   | |||||||
| @@ -3,7 +3,11 @@ | |||||||
|  |  | ||||||
| define('forum/post-queue', [ | define('forum/post-queue', [ | ||||||
| 	'categoryFilter', 'categorySelector', 'api', 'alerts', 'bootbox', | 	'categoryFilter', 'categorySelector', 'api', 'alerts', 'bootbox', | ||||||
| ], function (categoryFilter, categorySelector, api, alerts, bootbox) { | 	'accounts/moderate', 'accounts/delete', | ||||||
|  | ], function ( | ||||||
|  | 	categoryFilter, categorySelector, api, alerts, bootbox, | ||||||
|  | 	AccountModerate, AccountsDelete | ||||||
|  | ) { | ||||||
| 	const PostQueue = {}; | 	const PostQueue = {}; | ||||||
|  |  | ||||||
| 	PostQueue.init = function () { | 	PostQueue.init = function () { | ||||||
| @@ -13,61 +17,8 @@ define('forum/post-queue', [ | |||||||
| 			privilege: 'moderate', | 			privilege: 'moderate', | ||||||
| 		}); | 		}); | ||||||
|  |  | ||||||
|  | 		handleActions(); | ||||||
| 		handleBulkActions(); | 		handleBulkActions(); | ||||||
|  |  | ||||||
| 		$('.posts-list').on('click', '[data-action]', async function () { |  | ||||||
| 			function getMessage() { |  | ||||||
| 				return new Promise((resolve) => { |  | ||||||
| 					const modal = bootbox.dialog({ |  | ||||||
| 						title: '[[post-queue:notify-user]]', |  | ||||||
| 						message: '<textarea class="form-control"></textarea>', |  | ||||||
| 						buttons: { |  | ||||||
| 							OK: { |  | ||||||
| 								label: '[[modules:bootbox.send]]', |  | ||||||
| 								callback: function () { |  | ||||||
| 									const val = modal.find('textarea').val(); |  | ||||||
| 									if (val) { |  | ||||||
| 										resolve(val); |  | ||||||
| 									} |  | ||||||
| 								}, |  | ||||||
| 							}, |  | ||||||
| 						}, |  | ||||||
| 					}); |  | ||||||
| 				}); |  | ||||||
| 			} |  | ||||||
|  |  | ||||||
| 			const parent = $(this).parents('[data-id]'); |  | ||||||
| 			const action = $(this).attr('data-action'); |  | ||||||
| 			const id = parent.attr('data-id'); |  | ||||||
| 			const listContainer = parent.get(0).parentNode; |  | ||||||
|  |  | ||||||
| 			if ((!['accept', 'reject', 'notify'].includes(action)) || |  | ||||||
| 				(action === 'reject' && !await confirmReject(ajaxify.data.canAccept ? '[[post-queue:confirm-reject]]' : '[[post-queue:confirm-remove]]'))) { |  | ||||||
| 				return; |  | ||||||
| 			} |  | ||||||
|  |  | ||||||
| 			socket.emit('posts.' + action, { |  | ||||||
| 				id: id, |  | ||||||
| 				message: action === 'notify' ? await getMessage() : undefined, |  | ||||||
| 			}, function (err) { |  | ||||||
| 				if (err) { |  | ||||||
| 					return alerts.error(err); |  | ||||||
| 				} |  | ||||||
| 				if (action === 'accept' || action === 'reject') { |  | ||||||
| 					parent.remove(); |  | ||||||
| 				} |  | ||||||
|  |  | ||||||
| 				if (listContainer.childElementCount === 0) { |  | ||||||
| 					if (ajaxify.data.singlePost) { |  | ||||||
| 						ajaxify.go('/post-queue' + window.location.search); |  | ||||||
| 					} else { |  | ||||||
| 						ajaxify.refresh(); |  | ||||||
| 					} |  | ||||||
| 				} |  | ||||||
| 			}); |  | ||||||
| 			return false; |  | ||||||
| 		}); |  | ||||||
|  |  | ||||||
| 		handleContentEdit('.post-content', '.post-content-editable', 'textarea'); | 		handleContentEdit('.post-content', '.post-content-editable', 'textarea'); | ||||||
| 		handleContentEdit('.topic-title', '.topic-title-editable', 'input'); | 		handleContentEdit('.topic-title', '.topic-title-editable', 'input'); | ||||||
|  |  | ||||||
| @@ -152,6 +103,106 @@ define('forum/post-queue', [ | |||||||
| 		}); | 		}); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	function handleActions() { | ||||||
|  | 		const listEl = document.querySelector('.posts-list'); | ||||||
|  | 		if (listEl) { | ||||||
|  | 			listEl.addEventListener('click', (e) => { | ||||||
|  | 				const subselector = e.target.closest('[data-action]'); | ||||||
|  | 				if (subselector) { | ||||||
|  | 					const action = subselector.getAttribute('data-action'); | ||||||
|  | 					const uid = subselector.closest('[data-uid]').getAttribute('data-uid'); | ||||||
|  |  | ||||||
|  | 					switch (action) { | ||||||
|  | 						case 'ban': | ||||||
|  | 							AccountModerate.banAccount(uid, ajaxify.refresh); | ||||||
|  | 							break; | ||||||
|  |  | ||||||
|  | 						case 'unban': | ||||||
|  | 							AccountModerate.unbanAccount(uid); | ||||||
|  | 							break; | ||||||
|  |  | ||||||
|  | 						case 'mute': | ||||||
|  | 							AccountModerate.muteAccount(uid, ajaxify.refresh); | ||||||
|  | 							break; | ||||||
|  |  | ||||||
|  | 						case 'unmute': | ||||||
|  | 							AccountModerate.unmuteAccount(uid); | ||||||
|  | 							break; | ||||||
|  |  | ||||||
|  | 						case 'delete-account': | ||||||
|  | 							AccountsDelete.account(uid, ajaxify.refresh); | ||||||
|  | 							break; | ||||||
|  |  | ||||||
|  | 						case 'delete-content': | ||||||
|  | 							AccountsDelete.content(uid, ajaxify.refresh); | ||||||
|  | 							break; | ||||||
|  |  | ||||||
|  | 						case 'delete-all': | ||||||
|  | 							AccountsDelete.purge(uid, ajaxify.refresh); | ||||||
|  | 							break; | ||||||
|  |  | ||||||
|  | 						default: | ||||||
|  | 							handleQueueActions.call(e.target); | ||||||
|  | 							break; | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			}); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	async function handleQueueActions() { | ||||||
|  | 		function getMessage() { | ||||||
|  | 			return new Promise((resolve) => { | ||||||
|  | 				const modal = bootbox.dialog({ | ||||||
|  | 					title: '[[post-queue:notify-user]]', | ||||||
|  | 					message: '<textarea class="form-control"></textarea>', | ||||||
|  | 					buttons: { | ||||||
|  | 						OK: { | ||||||
|  | 							label: '[[modules:bootbox.send]]', | ||||||
|  | 							callback: function () { | ||||||
|  | 								const val = modal.find('textarea').val(); | ||||||
|  | 								if (val) { | ||||||
|  | 									resolve(val); | ||||||
|  | 								} | ||||||
|  | 							}, | ||||||
|  | 						}, | ||||||
|  | 					}, | ||||||
|  | 				}); | ||||||
|  | 			}); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		const parent = $(this).parents('[data-id]'); | ||||||
|  | 		const action = $(this).attr('data-action'); | ||||||
|  | 		const id = parent.attr('data-id'); | ||||||
|  | 		const listContainer = parent.get(0).parentNode; | ||||||
|  |  | ||||||
|  | 		if ((!['accept', 'reject', 'notify'].includes(action)) || | ||||||
|  | 			(action === 'reject' && !await confirmReject(ajaxify.data.canAccept ? '[[post-queue:confirm-reject]]' : '[[post-queue:confirm-remove]]'))) { | ||||||
|  | 			return; | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		socket.emit('posts.' + action, { | ||||||
|  | 			id: id, | ||||||
|  | 			message: action === 'notify' ? await getMessage() : undefined, | ||||||
|  | 		}, function (err) { | ||||||
|  | 			if (err) { | ||||||
|  | 				return alerts.error(err); | ||||||
|  | 			} | ||||||
|  | 			if (action === 'accept' || action === 'reject') { | ||||||
|  | 				parent.remove(); | ||||||
|  | 			} | ||||||
|  |  | ||||||
|  | 			if (listContainer.childElementCount === 0) { | ||||||
|  | 				if (ajaxify.data.singlePost) { | ||||||
|  | 					ajaxify.go('/post-queue' + window.location.search); | ||||||
|  | 				} else { | ||||||
|  | 					ajaxify.refresh(); | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		}); | ||||||
|  | 		return false; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	function handleBulkActions() { | 	function handleBulkActions() { | ||||||
| 		$('[component="post-queue/bulk-actions"]').on('click', '[data-action]', async function () { | 		$('[component="post-queue/bulk-actions"]').on('click', '[data-action]', async function () { | ||||||
| 			const bulkAction = $(this).attr('data-action'); | 			const bulkAction = $(this).attr('data-action'); | ||||||
|   | |||||||
| @@ -203,12 +203,14 @@ modsController.postQueue = async function (req, res, next) { | |||||||
| 	const postsPerPage = 20; | 	const postsPerPage = 20; | ||||||
|  |  | ||||||
| 	let postData = await posts.getQueuedPosts({ id: id }); | 	let postData = await posts.getQueuedPosts({ id: id }); | ||||||
| 	const [isAdmin, isGlobalMod, moderatedCids, categoriesData] = await Promise.all([ | 	let [isAdmin, isGlobalMod, moderatedCids, categoriesData, _privileges] = await Promise.all([ | ||||||
| 		user.isAdministrator(req.uid), | 		user.isAdministrator(req.uid), | ||||||
| 		user.isGlobalModerator(req.uid), | 		user.isGlobalModerator(req.uid), | ||||||
| 		user.getModeratedCids(req.uid), | 		user.getModeratedCids(req.uid), | ||||||
| 		helpers.getSelectedCategory(cid), | 		helpers.getSelectedCategory(cid), | ||||||
|  | 		Promise.all(['global', 'admin'].map(async type => privileges[type].get(req.uid))), | ||||||
| 	]); | 	]); | ||||||
|  | 	_privileges = { ..._privileges[0], ..._privileges[1] }; | ||||||
|  |  | ||||||
| 	postData = postData | 	postData = postData | ||||||
| 		.filter(p => p && | 		.filter(p => p && | ||||||
| @@ -245,5 +247,6 @@ modsController.postQueue = async function (req, res, next) { | |||||||
| 		breadcrumbs: helpers.buildBreadcrumbs(crumbs), | 		breadcrumbs: helpers.buildBreadcrumbs(crumbs), | ||||||
| 		enabled: meta.config.postQueue, | 		enabled: meta.config.postQueue, | ||||||
| 		singlePost: !!id, | 		singlePost: !!id, | ||||||
|  | 		privileges: _privileges, | ||||||
| 	}); | 	}); | ||||||
| }; | }; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user