chrisbryan17's picture
Upload folder using huggingface_hub
d2897cd verified
raw
history blame contribute delete
7.53 kB
<?php
namespace Mautic\PointBundle\Entity;
use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\ORM\Mapping as ORM;
use Mautic\ApiBundle\Serializer\Driver\ApiMetadataDriver;
use Mautic\CoreBundle\Doctrine\Mapping\ClassMetadataBuilder;
use Mautic\CoreBundle\Entity\FormEntity;
use Symfony\Component\Validator\Constraints as Assert;
use Symfony\Component\Validator\Mapping\ClassMetadata;
class Trigger extends FormEntity
{
/**
* @var int
*/
private $id;
/**
* @var string
*/
private $name;
/**
* @var string|null
*/
private $description;
/**
* @var \DateTimeInterface
*/
private $publishUp;
/**
* @var \DateTimeInterface
*/
private $publishDown;
/**
* @var int
*/
private $points = 0;
/**
* @var string
*/
private $color = 'a0acb8';
/**
* @var bool
*/
private $triggerExistingLeads = false;
/**
* @var \Mautic\CategoryBundle\Entity\Category|null
**/
private $category;
/**
* @var ArrayCollection<int, \Mautic\PointBundle\Entity\TriggerEvent>
*/
private $events;
private ?Group $group = null;
public function __clone()
{
$this->id = null;
parent::__clone();
}
public function __construct()
{
$this->events = new ArrayCollection();
}
public static function loadMetadata(ORM\ClassMetadata $metadata): void
{
$builder = new ClassMetadataBuilder($metadata);
$builder->setTable('point_triggers')
->setCustomRepositoryClass(TriggerRepository::class);
$builder->addIdColumns();
$builder->addPublishDates();
$builder->addField('points', 'integer');
$builder->createField('color', 'string')
->length(7)
->build();
$builder->createField('triggerExistingLeads', 'boolean')
->columnName('trigger_existing_leads')
->build();
$builder->addCategory();
$builder->createOneToMany('events', 'TriggerEvent')
->setIndexBy('id')
->setOrderBy(['order' => 'ASC'])
->mappedBy('trigger')
->cascadeAll()
->fetchExtraLazy()
->build();
$builder->createManyToOne('group', Group::class)
->addJoinColumn('group_id', 'id', true, false, 'CASCADE')
->build();
}
public static function loadValidatorMetadata(ClassMetadata $metadata): void
{
$metadata->addPropertyConstraint('name', new Assert\NotBlank([
'message' => 'mautic.core.name.required',
]));
}
/**
* Prepares the metadata for API usage.
*/
public static function loadApiMetadata(ApiMetadataDriver $metadata): void
{
$metadata->setGroupPrefix('trigger')
->addListProperties(
[
'id',
'name',
'category',
'description',
]
)
->addProperties(
[
'publishUp',
'publishDown',
'points',
'color',
'events',
'triggerExistingLeads',
]
)
->build();
}
/**
* @param string $prop
* @param mixed $val
*/
protected function isChanged($prop, $val)
{
if ('events' == $prop) {
// changes are already computed so just add them
$this->changes[$prop][$val[0]] = $val[1];
} else {
parent::isChanged($prop, $val);
}
}
/**
* Get id.
*
* @return int
*/
public function getId()
{
return $this->id;
}
/**
* Set description.
*
* @param string $description
*
* @return Trigger
*/
public function setDescription($description)
{
$this->isChanged('description', $description);
$this->description = $description;
return $this;
}
/**
* Get description.
*
* @return string
*/
public function getDescription()
{
return $this->description;
}
/**
* Set name.
*
* @param string $name
*
* @return Trigger
*/
public function setName($name)
{
$this->isChanged('name', $name);
$this->name = $name;
return $this;
}
/**
* Get name.
*
* @return string
*/
public function getName()
{
return $this->name;
}
/**
* Add events.
*
* @return Point
*/
public function addTriggerEvent($key, TriggerEvent $event)
{
if ($changes = $event->getChanges()) {
$this->isChanged('events', [$key, $changes]);
}
$this->events[$key] = $event;
return $this;
}
/**
* Remove events.
*/
public function removeTriggerEvent(TriggerEvent $event): void
{
$this->events->removeElement($event);
}
/**
* Get events.
*
* @return \Doctrine\Common\Collections\Collection
*/
public function getEvents()
{
return $this->events;
}
/**
* Set publishUp.
*
* @param \DateTime $publishUp
*
* @return Point
*/
public function setPublishUp($publishUp)
{
$this->isChanged('publishUp', $publishUp);
$this->publishUp = $publishUp;
return $this;
}
/**
* Get publishUp.
*
* @return \DateTimeInterface
*/
public function getPublishUp()
{
return $this->publishUp;
}
/**
* Set publishDown.
*
* @param \DateTime $publishDown
*
* @return Point
*/
public function setPublishDown($publishDown)
{
$this->isChanged('publishDown', $publishDown);
$this->publishDown = $publishDown;
return $this;
}
/**
* Get publishDown.
*
* @return \DateTimeInterface
*/
public function getPublishDown()
{
return $this->publishDown;
}
/**
* @return mixed
*/
public function getPoints()
{
return $this->points;
}
/**
* @param mixed $points
*/
public function setPoints($points): void
{
$this->isChanged('points', $points);
$this->points = $points;
}
/**
* @return mixed
*/
public function getColor()
{
return $this->color;
}
/**
* @param mixed $color
*/
public function setColor($color): void
{
$this->color = $color;
}
/**
* @return mixed
*/
public function getTriggerExistingLeads()
{
return $this->triggerExistingLeads;
}
/**
* @param mixed $triggerExistingLeads
*/
public function setTriggerExistingLeads($triggerExistingLeads): void
{
$this->triggerExistingLeads = $triggerExistingLeads;
}
/**
* @return mixed
*/
public function getCategory()
{
return $this->category;
}
/**
* @param mixed $category
*/
public function setCategory($category): void
{
$this->category = $category;
}
public function getGroup(): ?Group
{
return $this->group;
}
public function setGroup(Group $group): void
{
$this->group = $group;
}
}