127 lines
5.1 KiB
PHP
127 lines
5.1 KiB
PHP
<?php
|
|
require_once 'includes/header.php';
|
|
|
|
if (!isAdmin()) {
|
|
redirect('index.php');
|
|
}
|
|
|
|
$type_filter = $_GET['type'] ?? '';
|
|
$user_filter = $_GET['user_id'] ?? '';
|
|
|
|
$params = [];
|
|
$where = ["due_date < CURDATE()", "status != 'closed'"];
|
|
|
|
if ($type_filter) {
|
|
$where[] = "type = ?";
|
|
$params[] = $type_filter;
|
|
}
|
|
|
|
if ($user_filter) {
|
|
$where[] = "assigned_to = ?";
|
|
$params[] = $user_filter;
|
|
}
|
|
|
|
$where_clause = implode(" AND ", $where);
|
|
$sql = "SELECT m.*, u.full_name as assigned_name
|
|
FROM mailbox m
|
|
LEFT JOIN users u ON m.assigned_to = u.id
|
|
WHERE $where_clause
|
|
ORDER BY m.due_date ASC";
|
|
|
|
$stmt = db()->prepare($sql);
|
|
$stmt->execute($params);
|
|
$overdue_items = $stmt->fetchAll();
|
|
|
|
// Fetch all users for filter
|
|
$users = db()->query("SELECT id, full_name FROM users ORDER BY full_name")->fetchAll();
|
|
?>
|
|
|
|
<div class="d-flex justify-content-between flex-wrap flex-md-nowrap align-items-center pt-3 pb-2 mb-3 border-bottom">
|
|
<h1 class="h2">تقرير المهام المتأخرة</h1>
|
|
</div>
|
|
|
|
<div class="card mb-4">
|
|
<div class="card-body">
|
|
<form method="GET" class="row g-3">
|
|
<div class="col-md-4">
|
|
<label class="form-label">نوع البريد</label>
|
|
<select name="type" class="form-select">
|
|
<option value="">الكل</option>
|
|
<option value="inbound" <?= $type_filter == 'inbound' ? 'selected' : '' ?>>وارد</option>
|
|
<option value="outbound" <?= $type_filter == 'outbound' ? 'selected' : '' ?>>صادر</option>
|
|
</select>
|
|
</div>
|
|
<div class="col-md-4">
|
|
<label class="form-label">الموظف المسؤول</label>
|
|
<select name="user_id" class="form-select">
|
|
<option value="">الكل</option>
|
|
<?php foreach ($users as $user): ?>
|
|
<option value="<?= $user['id'] ?>" <?= $user_filter == $user['id'] ? 'selected' : '' ?>>
|
|
<?= htmlspecialchars($user['full_name']) ?>
|
|
</option>
|
|
<?php endforeach; ?>
|
|
</select>
|
|
</div>
|
|
<div class="col-md-4 d-flex align-items-end">
|
|
<button type="submit" class="btn btn-primary w-100">تصفية</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card">
|
|
<div class="card-header bg-danger text-white">
|
|
<h5 class="card-title mb-0"><i class="fas fa-exclamation-triangle me-2"></i> جميع المهام المتأخرة</h5>
|
|
</div>
|
|
<div class="card-body">
|
|
<div class="table-responsive">
|
|
<table class="table table-hover">
|
|
<thead>
|
|
<tr>
|
|
<th>رقم المرجع</th>
|
|
<th>النوع</th>
|
|
<th>الموضوع</th>
|
|
<th>الموظف المسؤول</th>
|
|
<th>تاريخ الاستحقاق</th>
|
|
<th>الأيام المتأخرة</th>
|
|
<th>الإجراءات</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<?php if (empty($overdue_items)): ?>
|
|
<tr>
|
|
<td colspan="7" class="text-center py-4 text-muted">لا توجد مهام متأخرة حالياً.</td>
|
|
</tr>
|
|
<?php else: ?>
|
|
<?php foreach ($overdue_items as $item):
|
|
$due_date = new DateTime($item['due_date']);
|
|
$today = new DateTime();
|
|
$diff = $today->diff($due_date)->format("%a");
|
|
?>
|
|
<tr>
|
|
<td><?= htmlspecialchars($item['ref_no']) ?></td>
|
|
<td>
|
|
<span class="badge bg-<?= $item['type'] == 'inbound' ? 'info' : 'warning' ?>">
|
|
<?= $item['type'] == 'inbound' ? 'وارد' : 'صادر' ?>
|
|
</span>
|
|
</td>
|
|
<td><?= htmlspecialchars($item['subject']) ?></td>
|
|
<td><?= htmlspecialchars($item['assigned_name'] ?? 'غير معين') ?></td>
|
|
<td class="text-danger fw-bold"><?= $item['due_date'] ?></td>
|
|
<td class="text-danger fw-bold"><?= $diff ?> يوم</td>
|
|
<td>
|
|
<a href="view_mail.php?id=<?= $item['id'] ?>" class="btn btn-sm btn-outline-primary">
|
|
<i class="fas fa-eye"></i> عرض
|
|
</a>
|
|
</td>
|
|
</tr>
|
|
<?php endforeach; ?>
|
|
<?php endif; ?>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<?php require_once 'includes/footer.php'; ?>
|