Sindbad~EG File Manager
<?php
require_once '../../config/config.php';
checkLogin();
$pageTitle = 'Edit Members - ' . APP_NAME;
$db = Database::getInstance()->getConnection();
// Get user access parameters
$accessLevel = $_SESSION['access_level'] ?? 'assembly';
$areaId = $_SESSION['area_id'] ?? null;
$districtId = $_SESSION['district_id'] ?? null;
$assemblyId = $_SESSION['assembly_id'] ?? null;
// Load districts and assemblies for filters
$districts = [];
$assemblies = [];
try {
$districtsStmt = $db->query("SELECT id, district_name FROM districts WHERE is_active = 1 ORDER BY district_name");
$districts = $districtsStmt->fetchAll();
} catch (PDOException $e) {
// ignore
}
try {
$assembliesStmt = $db->query("SELECT id, assembly_name FROM assemblies WHERE is_active = 1 ORDER BY assembly_name");
$assemblies = $assembliesStmt->fetchAll();
} catch (PDOException $e) {
// ignore
}
// Build base query
$query = "SELECT m.*, a.area_name, d.district_name, asm.assembly_name
FROM members m
JOIN areas a ON m.area_id = a.id
JOIN districts d ON m.district_id = d.id
JOIN assemblies asm ON m.assembly_id = asm.id
WHERE 1=1";
$params = [];
// Access level constraints (same as index)
if ($accessLevel === 'assembly') {
$query .= " AND m.assembly_id = :assembly_id";
$params['assembly_id'] = $assemblyId;
} elseif ($accessLevel === 'district') {
$query .= " AND m.district_id = :district_id";
$params['district_id'] = $districtId;
} elseif ($accessLevel === 'area') {
$query .= " AND m.area_id = :area_id";
$params['area_id'] = $areaId;
}
// Optional filters
if (isset($_GET['district_filter']) && $_GET['district_filter'] !== '') {
$query .= " AND m.district_id = :filter_district_id";
$params['filter_district_id'] = (int)$_GET['district_filter'];
}
if (isset($_GET['assembly_filter']) && $_GET['assembly_filter'] !== '') {
$query .= " AND m.assembly_id = :filter_assembly_id";
$params['filter_assembly_id'] = (int)$_GET['assembly_filter'];
}
if (isset($_GET['search']) && $_GET['search'] !== '') {
$search = '%' . $_GET['search'] . '%';
$query .= " AND (m.first_name LIKE :search1 OR m.last_name LIKE :search2 OR m.email LIKE :search3)";
$params['search1'] = $search;
$params['search2'] = $search;
$params['search3'] = $search;
}
$query .= " ORDER BY m.created_at DESC";
$stmt = $db->prepare($query);
$stmt->execute($params);
$members = $stmt->fetchAll();
include '../../includes/header.php';
include '../../includes/sidebar.php';
?>
<main class="flex-1 md:ml-64 mt-16">
<div class="container mx-auto px-4 py-8">
<!-- Page Header -->
<div class="flex flex-col md:flex-row justify-between items-start md:items-center mb-6 gap-4">
<div>
<h1 class="text-3xl font-bold text-gray-800">
<i class="fas fa-user-edit mr-2 text-blue-500"></i>Edit Members
</h1>
<p class="text-gray-600 mt-2">Filter and edit members individually or in bulk</p>
</div>
<div class="flex gap-3">
<a href="index.php" class="btn-gradient text-white px-6 py-3 rounded-full font-semibold transition shadow-lg hover:shadow-xl">
<i class="fas fa-users mr-2"></i>Back to Members
</a>
</div>
</div>
<!-- Filters -->
<div class="bg-white rounded-lg shadow-lg p-6 mb-6">
<form method="GET" action="" class="flex flex-col md:flex-row gap-4 items-center">
<div class="flex-1 w-full">
<div class="relative">
<input type="text"
name="search"
placeholder="Search by name or email..."
value="<?php echo htmlspecialchars($_GET['search'] ?? ''); ?>"
class="w-full pl-10 pr-4 py-3 border border-gray-300 rounded-lg focus:ring-2 focus:ring-blue-500 focus:border-transparent">
<i class="fas fa-search absolute left-3 top-4 text-gray-400"></i>
</div>
</div>
<div class="flex items-center space-x-3">
<div>
<label class="block text-xs font-semibold text-gray-600 mb-1">District</label>
<select name="district_filter" class="px-3 py-2 border border-gray-300 rounded-lg text-sm">
<option value="">All</option>
<?php foreach ($districts as $dist): ?>
<option value="<?php echo $dist['id']; ?>" <?php echo (isset($_GET['district_filter']) && $_GET['district_filter'] == $dist['id']) ? 'selected' : ''; ?>>
<?php echo htmlspecialchars($dist['district_name']); ?>
</option>
<?php endforeach; ?>
</select>
</div>
<div>
<label class="block text-xs font-semibold text-gray-600 mb-1">Assembly</label>
<select name="assembly_filter" class="px-3 py-2 border border-gray-300 rounded-lg text-sm">
<option value="">All</option>
<?php foreach ($assemblies as $asm): ?>
<option value="<?php echo $asm['id']; ?>" <?php echo (isset($_GET['assembly_filter']) && $_GET['assembly_filter'] == $asm['id']) ? 'selected' : ''; ?>>
<?php echo htmlspecialchars($asm['assembly_name']); ?>
</option>
<?php endforeach; ?>
</select>
</div>
<button type="submit" class="bg-blue-500 text-white px-6 py-3 rounded-lg hover:bg-blue-600 transition">
<i class="fas fa-filter mr-2"></i>Filter
</button>
<a href="members_edit.php" class="bg-gray-500 text-white px-6 py-3 rounded-lg hover:bg-gray-600 transition text-center">
<i class="fas fa-redo mr-2"></i>Reset
</a>
</div>
</form>
</div>
<!-- Members Edit Table -->
<div class="bg-white rounded-lg shadow-lg overflow-hidden">
<?php if (!empty($members)): ?>
<div class="flex justify-between items-center px-4 py-3 border-b border-gray-200 bg-gray-50">
<div class="flex space-x-2">
<button type="button" onclick="submitBulkEditMembers()" class="bg-blue-600 text-white px-4 py-2 rounded-lg hover:bg-blue-700 transition">
<i class="fas fa-edit mr-1"></i>Bulk Edit Selected
</button>
<button type="button" onclick="submitBulkCSVEdit()" class="bg-green-600 text-white px-4 py-2 rounded-lg hover:bg-green-700 transition">
<i class="fas fa-table mr-1"></i>Bulk Excel Edit
</button>
</div>
</div>
<?php endif; ?>
<div class="overflow-x-auto">
<form id="membersEditForm" method="POST">
<table class="min-w-full divide-y divide-gray-200">
<thead class="bg-gradient-to-r from-blue-500 to-blue-600">
<tr>
<th class="px-4 py-3 text-left text-xs font-medium text-white uppercase tracking-wider">
<input type="checkbox" id="selectAllEdit" class="rounded">
</th>
<th class="px-6 py-3 text-left text-xs font-medium text-white uppercase tracking-wider">Member</th>
<th class="px-6 py-3 text-left text-xs font-medium text-white uppercase tracking-wider">Contact</th>
<th class="px-6 py-3 text-left text-xs font-medium text-white uppercase tracking-wider">Location</th>
<th class="px-6 py-3 text-left text-xs font-medium text-white uppercase tracking-wider">Status</th>
<th class="px-6 py-3 text-left text-xs font-medium text-white uppercase tracking-wider">Actions</th>
</tr>
</thead>
<tbody class="bg-white divide-y divide-gray-200">
<?php if (empty($members)): ?>
<tr>
<td colspan="6" class="px-6 py-12 text-center text-gray-500">
<i class="fas fa-users-cog text-5xl mb-4 text-gray-300"></i>
<p class="text-lg">No members found for editing</p>
</td>
</tr>
<?php else: ?>
<?php foreach ($members as $member): ?>
<tr class="hover:bg-gray-50 transition">
<td class="px-4 py-4 whitespace-nowrap">
<input type="checkbox" name="member_ids[]" value="<?php echo $member['id']; ?>" class="memberEditCheckbox rounded">
</td>
<td class="px-6 py-4 whitespace-nowrap">
<div class="flex items-center">
<img src="<?php echo !empty($member['profile_photo']) ? BASE_URL . 'uploads/members/' . $member['profile_photo'] : BASE_URL . 'assets/images/default-avatar.png'; ?>"
alt="<?php echo htmlspecialchars($member['first_name']); ?>"
class="w-10 h-10 rounded-full object-cover mr-3 border-2 border-blue-200">
<div>
<div class="font-semibold text-gray-800">
<?php echo htmlspecialchars(($member['title'] ?? '') . ' ' . $member['first_name'] . ' ' . $member['last_name']); ?>
</div>
<div class="text-sm text-gray-500">
<?php echo htmlspecialchars($member['member_type']); ?>
</div>
</div>
</div>
</td>
<td class="px-6 py-4 whitespace-nowrap">
<div class="text-sm">
<div class="text-gray-800">
<i class="fas fa-phone text-blue-500 mr-1"></i>
<?php echo htmlspecialchars($member['phone'] ?: 'N/A'); ?>
</div>
<div class="text-gray-500">
<i class="fas fa-envelope text-blue-500 mr-1"></i>
<?php echo htmlspecialchars($member['email'] ?: 'N/A'); ?>
</div>
</div>
</td>
<td class="px-6 py-4">
<div class="text-sm text-gray-800">
<?php echo htmlspecialchars($member['assembly_name']); ?>
</div>
<div class="text-xs text-gray-500">
<?php echo htmlspecialchars($member['district_name']); ?>
</div>
</td>
<td class="px-6 py-4 whitespace-nowrap">
<div class="space-y-1">
<?php if ($member['is_active'] ?? 1): ?>
<span class="inline-flex px-2 py-1 text-xs font-semibold rounded-full bg-green-100 text-green-800">
<i class="fas fa-check-circle mr-1"></i>Active
</span>
<?php else: ?>
<span class="inline-flex px-2 py-1 text-xs font-semibold rounded-full bg-red-100 text-red-800">
<i class="fas fa-times-circle mr-1"></i>Inactive
</span>
<?php endif; ?>
</div>
</td>
<td class="px-6 py-4 whitespace-nowrap text-sm">
<div class="flex space-x-2">
<a href="edit.php?id=<?php echo $member['id']; ?>"
class="text-blue-600 hover:text-blue-800 transition"
title="Edit Member">
<i class="fas fa-edit"></i>
</a>
</div>
</td>
</tr>
<?php endforeach; ?>
<?php endif; ?>
</tbody>
</table>
</form>
</div>
</div>
</div>
<script>
const selectAllEdit = document.getElementById('selectAllEdit');
const editCheckboxes = document.querySelectorAll('.memberEditCheckbox');
if (selectAllEdit) {
selectAllEdit.addEventListener('change', function() {
editCheckboxes.forEach(cb => cb.checked = selectAllEdit.checked);
});
}
function getSelectedEditCount() {
let count = 0;
editCheckboxes.forEach(cb => { if (cb.checked) count++; });
return count;
}
function submitBulkEditMembers() {
if (getSelectedEditCount() === 0) {
alert('Please select at least one member to bulk edit.');
return;
}
const form = document.getElementById('membersEditForm');
form.action = 'bulk_edit.php';
form.method = 'POST';
form.submit();
}
function submitBulkCSVEdit() {
if (getSelectedEditCount() === 0) {
alert('Please select at least one member for Excel editing.');
return;
}
const form = document.getElementById('membersEditForm');
form.action = 'bulk_csv_edit.php';
form.method = 'POST';
form.submit();
}
</script>
</main>
<?php include '../../includes/footer.php'; ?>
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists