Change destination marker image, add backend functionality for job order processing stage

This commit is contained in:
Ramon Gutierrez 2018-01-30 22:05:32 +08:00
parent 2b4c289ba9
commit 29a838b1a8
4 changed files with 70 additions and 20 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.7 KiB

After

Width:  |  Height:  |  Size: 1.7 KiB

View file

@ -47,7 +47,7 @@ class JobOrderController extends BaseController
return $this->render('job-order/form.html.twig', $params);
}
public function incomingSubmit(Request $req)
public function incomingSubmit(Request $req, ValidatorInterface $validator)
{
$this->denyAccessUnlessGranted('jo_in.list', null, 'No access.');
@ -93,20 +93,16 @@ class JobOrderController extends BaseController
->setDeliveryInstructions($req->request->get('delivery_instructions'))
->setAgentNotes($req->request->get('agent_notes'))
->setDeliveryAddress($req->request->get('delivery_address'));
// validate
$errors = $validator->validate($obj);
// add errors to list
foreach ($errors as $error) {
$error_array[$error->getPropertyPath()] = $error->getMessage();
}
}
// TODO: Validation
/*
// validate
$errors = $validator->validate($obj);
// add errors to list
foreach ($errors as $error) {
$error_array[$error->getPropertyPath()] = $error->getMessage();
}
*/
// check if any errors were found
if (!empty($error_array)) {
// return validation failure response
@ -314,7 +310,59 @@ class JobOrderController extends BaseController
error_log(print_r($req->request->all(), true));
// TODO: validation and saving of updated job order
// check if lat and lng are provided
if (empty($req->request->get('coord_lng')) || empty($req->request->get('coord_lat'))) {
$error_array['coordinates'] = 'No map coordinates provided. Please click on a location on the map.';
}
// check if outlet is set
if (empty($req->request->get('outlet'))) {
$error_array['outlet'] = 'No outlet selected.';
} else {
// get outlet
$outlet = $em->getRepository(Outlet::class)->find($req->request->get('outlet'));
if (empty($outlet)) {
$error_array['outlet'] = 'Invalid outlet specified.';
}
}
if (empty($error_array)) {
// coordinates
$point = new Point($req->request->get('coord_lng'), $req->request->get('coord_lat'));
// set and save values
$obj->setDateSchedule(DateTime::createFromFormat("d M Y h:i A", $req->request->get('date_schedule_date') . " " . $req->request->get('date_schedule_time')))
->setCoordinates($point)
->setAdvanceOrder($req->request->get('flag_advance') ?? false)
->setServiceType($req->request->get('service_type'))
->setSource('web')
->setStatus($req->request->get('status'))
->setDeliveryInstructions($req->request->get('delivery_instructions'))
->setAgentNotes($req->request->get('agent_notes'))
->setDeliveryAddress($req->request->get('delivery_address'))
->setOutlet($outlet);
// validate
$errors = $validator->validate($obj);
// add errors to list
foreach ($errors as $error) {
$error_array[$error->getPropertyPath()] = $error->getMessage();
}
}
// check if any errors were found
if (!empty($error_array)) {
// return validation failure response
return $this->json([
'success' => false,
'errors' => $error_array
], 422);
}
// validated! save the entity
$em->flush();
// return successful response
return $this->json([

View file

@ -77,6 +77,7 @@ class JobOrder
/**
* @ORM\ManyToOne(targetEntity="Customer", inversedBy="job_orders")
* @ORM\JoinColumn(name="customer_id", referencedColumnName="id")
* Assert\NotBlank()
*/
protected $customer;
@ -84,6 +85,7 @@ class JobOrder
/**
* @ORM\ManyToOne(targetEntity="CustomerVehicle", inversedBy="job_orders")
* @ORM\JoinColumn(name="cvehicle_id", referencedColumnName="id")
* Assert\NotBlank()
*/
protected $cus_vehicle;

View file

@ -160,13 +160,13 @@
<div class="form-group m-form__group row">
<div class="col-lg-6">
<label>Transaction Date:</label>
<input type="text" name="date_transaction" class="form-control m-input" value="{{ "now"|date('d M Y') }}" disabled>
<input type="text" name="date_transaction" class="form-control m-input" value="{{ obj.getDateCreate|default("now")|date('d M Y') }}" disabled>
<div class="form-control-feedback hide" data-field="date_transaction"></div>
</div>
<div class="col-lg-3">
<label data-field="date_schedule">Scheduled Date:</label>
<div class="input-group date dp">
<input type="text" name="date_schedule_date" class="form-control m-input" data-default-value="{{ obj.getDateSchedule ? obj.getDateSchedule|date('Y-m-d') : "now"|date('Y-m-d') }}" value="{{ obj.getDateSchedule ? obj.getDateSchedule|date('d M Y') : "now"|date('d M Y') }}" readonly placeholder="Select a date" disabled>
<input type="text" name="date_schedule_date" class="form-control m-input" data-default-value="{{ obj.getDateSchedule|default("now")|date('Y-m-d') }}" value="{{ obj.getDateSchedule|default("now")|date('d M Y') }}" readonly placeholder="Select a date" disabled>
<span class="input-group-addon">
<i class="la la-calendar glyphicon-th"></i>
</span>
@ -176,7 +176,7 @@
<div class="col-lg-3">
<label data-field="date_schedule">Scheduled Time:</label>
<div class="input-group">
<input type="text" name="date_schedule_time" class="form-control m-input tp" data-default-value="{{ obj.getDateSchedule ? obj.getDateSchedule|date('g:i A') : "now"|date('g:i A') }}" value="{{ obj.getDateSchedule ? obj.getDateSchedule|date('g:i A') : "now"|date('g:i A') }}" readonly placeholder="Select a time" disabled>
<input type="text" name="date_schedule_time" class="form-control m-input tp" data-default-value="{{ obj.getDateSchedule|default("now")|date('g:i A') }}" value="{{ obj.getDateSchedule|default("now")|date('g:i A') }}" readonly placeholder="Select a time" disabled>
<span class="input-group-addon">
<i class="la la-clock-o glyphicon-th"></i>
</span>
@ -353,7 +353,7 @@
</tr>
{% for outlet in outlets %}
<tr data-id="{{ outlet.outlet.getID }}">
<tr data-id="{{ outlet.outlet.getID }}"{{ obj.getOutlet and obj.getOutlet.getID == outlet.outlet.getID ? ' class="m-table__row--primary"' }}>
<td>{{ outlet.outlet.getName }}</td>
<td>{{ outlet.outlet.getAddress }}</td>
<td>{{ outlet.outlet.getContactNumbers }}</td>
@ -823,7 +823,7 @@ $(function() {
{% if mode == 'update' %}
var selectedOutlet = false;
var selectedOutlet = '{{ obj.getOutlet ? obj.getOutlet.getID : "" }}';
$("#outlets-table tbody tr").click(function() {
var id = $(this).data('id');
@ -841,7 +841,7 @@ $(function() {
$(this).removeClass('m-table__row--primary');
// remove id value
selectedOutlet = false;
selectedOutlet = '';
}
});
{% endif %}