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