111 lines
2.6 KiB
PHP
111 lines
2.6 KiB
PHP
<?php
|
|
|
|
namespace App\Entity;
|
|
|
|
use Doctrine\ORM\Mapping as ORM;
|
|
use Doctrine\Common\Collections\ArrayCollection;
|
|
use Symfony\Component\Validator\Constraints as Assert;
|
|
|
|
use DateTime;
|
|
|
|
/**
|
|
* @ORM\Entity
|
|
* @ORM\Table(name="job_order")
|
|
*/
|
|
class JobOrder
|
|
{
|
|
// unique id
|
|
/**
|
|
* @ORM\Id
|
|
* @ORM\Column(type="integer")
|
|
* @ORM\GeneratedValue(strategy="AUTO")
|
|
*/
|
|
protected $id;
|
|
|
|
// date job order was created
|
|
/**
|
|
* @ORM\Column(type="datetime")
|
|
*/
|
|
protected $date_create;
|
|
|
|
// date and time of schedule
|
|
// defaults to current date / time
|
|
/**
|
|
* @ORM\Column(type="datetime")
|
|
*/
|
|
protected $date_schedule;
|
|
|
|
// date that the job order was fulfilled / delivered
|
|
/**
|
|
* @ORM\Column(type="datetime", nullable=true)
|
|
*/
|
|
protected $date_fulfill;
|
|
|
|
// coordinates of the customer vehicle that needs service
|
|
/**
|
|
* @ORM\Column(type="point")
|
|
*/
|
|
protected $coordinates;
|
|
|
|
// is it an advanced order (future date)
|
|
/**
|
|
* @ORM\Column(type="boolean")
|
|
*/
|
|
protected $flag_advance;
|
|
|
|
// user that created the job order
|
|
/**
|
|
* @ORM\ManyToOne(targetEntity="User", inversedBy="job_orders")
|
|
* @ORM\JoinColumn(name="user_id", referencedColumnName="id")
|
|
*/
|
|
protected $created_by;
|
|
|
|
// service type
|
|
/**
|
|
* @ORM\Column(type="string", length=12)
|
|
*/
|
|
protected $service_type;
|
|
|
|
// customer that requested job order
|
|
/**
|
|
* @ORM\ManyToOne(targetEntity="Customer", inversedBy="job_orders")
|
|
* @ORM\JoinColumn(name="customer_id", referencedColumnName="id")
|
|
*/
|
|
protected $customer;
|
|
|
|
// customer vehicle that needs servicing
|
|
/**
|
|
* @ORM\ManyToOne(targetEntity="CustomerVehicle", inversedBy="job_orders")
|
|
* @ORM\JoinColumn(name="cvehicle_id", referencedColumnName="id")
|
|
*/
|
|
protected $cus_vehicle;
|
|
|
|
// assigned outlet
|
|
/**
|
|
* @ORM\ManyToOne(targetEntity="Outlet", inversedBy="job_orders")
|
|
* @ORM\JoinColumn(name="outlet_id", referencedColumnName="id")
|
|
*/
|
|
protected $outlet;
|
|
|
|
// assigned rider
|
|
/**
|
|
* @ORM\ManyToOne(targetEntity="Rider", inversedBy="job_orders")
|
|
* @ORM\JoinColumn(name="rider_id", referencedColumnName="id")
|
|
*/
|
|
protected $rider;
|
|
|
|
// where requested job order came from (mobile or web)
|
|
/**
|
|
* @ORM\Column(type="string", length=10)
|
|
*/
|
|
protected $source;
|
|
|
|
public function __construct()
|
|
{
|
|
$this->date_create = new DateTime();
|
|
$this->date_schedule = new DateTime();
|
|
|
|
$this->flag_advance = false;
|
|
$this->source = 'mobile';
|
|
}
|
|
}
|