187 lines
4.2 KiB
PHP
187 lines
4.2 KiB
PHP
<?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 AS carType,
|
|
ride.paymentMethod AS ridePaymentMethod,
|
|
ride.rideTimeFinish AS rideTimeFinish,
|
|
payments.amount as paymentFromPaymentTable,
|
|
payments.created_at as timeFromPaymentTable,
|
|
(
|
|
SELECT
|
|
AVG(rd.rating)
|
|
FROM
|
|
ratingDriver rd
|
|
WHERE
|
|
rd.driver_id = cm.driver_id
|
|
) AS avgRatingDriverFromPassengers,
|
|
(
|
|
SELECT
|
|
COUNT(*)
|
|
FROM
|
|
ratingDriver rd
|
|
WHERE
|
|
rd.driver_id = cm.driver_id
|
|
) AS countratingDriverFromPassengers,
|
|
(
|
|
SELECT
|
|
AVG(rp.rating)
|
|
FROM
|
|
ratingPassenger rp
|
|
WHERE
|
|
rp.passenger_id = cm.passenger_id
|
|
) AS avgRatingPassengerFromDrivers,
|
|
(
|
|
SELECT
|
|
COUNT(*)
|
|
FROM
|
|
ratingPassenger rp
|
|
WHERE
|
|
rp.passenger_id = cm.passenger_id
|
|
) AS countRatingPassengerFromDrivers,
|
|
(
|
|
SELECT
|
|
COUNT(*)
|
|
FROM
|
|
ride
|
|
WHERE
|
|
ride.driver_id = cm.driver_id
|
|
) countDriverRide,
|
|
(
|
|
SELECT
|
|
COUNT(*)
|
|
FROM
|
|
ride
|
|
WHERE
|
|
ride.passenger_id = cm.passenger_id
|
|
) countPassengerRide,
|
|
(
|
|
SELECT
|
|
COALESCE(SUM(amount),
|
|
0) AS visaDriver
|
|
FROM
|
|
payments
|
|
WHERE
|
|
isGiven = 'waiting' AND `payment_method` IN(
|
|
'visa-in',
|
|
'visa',
|
|
'visaRide',
|
|
'TransferFrom',
|
|
'payout',
|
|
'TransferTo'
|
|
) AND payments.`driverID` = cm.driver_id
|
|
) AS driverVisa,
|
|
(
|
|
SELECT
|
|
COALESCE(SUM(amount),
|
|
0) AS pointDriver
|
|
FROM
|
|
driverWallet dw
|
|
WHERE
|
|
dw.paymentMethod IN(
|
|
'visa-in',
|
|
'visa',
|
|
'visaRide',
|
|
'TransferFrom',
|
|
'payout',
|
|
'TransferTo'
|
|
) AND dw.`driverID` = cm.driver_id
|
|
) AS driverWallet,
|
|
(
|
|
SELECT
|
|
COALESCE(SUM(pw.balance),
|
|
0)
|
|
FROM
|
|
passengerWallet pw
|
|
WHERE
|
|
pw.passenger_id = cm.passenger_id
|
|
) AS passengerWallet,
|
|
(
|
|
SELECT
|
|
token
|
|
FROM
|
|
driverToken
|
|
WHERE
|
|
driverToken.captain_id = cm.driver_id
|
|
) AS driverToken,
|
|
(
|
|
SELECT
|
|
token
|
|
FROM
|
|
tokens
|
|
WHERE
|
|
tokens.passengerID = cm.passenger_id
|
|
) AS passengerToken,
|
|
(
|
|
SELECT
|
|
COUNT(*)
|
|
FROM
|
|
complaint
|
|
WHERE
|
|
complaint.passenger_id = cm.passenger_id AND cm.complaint_type = 'Passenger'
|
|
) AS countOfComplaintFromPassenger,
|
|
(
|
|
SELECT
|
|
COUNT(*)
|
|
FROM
|
|
complaint
|
|
WHERE
|
|
complaint.driver_id = cm.driver_id AND cm.complaint_type = 'Driver'
|
|
) AS countOfComplaintFromDriver
|
|
FROM
|
|
`complaint` cm
|
|
LEFT JOIN passengers p ON
|
|
p.id = cm.`passenger_id`
|
|
LEFT JOIN driver d ON
|
|
d.id = cm.driver_id
|
|
LEFT JOIN ride ON ride.id = cm.ride_id
|
|
left join payments on payments.rideId=cm.ride_id";
|
|
|
|
try {
|
|
$stmt = $con->prepare($sql);
|
|
$stmt->execute();
|
|
|
|
$row = $stmt->fetchAll(PDO::FETCH_ASSOC);
|
|
|
|
if ($row) {
|
|
foreach ($row as &$item) {
|
|
if (!empty($item['passengerName'])) {
|
|
$dec = $encryptionHelper->decryptData($item['passengerName']);
|
|
if ($dec) $item['passengerName'] = $dec;
|
|
}
|
|
if (!empty($item['driverName'])) {
|
|
$dec = $encryptionHelper->decryptData($item['driverName']);
|
|
if ($dec) $item['driverName'] = $dec;
|
|
}
|
|
if (!empty($item['driverToken'])) {
|
|
$dec = $encryptionHelper->decryptData($item['driverToken']);
|
|
if ($dec) $item['driverToken'] = $dec;
|
|
}
|
|
if (!empty($item['passengerToken'])) {
|
|
$dec = $encryptionHelper->decryptData($item['passengerToken']);
|
|
if ($dec) $item['passengerToken'] = $dec;
|
|
}
|
|
}
|
|
jsonSuccess($row);
|
|
} else {
|
|
jsonSuccess([], "No complaints found");
|
|
}
|
|
} catch (Exception $e) {
|
|
jsonError("Database error: " . $e->getMessage());
|
|
}
|
|
?>
|