534 lines
25 KiB
PHP
534 lines
25 KiB
PHP
<!doctype html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="utf-8" />
|
|
<meta name="viewport" content="width=device-width,initial-scale=1" />
|
|
<title>Admin — Users by Category</title>
|
|
|
|
<!-- Bootstrap 5 CSS -->
|
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/css/bootstrap.min.css" rel="stylesheet">
|
|
|
|
<style>
|
|
/* Small visual tweaks */
|
|
.category-badge { font-weight: 600; color: #fff; padding: 0.25rem 0.5rem; border-radius: 0.25rem; font-size: .8rem; }
|
|
.badge-district { background:#f6a623; } /* amber */
|
|
.badge-regional { background:#17a2b8; } /* teal */
|
|
.badge-national { background:#1f6feb; } /* blue */
|
|
.user-row:hover .row-actions { visibility: visible; opacity: 1; }
|
|
.row-actions { visibility: hidden; opacity: 0; transition: .12s ease-in-out; }
|
|
.table-avatar { width:36px; height:36px; object-fit:cover; border-radius:50%; }
|
|
.toolbar { gap:.5rem; display:flex; flex-wrap:wrap; align-items:center; }
|
|
.select-all { margin-right:.5rem; }
|
|
@media (max-width: 767px) {
|
|
.toolbar { flex-direction:column; align-items:stretch; }
|
|
}
|
|
</style>
|
|
</head>
|
|
<body class="bg-light">
|
|
|
|
<div class="container py-4">
|
|
<div class="d-flex align-items-center mb-3">
|
|
<h3 class="me-auto">Manage Users</h3>
|
|
<div class="text-muted">June 15, 2026</div>
|
|
</div>
|
|
|
|
<!-- Tabs -->
|
|
<ul class="nav nav-tabs mb-3" id="userTabs" role="tablist">
|
|
<li class="nav-item" role="presentation">
|
|
<button class="nav-link active" id="district-tab" data-bs-toggle="tab" data-bs-target="#district" type="button" role="tab" aria-controls="district" aria-selected="true">District <span class="badge bg-secondary ms-1" id="count-district">3</span></button>
|
|
</li>
|
|
<li class="nav-item" role="presentation">
|
|
<button class="nav-link" id="regional-tab" data-bs-toggle="tab" data-bs-target="#regional" type="button" role="tab" aria-controls="regional" aria-selected="false">Regional <span class="badge bg-secondary ms-1" id="count-regional">2</span></button>
|
|
</li>
|
|
<li class="nav-item" role="presentation">
|
|
<button class="nav-link" id="national-tab" data-bs-toggle="tab" data-bs-target="#national" type="button" role="tab" aria-controls="national" aria-selected="false">National <span class="badge bg-secondary ms-1" id="count-national">1</span></button>
|
|
</li>
|
|
</ul>
|
|
|
|
<!-- Shared toolbar -->
|
|
<div class="card mb-3">
|
|
<div class="card-body">
|
|
<div class="toolbar">
|
|
<div class="d-flex align-items-center">
|
|
<input type="checkbox" id="globalSelect" class="form-check-input select-all" aria-label="Select all visible users">
|
|
<div class="me-2">Select</div>
|
|
</div>
|
|
|
|
<div class="input-group" style="max-width:420px;">
|
|
<span class="input-group-text">Search</span>
|
|
<input id="globalSearch" class="form-control" type="search" placeholder="Search name, email or ID (press /)" aria-label="Search users">
|
|
</div>
|
|
|
|
<div class="ms-auto d-flex gap-2">
|
|
<div class="dropdown">
|
|
<button class="btn btn-outline-secondary dropdown-toggle" type="button" data-bs-toggle="dropdown" aria-expanded="false">Filter</button>
|
|
<ul class="dropdown-menu p-3" style="min-width:220px;">
|
|
<div class="mb-2"><strong>Status</strong></div>
|
|
<div class="form-check"><input class="form-check-input filter-status" type="checkbox" value="Active" id="fActive"><label class="form-check-label" for="fActive">Active</label></div>
|
|
<div class="form-check"><input class="form-check-input filter-status" type="checkbox" value="Pending" id="fPending"><label class="form-check-label" for="fPending">Pending</label></div>
|
|
<div class="form-check"><input class="form-check-input filter-status" type="checkbox" value="Suspended" id="fSuspended"><label class="form-check-label" for="fSuspended">Suspended</label></div>
|
|
</ul>
|
|
</div>
|
|
|
|
<button id="bulkMoveBtn" class="btn btn-primary" disabled data-bs-toggle="modal" data-bs-target="#moveModal">Move</button>
|
|
<button id="bulkDeactivate" class="btn btn-outline-danger" disabled>Deactivate</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Tab content -->
|
|
<div class="tab-content" id="userTabsContent">
|
|
<!-- District -->
|
|
<div class="tab-pane fade show active" id="district" role="tabpanel" aria-labelledby="district-tab">
|
|
<div class="card mb-4">
|
|
<div class="card-body p-0">
|
|
<div class="table-responsive">
|
|
<table class="table table-hover mb-0">
|
|
<thead class="table-light">
|
|
<tr>
|
|
<th style="width:42px;"></th>
|
|
<th>Person</th>
|
|
<th>Email</th>
|
|
<th>Role</th>
|
|
<th>Last activity</th>
|
|
<th style="width:130px;">Actions</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="districtBody">
|
|
<!-- Example rows -->
|
|
<tr class="user-row" data-category="District" data-status="Active" data-name="Alice Doe" data-email="alice@example.com" data-id="D001">
|
|
<td><input class="row-select form-check-input" type="checkbox" aria-label="Select Alice Doe"></td>
|
|
<td class="align-middle">
|
|
<div class="d-flex align-items-center">
|
|
<img src="https://i.pravatar.cc/40?img=5" alt="avatar" class="table-avatar me-2">
|
|
<div>
|
|
<div class="fw-semibold">Alice Doe</div>
|
|
<div class="text-muted small">ID: D001</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="align-middle">alice@example.com</td>
|
|
<td class="align-middle"><span class="category-badge badge-district">District</span> · Manager</td>
|
|
<td class="align-middle">2026-06-10</td>
|
|
<td class="align-middle">
|
|
<div class="row-actions d-flex gap-2">
|
|
<button class="btn btn-sm btn-outline-secondary viewBtn" data-id="D001">View</button>
|
|
<button class="btn btn-sm btn-primary editBtn" data-id="D001" data-bs-toggle="modal" data-bs-target="#editModal">Edit</button>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr class="user-row" data-category="District" data-status="Pending" data-name="Ben Kyle" data-email="ben@example.com" data-id="D002">
|
|
<td><input class="row-select form-check-input" type="checkbox" aria-label="Select Ben Kyle"></td>
|
|
<td class="align-middle">
|
|
<div class="d-flex align-items-center">
|
|
<img src="https://i.pravatar.cc/40?img=6" alt="avatar" class="table-avatar me-2">
|
|
<div>
|
|
<div class="fw-semibold">Ben Kyle</div>
|
|
<div class="text-muted small">ID: D002</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="align-middle">ben@example.com</td>
|
|
<td class="align-middle"><span class="category-badge badge-district">District</span> · Staff</td>
|
|
<td class="align-middle">2026-06-12</td>
|
|
<td class="align-middle">
|
|
<div class="row-actions d-flex gap-2">
|
|
<button class="btn btn-sm btn-outline-secondary viewBtn" data-id="D002">View</button>
|
|
<button class="btn btn-sm btn-primary editBtn" data-id="D002" data-bs-toggle="modal" data-bs-target="#editModal">Edit</button>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr class="user-row" data-category="District" data-status="Suspended" data-name="Clara Park" data-email="clara@example.com" data-id="D003">
|
|
<td><input class="row-select form-check-input" type="checkbox" aria-label="Select Clara Park"></td>
|
|
<td class="align-middle">
|
|
<div class="d-flex align-items-center">
|
|
<img src="https://i.pravatar.cc/40?img=7" alt="avatar" class="table-avatar me-2">
|
|
<div>
|
|
<div class="fw-semibold">Clara Park</div>
|
|
<div class="text-muted small">ID: D003</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="align-middle">clara@example.com</td>
|
|
<td class="align-middle"><span class="category-badge badge-district">District</span> · Supervisor</td>
|
|
<td class="align-middle">2026-05-30</td>
|
|
<td class="align-middle">
|
|
<div class="row-actions d-flex gap-2">
|
|
<button class="btn btn-sm btn-outline-secondary viewBtn" data-id="D003">View</button>
|
|
<button class="btn btn-sm btn-primary editBtn" data-id="D003" data-bs-toggle="modal" data-bs-target="#editModal">Edit</button>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Regional -->
|
|
<div class="tab-pane fade" id="regional" role="tabpanel" aria-labelledby="regional-tab">
|
|
<div class="card mb-4">
|
|
<div class="card-body p-0">
|
|
<div class="table-responsive">
|
|
<table class="table table-hover mb-0">
|
|
<thead class="table-light">
|
|
<tr>
|
|
<th style="width:42px;"></th>
|
|
<th>Person</th>
|
|
<th>Email</th>
|
|
<th>Role</th>
|
|
<th>Last activity</th>
|
|
<th style="width:130px;">Actions</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="regionalBody">
|
|
<tr class="user-row" data-category="Regional" data-status="Active" data-name="Derek Holt" data-email="derek@example.com" data-id="R001">
|
|
<td><input class="row-select form-check-input" type="checkbox" aria-label="Select Derek Holt"></td>
|
|
<td class="align-middle">
|
|
<div class="d-flex align-items-center">
|
|
<img src="https://i.pravatar.cc/40?img=8" alt="avatar" class="table-avatar me-2">
|
|
<div>
|
|
<div class="fw-semibold">Derek Holt</div>
|
|
<div class="text-muted small">ID: R001</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="align-middle">derek@example.com</td>
|
|
<td class="align-middle"><span class="category-badge badge-regional">Regional</span> · Lead</td>
|
|
<td class="align-middle">2026-06-13</td>
|
|
<td class="align-middle">
|
|
<div class="row-actions d-flex gap-2">
|
|
<button class="btn btn-sm btn-outline-secondary viewBtn" data-id="R001">View</button>
|
|
<button class="btn btn-sm btn-primary editBtn" data-id="R001" data-bs-toggle="modal" data-bs-target="#editModal">Edit</button>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
|
|
<tr class="user-row" data-category="Regional" data-status="Active" data-name="Eva Stone" data-email="eva@example.com" data-id="R002">
|
|
<td><input class="row-select form-check-input" type="checkbox" aria-label="Select Eva Stone"></td>
|
|
<td class="align-middle">
|
|
<div class="d-flex align-items-center">
|
|
<img src="https://i.pravatar.cc/40?img=9" alt="avatar" class="table-avatar me-2">
|
|
<div>
|
|
<div class="fw-semibold">Eva Stone</div>
|
|
<div class="text-muted small">ID: R002</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="align-middle">eva@example.com</td>
|
|
<td class="align-middle"><span class="category-badge badge-regional">Regional</span> · Coordinator</td>
|
|
<td class="align-middle">2026-06-11</td>
|
|
<td class="align-middle">
|
|
<div class="row-actions d-flex gap-2">
|
|
<button class="btn btn-sm btn-outline-secondary viewBtn" data-id="R002">View</button>
|
|
<button class="btn btn-sm btn-primary editBtn" data-id="R002" data-bs-toggle="modal" data-bs-target="#editModal">Edit</button>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- National -->
|
|
<div class="tab-pane fade" id="national" role="tabpanel" aria-labelledby="national-tab">
|
|
<div class="card mb-4">
|
|
<div class="card-body p-0">
|
|
<div class="table-responsive">
|
|
<table class="table table-hover mb-0">
|
|
<thead class="table-light">
|
|
<tr>
|
|
<th style="width:42px;"></th>
|
|
<th>Person</th>
|
|
<th>Email</th>
|
|
<th>Role</th>
|
|
<th>Last activity</th>
|
|
<th style="width:130px;">Actions</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="nationalBody">
|
|
<tr class="user-row" data-category="National" data-status="Active" data-name="Frank West" data-email="frank@example.com" data-id="N001">
|
|
<td><input class="row-select form-check-input" type="checkbox" aria-label="Select Frank West"></td>
|
|
<td class="align-middle">
|
|
<div class="d-flex align-items-center">
|
|
<img src="https://i.pravatar.cc/40?img=10" alt="avatar" class="table-avatar me-2">
|
|
<div>
|
|
<div class="fw-semibold">Frank West</div>
|
|
<div class="text-muted small">ID: N001</div>
|
|
</div>
|
|
</div>
|
|
</td>
|
|
<td class="align-middle">frank@example.com</td>
|
|
<td class="align-middle"><span class="category-badge badge-national">National</span> · Director</td>
|
|
<td class="align-middle">2026-06-05</td>
|
|
<td class="align-middle">
|
|
<div class="row-actions d-flex gap-2">
|
|
<button class="btn btn-sm btn-outline-secondary viewBtn" data-id="N001">View</button>
|
|
<button class="btn btn-sm btn-primary editBtn" data-id="N001" data-bs-toggle="modal" data-bs-target="#editModal">Edit</button>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Pagination stub -->
|
|
<nav aria-label="User list pages" class="d-flex justify-content-end">
|
|
<ul class="pagination pagination-sm">
|
|
<li class="page-item disabled"><a class="page-link" href="#" tabindex="-1">Prev</a></li>
|
|
<li class="page-item active"><a class="page-link" href="#">1</a></li>
|
|
<li class="page-item"><a class="page-link" href="#">2</a></li>
|
|
<li class="page-item"><a class="page-link" href="#">Next</a></li>
|
|
</ul>
|
|
</nav>
|
|
</div>
|
|
|
|
<!-- Edit modal -->
|
|
<div class="modal fade" id="editModal" tabindex="-1" aria-labelledby="editModalLabel" aria-hidden="true">
|
|
<div class="modal-dialog modal-sm modal-dialog-centered">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h5 class="modal-title" id="editModalLabel">Edit user</h5>
|
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
|
|
</div>
|
|
<form id="editForm">
|
|
<div class="modal-body">
|
|
<input type="hidden" id="editId">
|
|
<div class="mb-3"><label class="form-label">Name</label><input id="editName" class="form-control"></div>
|
|
<div class="mb-3"><label class="form-label">Email</label><input id="editEmail" class="form-control" type="email"></div>
|
|
<div class="mb-3">
|
|
<label class="form-label">Category</label>
|
|
<select id="editCategory" class="form-select">
|
|
<option>District</option>
|
|
<option>Regional</option>
|
|
<option>National</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
<div class="modal-footer">
|
|
<button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Cancel</button>
|
|
<button type="submit" class="btn btn-primary">Save</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Move modal (bulk) -->
|
|
<div class="modal fade" id="moveModal" tabindex="-1" aria-labelledby="moveModalLabel" aria-hidden="true">
|
|
<div class="modal-dialog modal-sm modal-dialog-centered">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h5 class="modal-title" id="moveModalLabel">Move selected users</h5>
|
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
|
|
</div>
|
|
<form id="moveForm">
|
|
<div class="modal-body">
|
|
<p id="moveCountText">Move <span id="moveCount">0</span> users to:</p>
|
|
<div class="mb-3">
|
|
<select id="moveTarget" class="form-select" required>
|
|
<option value="">Choose category</option>
|
|
<option value="District">District</option>
|
|
<option value="Regional">Regional</option>
|
|
<option value="National">National</option>
|
|
</select>
|
|
</div>
|
|
</div>
|
|
<div class="modal-footer">
|
|
<button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Cancel</button>
|
|
<button type="submit" class="btn btn-primary">Move</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Bootstrap 5 JS + Popper + jQuery (for DOM convenience) -->
|
|
<script src="https://code.jquery.com/jquery-3.7.1.min.js"></script>
|
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.2/dist/js/bootstrap.bundle.min.js"></script>
|
|
|
|
<script>
|
|
(function(){
|
|
// keyboard shortcut to focus search
|
|
$(document).on('keydown', function(e){
|
|
if (e.key === '/' && !$(e.target).is('input, textarea')) {
|
|
e.preventDefault();
|
|
$('#globalSearch').focus().select();
|
|
}
|
|
});
|
|
|
|
// quick helpers
|
|
function updateCounts(){
|
|
$('#count-district').text($('#districtBody .user-row:visible').length);
|
|
$('#count-regional').text($('#regionalBody .user-row:visible').length);
|
|
$('#count-national').text($('#nationalBody .user-row:visible').length);
|
|
}
|
|
|
|
function getVisibleRowsInActiveTab(){
|
|
const activePane = $('.tab-pane.active');
|
|
return activePane.find('.user-row:visible');
|
|
}
|
|
|
|
// Select all visible in active tab
|
|
$('#globalSelect').on('change', function(){
|
|
const checked = $(this).is(':checked');
|
|
getVisibleRowsInActiveTab().find('.row-select').prop('checked', checked).trigger('change');
|
|
});
|
|
|
|
// Row checkbox toggles bulk buttons
|
|
$(document).on('change', '.row-select', function(){
|
|
const anyChecked = $('.tab-pane.active .row-select:checked').length > 0;
|
|
$('#bulkMoveBtn, #bulkDeactivate').prop('disabled', !anyChecked);
|
|
// sync header select state
|
|
const total = getVisibleRowsInActiveTab().find('.row-select').length;
|
|
const checked = getVisibleRowsInActiveTab().find('.row-select:checked').length;
|
|
$('#globalSelect').prop('checked', total>0 && total===checked);
|
|
});
|
|
|
|
// Search + filter (client-side demo)
|
|
function applyFilters(){
|
|
const q = $('#globalSearch').val().trim().toLowerCase();
|
|
const statuses = $('.filter-status:checked').map(function(){ return this.value; }).get();
|
|
|
|
$('.user-row').each(function(){
|
|
const $r = $(this);
|
|
const name = $r.data('name').toLowerCase();
|
|
const email = $r.data('email').toLowerCase();
|
|
const status = $r.data('status');
|
|
const matchesQuery = !q || name.includes(q) || email.includes(q) || $r.data('id').toLowerCase().includes(q);
|
|
const matchesStatus = statuses.length === 0 || statuses.indexOf(status) !== -1;
|
|
const show = matchesQuery && matchesStatus;
|
|
$r.toggle(show);
|
|
});
|
|
|
|
updateCounts();
|
|
// reset bulk buttons if nothing selected
|
|
$('.row-select').trigger('change');
|
|
}
|
|
|
|
$('#globalSearch').on('input', applyFilters);
|
|
$('.filter-status').on('change', applyFilters);
|
|
|
|
// Activate tab event -> clear globalSelect and bulk buttons
|
|
$('button[data-bs-toggle="tab"]').on('shown.bs.tab', function(){
|
|
$('#globalSelect').prop('checked', false);
|
|
$('#bulkMoveBtn, #bulkDeactivate').prop('disabled', true);
|
|
});
|
|
|
|
// Edit button opens modal and populates fields
|
|
let lastTrigger = null;
|
|
$(document).on('click', '.editBtn', function(){
|
|
lastTrigger = this;
|
|
const row = $(this).closest('.user-row');
|
|
$('#editId').val(row.data('id'));
|
|
$('#editName').val(row.data('name'));
|
|
$('#editEmail').val(row.data('email'));
|
|
$('#editCategory').val(row.data('category'));
|
|
});
|
|
|
|
// When edit modal closes, return focus to trigger
|
|
$('#editModal').on('hidden.bs.modal', function(){
|
|
if (lastTrigger && document.contains(lastTrigger)) lastTrigger.focus();
|
|
lastTrigger = null;
|
|
});
|
|
|
|
// Submit edit (demo: updates row inline)
|
|
$('#editForm').on('submit', function(e){
|
|
e.preventDefault();
|
|
const id = $('#editId').val();
|
|
const name = $('#editName').val();
|
|
const email = $('#editEmail').val();
|
|
const category = $('#editCategory').val();
|
|
|
|
const row = $(`.user-row[data-id="${id}"]`);
|
|
// Update data attrs and visible cells
|
|
row.data('name', name).data('email', email).data('category', category);
|
|
row.find('.fw-semibold').text(name);
|
|
row.find('td').eq(2).text(email);
|
|
row.find('.category-badge').removeClass('badge-district badge-regional badge-national');
|
|
if (category === 'District') row.find('.category-badge').addClass('badge-district').text('District');
|
|
if (category === 'Regional') row.find('.category-badge').addClass('badge-regional').text('Regional');
|
|
if (category === 'National') row.find('.category-badge').addClass('badge-national').text('National');
|
|
|
|
// Move row to correct table if category changed
|
|
const targetBody = category === 'District' ? '#districtBody' : (category === 'Regional' ? '#regionalBody' : '#nationalBody');
|
|
if (!row.parent().is(targetBody)) {
|
|
row.appendTo($(targetBody));
|
|
}
|
|
|
|
updateCounts();
|
|
$('#editModal').modal('hide');
|
|
});
|
|
|
|
// Bulk move: gather selected rows and show count
|
|
$('#bulkMoveBtn').on('click', function(){
|
|
const selected = $('.tab-pane.active .row-select:checked');
|
|
$('#moveCount').text(selected.length);
|
|
// focus first control in modal for accessibility
|
|
$('#moveModal').on('shown.bs.modal', function(){ $('#moveTarget').focus(); });
|
|
});
|
|
|
|
// Remember trigger to restore focus after move modal
|
|
$('#moveModal').on('hidden.bs.modal', function(){ $('.tab-pane.active').find('.row-select:checked').first().closest('tr').find('.row-select').focus(); });
|
|
|
|
// Execute move
|
|
$('#moveForm').on('submit', function(e){
|
|
e.preventDefault();
|
|
const target = $('#moveTarget').val();
|
|
const selected = $('.tab-pane.active .row-select:checked').closest('.user-row');
|
|
selected.each(function(){
|
|
const $r = $(this);
|
|
$r.data('category', target);
|
|
$r.find('.category-badge').removeClass('badge-district badge-regional badge-national');
|
|
if (target === 'District') $r.find('.category-badge').addClass('badge-district').text('District');
|
|
if (target === 'Regional') $r.find('.category-badge').addClass('badge-regional').text('Regional');
|
|
if (target === 'National') $r.find('.category-badge').addClass('badge-national').text('National');
|
|
const targetBody = target === 'District' ? '#districtBody' : (target === 'Regional' ? '#regionalBody' : '#nationalBody');
|
|
$r.appendTo($(targetBody));
|
|
$r.find('.row-select').prop('checked', false);
|
|
});
|
|
$('#moveModal').modal('hide');
|
|
$('#globalSelect').prop('checked', false);
|
|
$('#bulkMoveBtn, #bulkDeactivate').prop('disabled', true);
|
|
updateCounts();
|
|
});
|
|
|
|
// Bulk deactivate demo (toggles status)
|
|
$('#bulkDeactivate').on('click', function(){
|
|
const selected = $('.tab-pane.active .row-select:checked').closest('.user-row');
|
|
selected.each(function(){
|
|
const $r = $(this);
|
|
$r.data('status', 'Suspended');
|
|
// optionally add visual cue
|
|
$r.addClass('table-danger');
|
|
setTimeout(()=> $r.removeClass('table-danger'), 1200);
|
|
$r.find('.row-select').prop('checked', false);
|
|
});
|
|
$('#bulkMoveBtn, #bulkDeactivate').prop('disabled', true);
|
|
});
|
|
|
|
// Accessibility: avoid aria-hidden on focused elements (demo check)
|
|
// If you manually toggle aria-hidden elsewhere, ensure focus is moved first.
|
|
// Update counts initially
|
|
updateCounts();
|
|
|
|
// Demo: focus first edit button when pressing 'e' (example of keyboard shortcut)
|
|
$(document).on('keydown', function(e){
|
|
if (e.key === 'e' && !$(e.target).is('input, textarea')) {
|
|
e.preventDefault();
|
|
$('.editBtn').first().focus();
|
|
}
|
|
});
|
|
})();
|
|
</script> |