2010-07-04 12:17:15 +02:00
|
|
|
<?php
|
|
|
|
namespace Doctrine\Tests\Models\Company;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @Entity
|
2012-03-11 21:46:31 -03:00
|
|
|
*
|
|
|
|
* @NamedNativeQueries({
|
|
|
|
* @NamedNativeQuery(
|
|
|
|
* name = "all",
|
|
|
|
* resultClass = "__CLASS__",
|
|
|
|
* query = "SELECT id, hoursWorked, discr FROM company_contracts"
|
|
|
|
* ),
|
|
|
|
* @NamedNativeQuery(
|
|
|
|
* name = "all-flex",
|
|
|
|
* resultClass = "CompanyFlexContract",
|
|
|
|
* query = "SELECT id, hoursWorked, discr FROM company_contracts"
|
|
|
|
* ),
|
|
|
|
* })
|
|
|
|
*
|
|
|
|
* @SqlResultSetMappings({
|
|
|
|
* @SqlResultSetMapping(
|
|
|
|
* name = "mapping-all-flex",
|
|
|
|
* entities= {
|
|
|
|
* @EntityResult(
|
|
|
|
* entityClass = "__CLASS__",
|
|
|
|
* discriminatorColumn = "discr",
|
|
|
|
* fields = {
|
|
|
|
* @FieldResult("id"),
|
|
|
|
* @FieldResult("hoursWorked"),
|
|
|
|
* }
|
|
|
|
* )
|
|
|
|
* }
|
|
|
|
* ),
|
|
|
|
* @SqlResultSetMapping(
|
|
|
|
* name = "mapping-all",
|
|
|
|
* entities= {
|
|
|
|
* @EntityResult(
|
|
|
|
* entityClass = "CompanyFlexContract",
|
|
|
|
* discriminatorColumn = "discr",
|
|
|
|
* fields = {
|
|
|
|
* @FieldResult("id"),
|
|
|
|
* @FieldResult("hoursWorked"),
|
|
|
|
* }
|
|
|
|
* )
|
|
|
|
* }
|
|
|
|
* ),
|
|
|
|
* })
|
2010-07-04 12:17:15 +02:00
|
|
|
*/
|
|
|
|
class CompanyFlexContract extends CompanyContract
|
|
|
|
{
|
|
|
|
/**
|
2010-09-27 23:22:52 +02:00
|
|
|
* @column(type="integer")
|
2010-07-04 12:17:15 +02:00
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
private $hoursWorked = 0;
|
|
|
|
|
|
|
|
/**
|
2010-09-27 23:22:52 +02:00
|
|
|
* @column(type="integer")
|
2010-07-04 12:17:15 +02:00
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
private $pricePerHour = 0;
|
|
|
|
|
2011-12-21 23:56:17 +01:00
|
|
|
/**
|
2011-12-22 00:19:35 +01:00
|
|
|
* @ManyToMany(targetEntity="CompanyManager", inversedBy="managedContracts", fetch="EXTRA_LAZY")
|
2011-12-21 23:56:17 +01:00
|
|
|
* @JoinTable(name="company_contract_managers",
|
|
|
|
* joinColumns={@JoinColumn(name="contract_id", referencedColumnName="id", onDelete="CASCADE")},
|
|
|
|
* inverseJoinColumns={@JoinColumn(name="employee_id", referencedColumnName="id")}
|
|
|
|
* )
|
|
|
|
*/
|
2011-12-22 00:19:35 +01:00
|
|
|
public $managers;
|
2011-12-21 23:56:17 +01:00
|
|
|
|
2010-07-04 12:17:15 +02:00
|
|
|
public function calculatePrice()
|
|
|
|
{
|
|
|
|
return $this->hoursWorked * $this->pricePerHour;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getHoursWorked()
|
|
|
|
{
|
|
|
|
return $this->hoursWorked;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setHoursWorked($hoursWorked)
|
|
|
|
{
|
|
|
|
$this->hoursWorked = $hoursWorked;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getPricePerHour()
|
|
|
|
{
|
|
|
|
return $this->pricePerHour;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setPricePerHour($pricePerHour)
|
|
|
|
{
|
|
|
|
$this->pricePerHour = $pricePerHour;
|
|
|
|
}
|
2011-12-21 23:56:17 +01:00
|
|
|
public function getManagers()
|
|
|
|
{
|
|
|
|
return $this->managers;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function addManager(CompanyManager $manager)
|
|
|
|
{
|
|
|
|
$this->managers[] = $manager;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function removeManager(CompanyManager $manager)
|
|
|
|
{
|
|
|
|
$this->managers->removeElement($manager);
|
|
|
|
}
|
2012-08-07 21:31:01 -03:00
|
|
|
|
|
|
|
static public function loadMetadata(\Doctrine\ORM\Mapping\ClassMetadataInfo $metadata)
|
|
|
|
{
|
|
|
|
$metadata->mapField(array(
|
|
|
|
'type' => 'integer',
|
|
|
|
'name' => 'hoursWorked',
|
|
|
|
'fieldName' => 'hoursWorked',
|
|
|
|
));
|
|
|
|
|
|
|
|
$metadata->mapField(array(
|
|
|
|
'type' => 'integer',
|
|
|
|
'name' => 'pricePerHour',
|
|
|
|
'fieldName' => 'pricePerHour',
|
|
|
|
));
|
|
|
|
}
|
2011-12-21 23:56:17 +01:00
|
|
|
}
|