<?php
namespace App\Entity\Slave;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\Common\Collections\Collection;
use Doctrine\DBAL\Types\Types;
use Doctrine\ORM\Mapping as ORM;
/**
* @ORM\Table(name="eposm_s_operation_tariff")
* @ORM\Entity(repositoryClass="App\Repository\Slave\OperationTariffRepository")
*/
class OperationTariff
{
public function canDuplicate()
{
return true;
}
public function canDelete()
{
foreach($this->getAmounts() as $ota){
if(sizeof($ota->getTickets()) > 0 || sizeof($ota->getUavTickets()) > 0)
return false;
}
return true;
}
public function displayZips()
{
$string = '';
$first = true;
foreach($this->zips as $arrayZip){
if($first) $first = false; else $string.= ' - ';
$string.= $arrayZip[1];
}
return $string;
}
public function displayFirstThreeZips()
{
$length = sizeof($this->zips);
$string = $this->zips[0][1];
if(sizeof($this->zips) > 1)
$string.=' - '.$this->zips[1][1];
if(sizeof($this->zips) > 2)
$string.=' - '.$this->zips[2][1];
return $string.' ... ';
}
public function displayZipIds()
{
$string = '';
$first = true;
foreach($this->zips as $arrayZip){
if($first) $first = false; else $string.= ' ';
$string.= $arrayZip[0];
}
return $string;
}
public function getStandardAmount()
{
foreach($this->amounts as $amount){
if($amount->isStandard()){
return $amount;
break;
}
}
return null;
}
public function getUavAmount()
{
foreach($this->amounts as $amount){
if($amount->getValue() == 'UAV'){
return $amount;
break;
}
}
return null;
}
/**
* @ORM\Column(name="id", type="bigint")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @ORM\Column(name="is_all_zip", type="boolean")
*/
protected $allZip;
/**
* @ORM\Column(name="id_province", type="bigint")
*/
protected $idProvince;
/**
* @ORM\Column(name="zips", type="array", nullable=true)
*/
protected $zips;
// ManyToOne
/**
* @ORM\ManyToOne(targetEntity="App\Entity\Slave\Operation", inversedBy="tariffs")
* @ORM\JoinColumn(name="operation_id", referencedColumnName="id")
*/
private $operation;
//
// OneToMany
/**
* @ORM\OneToMany(targetEntity="App\Entity\Slave\OperationTariffAmount", mappedBy="tariff", cascade={"persist", "remove"})
*/
private $amounts;
//
public function __construct()
{
$this->amounts = new ArrayCollection();
}
public function getId(): ?string
{
return $this->id;
}
public function isAllZip(): ?bool
{
return $this->allZip;
}
public function setAllZip(bool $allZip): self
{
$this->allZip = $allZip;
return $this;
}
public function getIdProvince(): ?string
{
return $this->idProvince;
}
public function setIdProvince(string $idProvince): self
{
$this->idProvince = $idProvince;
return $this;
}
public function getZips(): array
{
return $this->zips;
}
public function setZips(?array $zips): self
{
$this->zips = $zips;
return $this;
}
public function getOperation(): ?Operation
{
return $this->operation;
}
public function setOperation(?Operation $operation): self
{
$this->operation = $operation;
return $this;
}
/**
* @return Collection<int, OperationTariffAmount>
*/
public function getAmounts(): Collection
{
return $this->amounts;
}
public function addAmount(OperationTariffAmount $amount): self
{
if (!$this->amounts->contains($amount)) {
$this->amounts->add($amount);
$amount->setTariff($this);
}
return $this;
}
public function removeAmount(OperationTariffAmount $amount): self
{
if ($this->amounts->removeElement($amount)) {
// set the owning side to null (unless already changed)
if ($amount->getTariff() === $this) {
$amount->setTariff(null);
}
}
return $this;
}
}