| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @copyright NetMonsters <team@netmonsters.ru> | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  |  * @link http://netmonsters.ru | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |  * @package Majestic | 
					
						
							|  |  |  |  * @subpackage form | 
					
						
							|  |  |  |  * @since 2010-04-25 | 
					
						
							|  |  |  |  * @version SVN: $Id$ | 
					
						
							|  |  |  |  * @filesource $URL$ | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class FormField | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @var iValidator[] | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     protected $validators = array(); | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @var iFilter[] | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     protected $filters = array(); | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Used instead message of validator if defined. | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |      * @var string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected $default_message = false; | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @var string | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     protected $message = false; | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @var mixed | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     protected $value; | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     /* Flags */ | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @var bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     protected $required = true; | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @var bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     protected $ignored = false; | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param bool|string $default_message | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function __construct($default_message = false) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->default_message = $default_message; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param bool $flag | 
					
						
							|  |  |  |      * @return FormField | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function setRequired($flag) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->required = (bool) $flag; | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function isRequired() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->required; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param bool $flag | 
					
						
							|  |  |  |      * @return FormField | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function setIgnored($flag) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->ignored = (bool) $flag; | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function isIgnored() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->ignored; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string[]|iValidator[] $validators | 
					
						
							|  |  |  |      * @return FormField | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function addValidators($validators) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         foreach ($validators as $validator) { | 
					
						
							|  |  |  |             $this->addValidator($validator); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param string|iValidator $validator | 
					
						
							|  |  |  |      * @return FormField | 
					
						
							|  |  |  |      * @throws InitializationException | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function addValidator($validator) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if ($validator instanceof iValidator) { | 
					
						
							|  |  |  |             $name = get_class($validator); | 
					
						
							|  |  |  |         } elseif (is_string($validator)) { | 
					
						
							|  |  |  |             $name = $validator . 'Validator'; | 
					
						
							|  |  |  |             $validator = new $name(); | 
					
						
							|  |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2011-11-25 13:54:31 +04:00
										 |  |  |             throw new InitializationException('Invalid validator provided to addValidator; must be string or iValidator'); | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |         $this->validators[$name] = $validator; | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function addFilters($filters) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         foreach ($filters as $filter) { | 
					
						
							|  |  |  |             $this->addFilter($filter); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function addFilter($filter) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  |         if ($filter instanceof iFilter) { | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |             $name = get_class($filter); | 
					
						
							|  |  |  |         } elseif (is_string($filter)) { | 
					
						
							|  |  |  |             $name = $filter . 'Filter'; | 
					
						
							|  |  |  |             $filter = new $name(); | 
					
						
							|  |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2011-11-25 13:54:31 +04:00
										 |  |  |             throw new InitializationException('Invalid filter provided to addFilter; must be string or iFilter'); | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |         $this->filters[$name] = $filter; | 
					
						
							|  |  |  |         return $this; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function getValue() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $value = $this->value; | 
					
						
							|  |  |  |         if (is_array($value)) { | 
					
						
							|  |  |  |             array_walk_recursive($value, array($this, 'filterValue')); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             $this->filterValue($value, $value); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $value; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * $value & $key for array_walk_recursive | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |      * @param mixed $value | 
					
						
							|  |  |  |      * @param mixed $key | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected function filterValue(&$value, &$key) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         foreach ($this->filters as $filter) { | 
					
						
							|  |  |  |             $value = $filter->filter($value); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function getSourceValue() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->value; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function isValid($value, $context = null) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $this->value = $value; | 
					
						
							|  |  |  |         // filtered value here
 | 
					
						
							|  |  |  |         $value = $this->getValue(); | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |         $valid = true; | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |         if ((($value === '') || ($value === null)) && !$this->isRequired()) { | 
					
						
							|  |  |  |             return $valid; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |         foreach ($this->validators as $validator) { | 
					
						
							|  |  |  |             if (is_array($value)) { | 
					
						
							|  |  |  |                 foreach ($value as $val) { | 
					
						
							|  |  |  |                     if (!$validator->isValid($val, $context)) { | 
					
						
							|  |  |  |                         $valid = false; | 
					
						
							|  |  |  |                         if (!$this->default_message) { | 
					
						
							| 
									
										
										
										
											2011-11-25 13:54:31 +04:00
										 |  |  |                             throw new InitializationException('Define default message for array fields'); | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |                         } | 
					
						
							|  |  |  |                         $this->message = $this->default_message; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 if ($valid) { | 
					
						
							|  |  |  |                     continue; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } elseif ($validator->isValid($value, $context)) { | 
					
						
							|  |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |             $valid = false; | 
					
						
							|  |  |  |             $this->message = ($this->default_message) ? $this->default_message : $validator->getMessage(); | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return $valid; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2012-11-19 19:20:15 +04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-26 19:56:01 +00:00
										 |  |  |     public function getMessage() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return $this->message; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |