mirror of
https://gitlab.com/Chill-Projet/chill-bundles.git
synced 2025-06-07 18:44:08 +00:00
313 lines
5.4 KiB
PHP
313 lines
5.4 KiB
PHP
<?php
|
|
|
|
/*
|
|
* Chill is a software for social workers
|
|
*
|
|
* Copyright (C) 2014, Champs Libres Cooperative SCRLFS, <http://www.champs-libres.coop>
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
* License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
namespace Chill\CustomFieldsBundle\Entity;
|
|
|
|
use Doctrine\ORM\Mapping as ORM;
|
|
|
|
/**
|
|
* CustomField
|
|
*
|
|
* @ORM\Entity()
|
|
* @ORM\Table(name="customfield")
|
|
* @ORM\HasLifecycleCallbacks()
|
|
*/
|
|
class CustomField
|
|
{
|
|
/**
|
|
* @var integer
|
|
*
|
|
* @ORM\Id
|
|
* @ORM\Column(name="id", type="integer")
|
|
* @ORM\GeneratedValue(strategy="AUTO")
|
|
*/
|
|
private $id;
|
|
|
|
/**
|
|
* @var string
|
|
*
|
|
* @ORM\Column(type="string", length=255)
|
|
*/
|
|
private $slug;
|
|
|
|
/**
|
|
* @var string
|
|
*
|
|
* @ORM\Column(type="string", length=255)
|
|
*/
|
|
private $type;
|
|
|
|
/**
|
|
* @var boolean
|
|
*
|
|
* @ORM\Column(type="boolean")
|
|
*/
|
|
private $active = true;
|
|
|
|
/**
|
|
* @var array
|
|
*
|
|
* @ORM\Column(type="json")
|
|
*/
|
|
private $options = array();
|
|
|
|
/**
|
|
* @var array
|
|
*
|
|
* @ORM\Column(type="json")
|
|
*/
|
|
private $name;
|
|
|
|
/**
|
|
* @var float
|
|
*
|
|
* @ORM\Column(type="float")
|
|
*/
|
|
private $ordering;
|
|
|
|
/**
|
|
* @var boolean
|
|
*
|
|
* @ORM\Column(type="boolean")
|
|
*/
|
|
private $required = FALSE;
|
|
|
|
const ONE_TO_ONE = 1;
|
|
const ONE_TO_MANY = 2;
|
|
|
|
/**
|
|
* @var CustomFieldsGroup
|
|
*
|
|
* @ORM\ManyToOne(
|
|
* targetEntity="Chill\CustomFieldsBundle\Entity\CustomFieldsGroup",
|
|
* inversedBy="customFields")
|
|
*/
|
|
private $customFieldGroup;
|
|
|
|
|
|
/**
|
|
* Get id
|
|
*
|
|
* @return integer
|
|
*/
|
|
public function getId()
|
|
{
|
|
return $this->id;
|
|
}
|
|
|
|
/**
|
|
* @return string
|
|
*/
|
|
function getSlug()
|
|
{
|
|
return $this->slug;
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
function getOptions()
|
|
{
|
|
return $this->options;
|
|
}
|
|
|
|
/**
|
|
* Set type
|
|
*
|
|
* @param string $type
|
|
* @return CustomField
|
|
*/
|
|
public function setType($type)
|
|
{
|
|
$this->type = $type;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get type
|
|
*
|
|
* @return string
|
|
*/
|
|
public function getType()
|
|
{
|
|
return $this->type;
|
|
}
|
|
|
|
|
|
/**
|
|
* Set active
|
|
*
|
|
* @param boolean $active
|
|
* @return CustomField
|
|
*/
|
|
public function setActive($active)
|
|
{
|
|
$this->active = $active;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Returns true if the custom field is active
|
|
*
|
|
* @return boolean
|
|
*/
|
|
public function isActive()
|
|
{
|
|
return $this->active;
|
|
}
|
|
|
|
/**
|
|
* Get customFieldGroup
|
|
*
|
|
* @return CustomFieldsGroup
|
|
*/
|
|
public function getCustomFieldsGroup()
|
|
{
|
|
return $this->customFieldGroup;
|
|
}
|
|
|
|
/**
|
|
* Set customFieldGroup
|
|
*
|
|
* @param CustomFieldsGroup $customFieldGroup
|
|
* @return CustomField
|
|
*/
|
|
public function setCustomFieldsGroup(CustomFieldsGroup $customFieldGroup = null)
|
|
{
|
|
$this->customFieldGroup = $customFieldGroup;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Set name
|
|
*
|
|
* @param array $name
|
|
* @return CustomField
|
|
*/
|
|
public function setName($name)
|
|
{
|
|
$this->name = $name;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get name
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getName($locale = null)
|
|
{
|
|
if ($locale) {
|
|
if (isset($this->name[$locale])) {
|
|
return $this->name[$locale];
|
|
} else {
|
|
foreach ($this->name as $name) {
|
|
if (!empty($name)) {
|
|
return $name;
|
|
}
|
|
}
|
|
}
|
|
|
|
return '';
|
|
|
|
} else {
|
|
return $this->name;
|
|
};
|
|
}
|
|
|
|
/**
|
|
* Set order
|
|
*
|
|
* @param float $order
|
|
* @return CustomField
|
|
*/
|
|
public function setOrdering($order)
|
|
{
|
|
$this->ordering = $order;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get order
|
|
*
|
|
* @return float
|
|
*/
|
|
public function getOrdering()
|
|
{
|
|
return $this->ordering;
|
|
}
|
|
|
|
/**
|
|
* Set options
|
|
*
|
|
* @param array $options
|
|
* @return CustomField
|
|
*/
|
|
public function setOptions(array $options)
|
|
{
|
|
$this->options = $options;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* @param $slug
|
|
* @return $this
|
|
*/
|
|
public function setSlug($slug)
|
|
{
|
|
$this->slug = $slug;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* alias for isRequired
|
|
*
|
|
* @return boolean
|
|
*/
|
|
public function getRequired()
|
|
{
|
|
return $this->isRequired();
|
|
}
|
|
|
|
/**
|
|
* return true if the field required
|
|
*
|
|
* @return boolean
|
|
*/
|
|
public function isRequired()
|
|
{
|
|
return $this->required;
|
|
}
|
|
|
|
public function setRequired($required)
|
|
{
|
|
$this->required = $required;
|
|
return $this;
|
|
}
|
|
|
|
}
|