2010-07-04 14:17:15 +04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests\Models\Company;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @Entity
|
|
|
|
* @Table(name="company_contracts")
|
|
|
|
* @InheritanceType("SINGLE_TABLE")
|
|
|
|
* @DiscriminatorColumn(name="discr", type="string")
|
2012-07-30 02:10:33 +04:00
|
|
|
* @EntityListeners({"Doctrine\Tests\Models\Company\ContractSubscriber"})
|
2011-10-15 07:18:57 +04:00
|
|
|
* @DiscriminatorMap({
|
2011-12-20 01:56:19 +04:00
|
|
|
* "fix" = "CompanyFixContract",
|
|
|
|
* "flexible" = "CompanyFlexContract",
|
2011-10-15 07:18:57 +04:00
|
|
|
* "flexultra" = "CompanyFlexUltraContract"
|
|
|
|
* })
|
2012-03-12 04:46:31 +04:00
|
|
|
*
|
|
|
|
* @NamedNativeQueries({
|
|
|
|
* @NamedNativeQuery(
|
|
|
|
* name = "all-contracts",
|
|
|
|
* resultClass = "__CLASS__",
|
|
|
|
* query = "SELECT id, completed, discr FROM company_contracts"
|
|
|
|
* ),
|
|
|
|
* @NamedNativeQuery(
|
|
|
|
* name = "all",
|
|
|
|
* resultClass = "__CLASS__",
|
|
|
|
* query = "SELECT id, completed, discr FROM company_contracts"
|
|
|
|
* ),
|
|
|
|
* })
|
|
|
|
*
|
|
|
|
* @SqlResultSetMappings({
|
|
|
|
* @SqlResultSetMapping(
|
|
|
|
* name = "mapping-all-contracts",
|
|
|
|
* entities= {
|
|
|
|
* @EntityResult(
|
|
|
|
* entityClass = "__CLASS__",
|
|
|
|
* discriminatorColumn = "discr",
|
|
|
|
* fields = {
|
|
|
|
* @FieldResult("id"),
|
|
|
|
* @FieldResult("completed"),
|
|
|
|
* }
|
|
|
|
* )
|
|
|
|
* }
|
|
|
|
* ),
|
|
|
|
* @SqlResultSetMapping(
|
|
|
|
* name = "mapping-all",
|
|
|
|
* entities= {
|
|
|
|
* @EntityResult(
|
|
|
|
* entityClass = "__CLASS__",
|
|
|
|
* discriminatorColumn = "discr",
|
|
|
|
* fields = {
|
|
|
|
* @FieldResult("id"),
|
|
|
|
* @FieldResult("completed"),
|
|
|
|
* }
|
|
|
|
* )
|
|
|
|
* }
|
|
|
|
* ),
|
|
|
|
* })
|
2010-07-04 14:17:15 +04:00
|
|
|
*/
|
|
|
|
abstract class CompanyContract
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @Id @column(type="integer") @GeneratedValue
|
|
|
|
*/
|
|
|
|
private $id;
|
|
|
|
|
|
|
|
/**
|
2011-12-22 23:50:57 +04:00
|
|
|
* @ManyToOne(targetEntity="CompanyEmployee", inversedBy="soldContracts")
|
2010-07-04 14:17:15 +04:00
|
|
|
*/
|
|
|
|
private $salesPerson;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @Column(type="boolean")
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
private $completed = false;
|
|
|
|
|
|
|
|
/**
|
2011-12-22 02:56:17 +04:00
|
|
|
* @ManyToMany(targetEntity="CompanyEmployee", inversedBy="contracts")
|
2010-07-04 14:17:15 +04:00
|
|
|
* @JoinTable(name="company_contract_employees",
|
|
|
|
* joinColumns={@JoinColumn(name="contract_id", referencedColumnName="id", onDelete="CASCADE")},
|
|
|
|
* inverseJoinColumns={@JoinColumn(name="employee_id", referencedColumnName="id")}
|
|
|
|
* )
|
|
|
|
*/
|
|
|
|
private $engineers;
|
|
|
|
|
|
|
|
public function __construct()
|
|
|
|
{
|
|
|
|
$this->engineers = new \Doctrine\Common\Collections\ArrayCollection;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getId()
|
|
|
|
{
|
|
|
|
return $this->id;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function markCompleted()
|
|
|
|
{
|
|
|
|
$this->completed = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function isCompleted()
|
|
|
|
{
|
|
|
|
return $this->completed;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getSalesPerson()
|
|
|
|
{
|
|
|
|
return $this->salesPerson;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setSalesPerson(CompanyEmployee $salesPerson)
|
|
|
|
{
|
|
|
|
$this->salesPerson = $salesPerson;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getEngineers()
|
|
|
|
{
|
|
|
|
return $this->engineers;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function addEngineer(CompanyEmployee $engineer)
|
|
|
|
{
|
|
|
|
$this->engineers[] = $engineer;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function removeEngineer(CompanyEmployee $engineer)
|
|
|
|
{
|
|
|
|
$this->engineers->removeElement($engineer);
|
|
|
|
}
|
|
|
|
|
|
|
|
abstract public function calculatePrice();
|
2011-12-22 02:56:17 +04:00
|
|
|
}
|