mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-25 20:07:13 +00:00 
			
		
		
		
	Add user status filter to admin user management page (#16770)
It makes Admin's life easier to filter users by various status. * introduce window.config.PageData to pass template data to javascript module and small refactor move legacy window.ActivityTopAuthors to window.config.PageData.ActivityTopAuthors make HTML structure more IDE-friendly in footer.tmpl and head.tmpl remove incorrect <style class="list-search-style"></style> in head.tmpl use log.Error instead of log.Critical in admin user search * use LEFT JOIN instead of SubQuery when admin filters users by 2fa. revert non-en locale. * use OptionalBool instead of status map * refactor SearchUserOptions.toConds to SearchUserOptions.toSearchQueryBase * add unit test for user search * only allow admin to use filters to search users
This commit is contained in:
		
							
								
								
									
										32
									
								
								web_src/js/features/admin-users.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								web_src/js/features/admin-users.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| export function initAdminUserListSearchForm() { | ||||
|   const searchForm = window.config.PageData.adminUserListSearchForm; | ||||
|   if (!searchForm) return; | ||||
|  | ||||
|   const $form = $('#user-list-search-form'); | ||||
|   if (!$form.length) return; | ||||
|  | ||||
|   $form.find(`button[name=sort][value=${searchForm.SortType}]`).addClass('active'); | ||||
|  | ||||
|   if (searchForm.StatusFilterMap) { | ||||
|     for (const [k, v] of Object.entries(searchForm.StatusFilterMap)) { | ||||
|       if (!v) continue; | ||||
|       $form.find(`input[name="status_filter[${k}]"][value=${v}]`).prop('checked', true); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   $form.find(`input[type=radio]`).click(() => { | ||||
|     $form.submit(); | ||||
|     return false; | ||||
|   }); | ||||
|  | ||||
|   $form.find('.j-reset-status-filter').click(() => { | ||||
|     $form.find(`input[type=radio]`).each((_, e) => { | ||||
|       const $e = $(e); | ||||
|       if ($e.attr('name').startsWith('status_filter[')) { | ||||
|         $e.prop('checked', false); | ||||
|       } | ||||
|     }); | ||||
|     $form.submit(); | ||||
|     return false; | ||||
|   }); | ||||
| } | ||||
| @@ -17,6 +17,7 @@ import initMigration from './features/migration.js'; | ||||
| import initProject from './features/projects.js'; | ||||
| import initServiceWorker from './features/serviceworker.js'; | ||||
| import initTableSort from './features/tablesort.js'; | ||||
| import {initAdminUserListSearchForm} from './features/admin-users.js'; | ||||
| import {createCodeEditor, createMonaco} from './features/codeeditor.js'; | ||||
| import {initMarkupAnchors} from './markup/anchors.js'; | ||||
| import {initNotificationsTable, initNotificationCount} from './features/notification.js'; | ||||
| @@ -2875,6 +2876,7 @@ $(document).ready(async () => { | ||||
|   initReleaseEditor(); | ||||
|   initRelease(); | ||||
|   initIssueContentHistory(); | ||||
|   initAdminUserListSearchForm(); | ||||
|  | ||||
|   const routes = { | ||||
|     'div.user.settings': initUserSettings, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 wxiaoguang
					wxiaoguang