Add viewJobOrderHistory API call to rider api. #420

This commit is contained in:
Korina Cordero 2020-06-01 04:37:12 +00:00
parent 2ea5bfe193
commit 8730ab4ea3
3 changed files with 180 additions and 0 deletions

View file

@ -64,3 +64,8 @@ cmb_rapi_available:
path: /cmbrapi/available
controller: App\Controller\CMBRAPIController::available
methods: [POST]
cmb_rapi_jo_history_view:
path: /cmbrapi/joborderhistory
controller: App\Controller\CMBRAPIController::viewJobOrderHistory
methods: [GET]

View file

@ -300,4 +300,27 @@ class CMBRAPIController extends Controller
// response
return $res->getReturnResponse();
}
public function viewJobOrderHistory(Request $req, RiderAPIHandlerInterface $rapi_handler)
{
$res = new APIResult();
$data = $rapi_handler->getJobOrderHistory($req);
if (isset($data['error']))
{
$message = $data['error'];
$res->setError(true)
->setErrorMessage($message);
}
else
{
$res->setData($data);
}
// response
return $res->getReturnResponse();
}
}

View file

@ -30,6 +30,7 @@ use App\Entity\Promo;
use App\Entity\Battery;
use App\Entity\BatteryModel;
use App\Entity\BatterySize;
use App\Entity\JobOrder;
use DateTime;
@ -243,6 +244,157 @@ class CMBRiderAPIHandler implements RiderAPIHandlerInterface
return $data;
}
public function getJobOrderHistory(Request $req)
{
$required_params = [];
$data = $this->checkParamsAndKey($req, $required_params);
if (isset($data['error']))
return $data;
// are we logged in?
if (!$this->session->hasRider())
{
$data = [
'error' => 'No logged in rider.'
];
return $data;
}
$rider = $this->session->getRider();
// get JOs assigned to rider for the month given
// TODO: what date to use
// for now, using date_schedule
// setup start date and end dates
// get current year
$month = $req->query->get('month');
$current_date = new DateTime();
$current_year = $current_date->format('Y');
// get number of days in month requested
$last_day = cal_days_in_month(CAL_GREGORIAN, $month, $current_year);
$s_date = $current_year . '-' . $month . '-01 00:00:00';
$e_date = $current_year . '-' . $month . '-' . $last_day . ' 23:59:59';
$qb = $this->em->getRepository(JobOrder::class)->createQueryBuilder('j');
$query = $qb->innerJoin('j.rider', 'r')
->where('j.date_schedule >= :start')
->andWhere('j.date_schedule <= :end')
->andWhere('r.id = :rider_id')
->setParameter('start', $s_date)
->setParameter('end', $e_date)
->setParameter('rider_id', $rider->getID())
->getQuery();
$jo_results = $query->getResult();
$jo_data = [];
if (!(empty($jo_results)))
{
foreach ($jo_results as $jo)
{
$coord = $jo->getCoordinates();
$cust = $jo->getCustomer();
$cv = $jo->getCustomerVehicle();
$v = $cv->getVehicle();
$inv = $jo->getInvoice();
$promo = $inv->getPromo();
// invoice items
$inv_items = [];
foreach ($inv->getItems() as $item)
{
$item_batt = $item->getBattery();
if ($item_batt == null)
$batt_id = null;
else
$batt_id = $item_batt->getID();
$inv_items[] = [
'id' => $item->getID(),
'title' => $item->getTitle(),
'qty' => $item->getQuantity(),
'price' => $item->getPrice(),
'batt_id' => $batt_id,
];
}
// promo
if ($promo != null)
{
$promo_data = [
'id' => $promo->getID(),
'name' => $promo->getName(),
'code' => $promo->getCode(),
'discount_rate' => $promo->getDiscountRate(),
'discount_apply' => $promo->getDiscountApply(),
];
}
else
{
$promo_data = null;
}
$trade_in_type = $jo->getTradeInType();
if (empty($trade_in_type))
$trade_in_type = 'none';
$jo_data[] = [
'job_order' => [
'id' => $jo->getID(),
'service_type' => $jo->getServiceType(),
'date_schedule' => $jo->getDateSchedule()->format('Ymd H:i:s'),
'longitude' => $coord->getLongitude(),
'latitude' => $coord->getLatitude(),
'status' => $jo->getStatus(),
'customer' => [
'title' => $cust->getTitle(),
'first_name' => $cust->getFirstName(),
'last_name' => $cust->getLastName(),
'phone_mobile' => $this->country_code . $cust->getPhoneMobile(),
],
'vehicle' => [
'manufacturer' => $v->getManufacturer()->getName(),
'make' => $v->getMake(),
'model' => $cv->getModelYear(),
'plate_number' => $cv->getPlateNumber(),
'color' => $cv->getColor(),
],
'or_num' => $jo->getORNum(),
'or_name' => $jo->getORName(),
'delivery_instructions' => $jo->getDeliveryInstructions(),
'delivery_address' => $jo->getDeliveryAddress(),
'landmark' => $jo->getLandmark(),
'invoice' => [
'discount' => $inv->getDiscount(),
'trade_in' => $inv->getTradeIn(),
'total_price' => $inv->getTotalPrice(),
'vat' => $inv->getVat(),
'items' => $inv_items,
],
'mode_of_payment' => $jo->getModeOfPayment(),
'trade_in_type' => $trade_in_type,
'promo' => $promo_data,
// TODO: load the actual
'has_warranty_doc' => false,
'flag_coolant' => $jo->hasCoolant(),
'has_motolite' => $cv->hasMotoliteBattery(),
]
];
}
}
$data = [
'jo_history' => $jo_data,
];
return $data;
}
public function getJobOrder(Request $req)
{
// get the job order of the rider assigned to this session