first commit
This commit is contained in:
148
backend/serviceapp/getComplaintAllData.php
Normal file
148
backend/serviceapp/getComplaintAllData.php
Normal file
@@ -0,0 +1,148 @@
|
||||
<?php
|
||||
require_once __DIR__ . '/../connect.php';
|
||||
|
||||
$sql = "
|
||||
SELECT
|
||||
cm.id, cm.ride_id, cm.passenger_id, cm.driver_id,
|
||||
cm.complaint_type, cm.description, cm.date_filed,
|
||||
cm.statusComplaint, cm.resolution, cm.date_resolved,
|
||||
p.first_name AS passengerName,
|
||||
d.name_arabic AS driverName,
|
||||
d.gender,
|
||||
ride.price AS priceOfRide,
|
||||
ride.status AS rideStatus,
|
||||
ride.carType,
|
||||
ride.paymentMethod AS ridePaymentMethod,
|
||||
ride.rideTimeFinish,
|
||||
payments.amount AS paymentFromPaymentTable,
|
||||
payments.created_at AS timeFromPaymentTable,
|
||||
|
||||
COALESCE(dr_rating.avgRating, 0) AS avgRatingDriverFromPassengers,
|
||||
COALESCE(dr_rating.cntRating, 0) AS countratingDriverFromPassengers,
|
||||
COALESCE(ps_rating.avgRating, 0) AS avgRatingPassengerFromDrivers,
|
||||
COALESCE(ps_rating.cntRating, 0) AS countRatingPassengerFromDrivers,
|
||||
COALESCE(dr_rides.cnt, 0) AS countDriverRide,
|
||||
COALESCE(ps_rides.cnt, 0) AS countPassengerRide,
|
||||
COALESCE(dr_visa.total, 0) AS driverVisa,
|
||||
COALESCE(dr_wallet.total, 0) AS driverWallet,
|
||||
COALESCE(ps_wallet.total, 0) AS passengerWallet,
|
||||
|
||||
dt.token AS driverToken,
|
||||
tk.token AS passengerToken,
|
||||
|
||||
COALESCE(ps_complaints.cnt, 0) AS countOfComplaintFromPassenger,
|
||||
COALESCE(dr_complaints.cnt, 0) AS countOfComplaintFromDriver
|
||||
|
||||
FROM complaint cm
|
||||
|
||||
LEFT JOIN passengers p
|
||||
ON p.id = cm.passenger_id COLLATE utf8mb4_general_ci
|
||||
|
||||
LEFT JOIN driver d
|
||||
ON d.id = cm.driver_id COLLATE utf8mb4_general_ci
|
||||
|
||||
LEFT JOIN ride
|
||||
ON ride.id = cm.ride_id COLLATE utf8mb4_general_ci
|
||||
|
||||
LEFT JOIN payments
|
||||
ON payments.rideId = cm.ride_id COLLATE utf8mb4_general_ci
|
||||
|
||||
-- تقييمات السائق (مرة واحدة لكل سائق)
|
||||
LEFT JOIN (
|
||||
SELECT driver_id, AVG(rating) AS avgRating, COUNT(*) AS cntRating
|
||||
FROM ratingDriver
|
||||
GROUP BY driver_id
|
||||
) dr_rating ON dr_rating.driver_id = cm.driver_id COLLATE utf8mb4_general_ci
|
||||
|
||||
-- تقييمات الراكب (مرة واحدة لكل راكب)
|
||||
LEFT JOIN (
|
||||
SELECT passenger_id, AVG(rating) AS avgRating, COUNT(*) AS cntRating
|
||||
FROM ratingPassenger
|
||||
GROUP BY passenger_id
|
||||
) ps_rating ON ps_rating.passenger_id = cm.passenger_id COLLATE utf8mb4_general_ci
|
||||
|
||||
-- عدد رحلات السائق
|
||||
LEFT JOIN (
|
||||
SELECT driver_id, COUNT(*) AS cnt
|
||||
FROM ride
|
||||
GROUP BY driver_id
|
||||
) dr_rides ON dr_rides.driver_id = cm.driver_id COLLATE utf8mb4_general_ci
|
||||
|
||||
-- عدد رحلات الراكب
|
||||
LEFT JOIN (
|
||||
SELECT passenger_id, COUNT(*) AS cnt
|
||||
FROM ride
|
||||
GROUP BY passenger_id
|
||||
) ps_rides ON ps_rides.passenger_id = cm.passenger_id COLLATE utf8mb4_general_ci
|
||||
|
||||
-- رصيد Visa السائق
|
||||
LEFT JOIN (
|
||||
SELECT driverID, SUM(amount) AS total
|
||||
FROM payments
|
||||
WHERE isGiven = 'waiting'
|
||||
AND payment_method IN ('visa-in','visa','visaRide','TransferFrom','payout','TransferTo')
|
||||
GROUP BY driverID
|
||||
) dr_visa ON dr_visa.driverID = cm.driver_id COLLATE utf8mb4_general_ci
|
||||
|
||||
-- محفظة السائق
|
||||
LEFT JOIN (
|
||||
SELECT driverID, SUM(amount) AS total
|
||||
FROM driverWallet
|
||||
WHERE paymentMethod IN ('visa-in','visa','visaRide','TransferFrom','payout','TransferTo')
|
||||
GROUP BY driverID
|
||||
) dr_wallet ON dr_wallet.driverID = cm.driver_id COLLATE utf8mb4_general_ci
|
||||
|
||||
-- محفظة الراكب
|
||||
LEFT JOIN (
|
||||
SELECT passenger_id, SUM(balance) AS total
|
||||
FROM passengerWallet
|
||||
GROUP BY passenger_id
|
||||
) ps_wallet ON ps_wallet.passenger_id = cm.passenger_id COLLATE utf8mb4_general_ci
|
||||
|
||||
-- توكن السائق
|
||||
LEFT JOIN driverToken dt
|
||||
ON dt.captain_id = cm.driver_id COLLATE utf8mb4_general_ci
|
||||
|
||||
-- توكن الراكب
|
||||
LEFT JOIN tokens tk
|
||||
ON tk.passengerID = cm.passenger_id COLLATE utf8mb4_general_ci
|
||||
|
||||
-- عدد شكاوى الراكب
|
||||
LEFT JOIN (
|
||||
SELECT passenger_id, COUNT(*) AS cnt
|
||||
FROM complaint
|
||||
WHERE complaint_type = 'Passenger'
|
||||
GROUP BY passenger_id
|
||||
) ps_complaints ON ps_complaints.passenger_id = cm.passenger_id
|
||||
|
||||
-- عدد شكاوى السائق
|
||||
LEFT JOIN (
|
||||
SELECT driver_id, COUNT(*) AS cnt
|
||||
FROM complaint
|
||||
WHERE complaint_type = 'Driver'
|
||||
GROUP BY driver_id
|
||||
) dr_complaints ON dr_complaints.driver_id = cm.driver_id
|
||||
";
|
||||
|
||||
try {
|
||||
$stmt = $con->prepare($sql);
|
||||
$stmt->execute();
|
||||
$row = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
||||
|
||||
if ($row) {
|
||||
foreach ($row as &$item) {
|
||||
foreach (['passengerName', 'driverName', 'driverToken', 'passengerToken'] as $field) {
|
||||
if (!empty($item[$field])) {
|
||||
$dec = $encryptionHelper->decryptData($item[$field]);
|
||||
if ($dec)
|
||||
$item[$field] = $dec;
|
||||
}
|
||||
}
|
||||
}
|
||||
jsonSuccess($row);
|
||||
} else {
|
||||
jsonSuccess([], "No complaints found");
|
||||
}
|
||||
} catch (Exception $e) {
|
||||
jsonError("Database error: " . $e->getMessage());
|
||||
}
|
||||
Reference in New Issue
Block a user