2013-10-01 13:26:39 +03:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* LiveStreet CMS
|
|
|
|
* Copyright © 2013 OOO "ЛС-СОФТ"
|
|
|
|
*
|
|
|
|
* ------------------------------------------------------
|
|
|
|
*
|
|
|
|
* Official site: www.livestreetcms.com
|
|
|
|
* Contact e-mail: office@livestreetcms.com
|
|
|
|
*
|
|
|
|
* GNU General Public License, version 2:
|
|
|
|
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
|
|
|
*
|
|
|
|
* ------------------------------------------------------
|
|
|
|
*
|
|
|
|
* @link http://www.livestreetcms.com
|
|
|
|
* @copyright 2013 OOO "ЛС-СОФТ"
|
|
|
|
* @author Maxim Mzhelskiy <rus.engine@gmail.com>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
class ModuleProperty_EntityProperty extends EntityORM {
|
|
|
|
|
|
|
|
protected $aValidateRules=array(
|
2014-01-24 08:41:48 +02:00
|
|
|
array('type','check_type','on'=>array('create','auto')),
|
|
|
|
array('code','regexp','allowEmpty'=>false,'pattern'=>'#^[a-z0-9\_]+$#i','on'=>array('create','update','auto')),
|
|
|
|
array('title','string','allowEmpty'=>false,'min'=>1,'max'=>250,'on'=>array('create','update','auto')),
|
|
|
|
array('description','string','allowEmpty'=>true,'max'=>500,'on'=>array('update','auto')),
|
|
|
|
array('sort','number','allowEmpty'=>false,'integerOnly'=>true,'min'=>0,'on'=>array('auto')),
|
|
|
|
array('validate_rules_raw','check_validate_rules_raw','on'=>array('create','update','auto')),
|
|
|
|
array('params_raw','check_params_raw','on'=>array('update','auto')),
|
|
|
|
array('code','check_code','on'=>array('create','update','auto')),
|
|
|
|
array('title','check_title','on'=>array('create','update','auto')),
|
|
|
|
array('description','check_description','on'=>array('update','auto')),
|
2013-10-01 13:26:39 +03:00
|
|
|
);
|
|
|
|
|
|
|
|
protected $aRelations=array(
|
2013-10-29 09:53:26 +02:00
|
|
|
'selects' => array(self::RELATION_TYPE_HAS_MANY,'ModuleProperty_EntitySelect','property_id',array('#order'=>array('sort'=>'desc'))),
|
2013-10-01 13:26:39 +03:00
|
|
|
);
|
|
|
|
|
|
|
|
public function ValidateCheckType() {
|
|
|
|
if ($this->Property_IsAllowPropertyType($this->getType())) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return 'Неверный тип поля';
|
|
|
|
}
|
|
|
|
|
2014-01-24 08:41:48 +02:00
|
|
|
public function ValidateCheckCode() {
|
|
|
|
if ($oProperty=$this->Property_GetPropertyByTargetTypeAndCode($this->getTargetType(),$this->getCode())) {
|
|
|
|
if ($this->getId()!=$oProperty->getId()) {
|
|
|
|
return 'Код поля должен быть уникальным';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-10-01 13:26:39 +03:00
|
|
|
public function ValidateCheckTitle() {
|
|
|
|
$this->setTitle(htmlspecialchars($this->getTitle()));
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2014-01-13 08:50:04 +02:00
|
|
|
public function ValidateCheckDescription() {
|
|
|
|
$this->setDescription(htmlspecialchars($this->getDescription()));
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-10-01 13:26:39 +03:00
|
|
|
public function ValidateCheckValidateRulesRaw() {
|
|
|
|
$aRulesRaw=$this->getValidateRulesRaw();
|
|
|
|
/**
|
|
|
|
* Валидация зависит от типа
|
|
|
|
*/
|
|
|
|
$oValue=Engine::GetEntity('ModuleProperty_EntityValue',array('property_type'=>$this->getType(),'property_id'=>$this->getId(),'target_type'=>$this->getTargetType(),'target_id'=>$this->getId()));
|
|
|
|
$oValueType=$oValue->getValueTypeObject();
|
|
|
|
$aRules=$oValueType->prepareValidateRulesRaw($aRulesRaw);
|
|
|
|
$this->setValidateRules($aRules);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function ValidateCheckParamsRaw() {
|
|
|
|
$aParamsRaw=$this->getParamsRaw();
|
|
|
|
/**
|
|
|
|
* Валидация зависит от типа
|
|
|
|
*/
|
|
|
|
$oValue=Engine::GetEntity('ModuleProperty_EntityValue',array('property_type'=>$this->getType(),'property_id'=>$this->getId(),'target_type'=>$this->getTargetType(),'target_id'=>$this->getId()));
|
|
|
|
$oValueType=$oValue->getValueTypeObject();
|
|
|
|
$aParams=$oValueType->prepareParamsRaw($aParamsRaw);
|
|
|
|
$this->setParams($aParams);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2014-02-11 08:44:52 +02:00
|
|
|
/**
|
|
|
|
* Выполняется перед сохранением сущности
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-10-01 13:26:39 +03:00
|
|
|
protected function beforeSave() {
|
2014-06-15 18:24:11 +03:00
|
|
|
if ($bResult=parent::beforeSave()) {
|
|
|
|
if ($this->_isNew()) {
|
|
|
|
$this->setDateCreate(date("Y-m-d H:i:s"));
|
2014-02-11 08:44:52 +02:00
|
|
|
|
2014-06-15 18:24:11 +03:00
|
|
|
$oValue=Engine::GetEntity('ModuleProperty_EntityValue',array('property_type'=>$this->getType(),'property_id'=>$this->getId(),'target_type'=>$this->getTargetType(),'target_id'=>$this->getId()));
|
|
|
|
$oValueType=$oValue->getValueTypeObject();
|
|
|
|
/**
|
|
|
|
* Выставляем дефолтные значения параметров
|
|
|
|
*/
|
|
|
|
$this->setParams($oValueType->getParamsDefault());
|
|
|
|
/**
|
|
|
|
* Выставляем дефолтные значения параметров валидации
|
|
|
|
*/
|
|
|
|
$this->setValidateRules($oValueType->getValidateRulesDefault());
|
|
|
|
}
|
2013-10-01 13:26:39 +03:00
|
|
|
}
|
2014-06-15 18:24:11 +03:00
|
|
|
return $bResult;
|
2013-10-01 13:26:39 +03:00
|
|
|
}
|
2014-02-06 09:32:50 +02:00
|
|
|
/**
|
|
|
|
* Выполняется перед удалением сущности
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
protected function beforeDelete() {
|
2014-06-15 18:24:11 +03:00
|
|
|
if ($bResult=parent::beforeDelete()) {
|
|
|
|
/**
|
|
|
|
* Сначала удаляем стандартные значения
|
|
|
|
*/
|
|
|
|
$this->Property_RemoveValueByPropertyId($this->getId());
|
|
|
|
/**
|
|
|
|
* Удаляем значения тегов
|
|
|
|
*/
|
|
|
|
$this->Property_RemoveValueTagByPropertyId($this->getId());
|
|
|
|
/**
|
|
|
|
* Удаляем значения селектов
|
|
|
|
*/
|
|
|
|
$this->Property_RemoveValueSelectByPropertyId($this->getId());
|
|
|
|
/**
|
|
|
|
* Удаляем сами варианты селектов
|
|
|
|
*/
|
|
|
|
$this->Property_RemoveSelectByPropertyId($this->getId());
|
|
|
|
}
|
|
|
|
return $bResult;
|
2014-02-06 09:32:50 +02:00
|
|
|
}
|
2013-10-01 13:26:39 +03:00
|
|
|
/**
|
|
|
|
* Возвращает правила валидации поля
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getValidateRules() {
|
|
|
|
$aData=@unserialize($this->_getDataOne('validate_rules'));
|
|
|
|
if (!$aData) {
|
|
|
|
$aData=array();
|
|
|
|
}
|
|
|
|
return $aData;
|
|
|
|
}
|
2014-02-11 08:44:52 +02:00
|
|
|
/**
|
|
|
|
* Возвращает экранированный список правил валидации
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getValidateRulesEscape() {
|
|
|
|
$aRules=$this->getValidateRules();
|
|
|
|
func_htmlspecialchars($aRules);
|
|
|
|
return $aRules;
|
|
|
|
}
|
2013-10-29 09:53:26 +02:00
|
|
|
/**
|
|
|
|
* Возвращает конкретное правило валидации
|
|
|
|
*
|
|
|
|
* @param string $sRule
|
|
|
|
*
|
|
|
|
* @return null|mixed
|
|
|
|
*/
|
|
|
|
public function getValidateRuleOne($sRule) {
|
|
|
|
$aData=$this->getValidateRules();
|
|
|
|
if (isset($aData[$sRule])) {
|
|
|
|
return $aData[$sRule];
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
2013-10-01 13:26:39 +03:00
|
|
|
/**
|
|
|
|
* Устанавливает правила валидации поля
|
|
|
|
*
|
|
|
|
* @param array $aRules
|
|
|
|
*/
|
|
|
|
public function setValidateRules($aRules) {
|
|
|
|
$this->_aData['validate_rules']=@serialize($aRules);
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Возвращает список дополнительных параметров поля
|
|
|
|
*
|
|
|
|
* @return array|mixed
|
|
|
|
*/
|
|
|
|
public function getParams() {
|
|
|
|
$aData=@unserialize($this->_getDataOne('params'));
|
|
|
|
if (!$aData) {
|
|
|
|
$aData=array();
|
|
|
|
}
|
|
|
|
return $aData;
|
|
|
|
}
|
2014-02-11 08:44:52 +02:00
|
|
|
/**
|
|
|
|
* Возвращает экранированный список параметров
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getParamsEscape() {
|
|
|
|
$aParams=$this->getParams();
|
|
|
|
func_htmlspecialchars($aParams);
|
|
|
|
return $aParams;
|
|
|
|
}
|
2013-10-01 13:26:39 +03:00
|
|
|
/**
|
|
|
|
* Устанавливает список дополнительных параметров поля
|
|
|
|
*
|
|
|
|
* @param $aParams
|
|
|
|
*/
|
|
|
|
public function setParams($aParams) {
|
|
|
|
$this->_aData['params']=@serialize($aParams);
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Возвращает конкретный параметр поля
|
|
|
|
*
|
|
|
|
* @param $sName
|
|
|
|
*
|
|
|
|
* @return null
|
|
|
|
*/
|
|
|
|
public function getParam($sName) {
|
|
|
|
$aParams=$this->getParams();
|
|
|
|
return isset($aParams[$sName]) ? $aParams[$sName] : null;
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Возвращает URL админки для редактирования поля
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getUrlAdminUpdate() {
|
|
|
|
return Router::GetPath('admin/properties/'.$this->getTargetType().'/update/'.$this->getId());
|
|
|
|
}
|
2014-01-08 13:15:46 +02:00
|
|
|
/**
|
|
|
|
* Возвращает URL админки для редактирования поля
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getUrlAdminRemove() {
|
|
|
|
return Router::GetPath('admin/properties/'.$this->getTargetType().'/remove/'.$this->getId());
|
|
|
|
}
|
2013-10-01 13:26:39 +03:00
|
|
|
/**
|
|
|
|
* Возвращает описание типа поля
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function getTypeTitle() {
|
|
|
|
/**
|
|
|
|
* TODO: использовать текстовку из языкового
|
|
|
|
*/
|
|
|
|
return $this->getType();
|
|
|
|
}
|
2014-04-01 15:43:38 +03:00
|
|
|
|
|
|
|
public function getSaveFileDir($sPostfix='') {
|
|
|
|
$sPostfix=trim($sPostfix,'/');
|
|
|
|
return Config::Get('path.uploads.base').'/property/'.$this->getTargetType().'/'.$this->getType().'/'.date('Y/m/d/H/').($sPostfix ? "{$sPostfix}/" : '');
|
|
|
|
}
|
|
|
|
|
2013-10-01 13:26:39 +03:00
|
|
|
}
|