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 userstokarchuk/v1.17
parent
d0a681fbc3
commit
7bcbdd0707
@ -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; |
||||||
|
}); |
||||||
|
} |
Loading…
Reference in new issue