Files
intaleq_v3_pure_php/ride/driver_order/get.php
2026-04-28 13:04:27 +03:00

75 lines
2.2 KiB
PHP
Executable File

<?php
require_once __DIR__ . '/../../connect.php';
$driver_id = filterRequest("driver_id");
$order_id = filterRequest("order_id");
if ($driver_id != null) {
// 1. First, get the statistics for the driver
$stats_sql = "
SELECT
COUNT(*) AS total_rides,
SUM(CASE WHEN status = 'Apply' THEN 1 ELSE 0 END) AS total_applied,
SUM(CASE WHEN status = 'Refused' THEN 1 ELSE 0 END) AS total_refused
FROM driver_orders
WHERE
driver_id = :driver_id
AND MONTH(created_at) = MONTH(CURRENT_DATE())
AND YEAR(created_at) = YEAR(CURRENT_DATE())
";
$stats_stmt = $con->prepare($stats_sql);
$stats_stmt->execute([':driver_id' => $driver_id]);
$stats = $stats_stmt->fetch(PDO::FETCH_ASSOC);
// Calculate the average
if ($stats && $stats['total_rides'] > 0) {
$stats['averageApplied'] = $stats['total_applied'] / $stats['total_rides'];
} else {
$stats['averageApplied'] = 0;
}
// 2. Second, get the actual order history
$orders_sql = "
SELECT * FROM driver_orders
WHERE
driver_id = :driver_id
AND MONTH(created_at) = MONTH(CURRENT_DATE())
AND YEAR(created_at) = YEAR(CURRENT_DATE())
ORDER BY created_at DESC
";
$orders_stmt = $con->prepare($orders_sql);
$orders_stmt->execute([':driver_id' => $driver_id]);
$orders = $orders_stmt->fetchAll(PDO::FETCH_ASSOC);
// 3. Combine the results into one response
jsonSuccess($orders);
} elseif ($order_id != null) {
// This part remains the same, but let's ensure it's correct
$sql = "
SELECT * FROM driver_orders
WHERE order_id = :order_id
AND MONTH(created_at) = MONTH(CURRENT_DATE())
AND YEAR(created_at) = YEAR(CURRENT_DATE())
";
$stmt = $con->prepare($sql);
$stmt->execute([':order_id' => $order_id]);
$result = $stmt->fetchAll(PDO::FETCH_ASSOC);
if ($stmt->rowCount() > 0) {
jsonSuccess($result);
} else {
jsonError("No driver order data found for this order_id");
}
} else {
jsonError("No driver_id or order_id provided");
}
?>