233 lines
		
	
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			233 lines
		
	
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Static Factory class for HTML_QuickForm2 package
 | |
|  *
 | |
|  * PHP version 5
 | |
|  *
 | |
|  * LICENSE:
 | |
|  *
 | |
|  * Copyright (c) 2006-2010, Alexey Borzov <avb@php.net>,
 | |
|  *                          Bertrand Mansion <golgote@mamasam.com>
 | |
|  * All rights reserved.
 | |
|  *
 | |
|  * Redistribution and use in source and binary forms, with or without
 | |
|  * modification, are permitted provided that the following conditions
 | |
|  * are met:
 | |
|  *
 | |
|  *    * Redistributions of source code must retain the above copyright
 | |
|  *      notice, this list of conditions and the following disclaimer.
 | |
|  *    * Redistributions in binary form must reproduce the above copyright
 | |
|  *      notice, this list of conditions and the following disclaimer in the
 | |
|  *      documentation and/or other materials provided with the distribution.
 | |
|  *    * The names of the authors may not be used to endorse or promote products
 | |
|  *      derived from this software without specific prior written permission.
 | |
|  *
 | |
|  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
 | |
|  * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
 | |
|  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 | |
|  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
 | |
|  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 | |
|  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 | |
|  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 | |
|  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
 | |
|  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
 | |
|  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 | |
|  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 | |
|  *
 | |
|  * @category   HTML
 | |
|  * @package    HTML_QuickForm2
 | |
|  * @author     Alexey Borzov <avb@php.net>
 | |
|  * @author     Bertrand Mansion <golgote@mamasam.com>
 | |
|  * @license    http://opensource.org/licenses/bsd-license.php New BSD License
 | |
|  * @version    SVN: $Id: Factory.php 299305 2010-05-12 20:15:28Z avb $
 | |
|  * @link       http://pear.php.net/package/HTML_QuickForm2
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * Class with static methods for loading classes and files
 | |
|  */
 | |
| // require_once 'HTML/QuickForm2/Loader.php';
 | |
| 
 | |
| /**
 | |
|  * Static factory class
 | |
|  *
 | |
|  * The class handles instantiation of Element and Rule objects as well as
 | |
|  * registering of new Element and Rule classes.
 | |
|  *
 | |
|  * @category   HTML
 | |
|  * @package    HTML_QuickForm2
 | |
|  * @author     Alexey Borzov <avb@php.net>
 | |
|  * @author     Bertrand Mansion <golgote@mamasam.com>
 | |
|  * @version    Release: @package_version@
 | |
|  */
 | |
| class HTML_QuickForm2_Factory
 | |
| {
 | |
|    /**
 | |
|     * List of element types known to Factory
 | |
|     * @var array
 | |
|     */
 | |
|     protected static $elementTypes = array(
 | |
|         'button'        => array('HTML_QuickForm2_Element_Button', null),
 | |
|         'checkbox'      => array('HTML_QuickForm2_Element_InputCheckbox', null),
 | |
|         'date'          => array('HTML_QuickForm2_Element_Date', null),
 | |
|         'fieldset'      => array('HTML_QuickForm2_Container_Fieldset', null),
 | |
|         'group'         => array('HTML_QuickForm2_Container_Group', null),
 | |
|         'file'          => array('HTML_QuickForm2_Element_InputFile', null),
 | |
|         'hidden'        => array('HTML_QuickForm2_Element_InputHidden', null),
 | |
|         'image'         => array('HTML_QuickForm2_Element_InputImage', null),
 | |
|         'inputbutton'   => array('HTML_QuickForm2_Element_InputButton', null),
 | |
|         'password'      => array('HTML_QuickForm2_Element_InputPassword', null),
 | |
|         'radio'         => array('HTML_QuickForm2_Element_InputRadio', null),
 | |
|         'reset'         => array('HTML_QuickForm2_Element_InputReset', null),
 | |
|         'select'        => array('HTML_QuickForm2_Element_Select', null),
 | |
|         'submit'        => array('HTML_QuickForm2_Element_InputSubmit', null),
 | |
|         'text'          => array('HTML_QuickForm2_Element_InputText', null),
 | |
|         'textarea'      => array('HTML_QuickForm2_Element_Textarea', null)
 | |
|     );
 | |
| 
 | |
|    /**
 | |
|     * List of registered rules
 | |
|     * @var array
 | |
|     */
 | |
|     protected static $registeredRules = array(
 | |
|         'nonempty'      => array('HTML_QuickForm2_Rule_Nonempty', null),
 | |
|         'empty'         => array('HTML_QuickForm2_Rule_Empty', null),
 | |
|         'required'      => array('HTML_QuickForm2_Rule_Required', null),
 | |
|         'compare'       => array('HTML_QuickForm2_Rule_Compare', null),
 | |
|         'eq'            => array('HTML_QuickForm2_Rule_Compare', null,
 | |
|                                  array('operator' => '===')),
 | |
|         'neq'           => array('HTML_QuickForm2_Rule_Compare', null,
 | |
|                                  array('operator' => '!==')),
 | |
|         'lt'            => array('HTML_QuickForm2_Rule_Compare', null,
 | |
|                                  array('operator' => '<')),
 | |
|         'lte'           => array('HTML_QuickForm2_Rule_Compare', null,
 | |
|                                  array('operator' => '<=')),
 | |
|         'gt'            => array('HTML_QuickForm2_Rule_Compare', null,
 | |
|                                  array('operator' => '>')),
 | |
|         'gte'           => array('HTML_QuickForm2_Rule_Compare', null,
 | |
|                                  array('operator' => '>=')),
 | |
|         'regex'         => array('HTML_QuickForm2_Rule_Regex', null),
 | |
|         'callback'      => array('HTML_QuickForm2_Rule_Callback', null),
 | |
|         'length'        => array('HTML_QuickForm2_Rule_Length', null),
 | |
|         'minlength'     => array('HTML_QuickForm2_Rule_Length', null,
 | |
|                                  array('max' => 0)),
 | |
|         'maxlength'     => array('HTML_QuickForm2_Rule_Length', null,
 | |
|                                  array('min' => 0)),
 | |
|         'maxfilesize'   => array('HTML_QuickForm2_Rule_MaxFileSize', null),
 | |
|         'mimetype'      => array('HTML_QuickForm2_Rule_MimeType', null),
 | |
|         'each'          => array('HTML_QuickForm2_Rule_Each', null),
 | |
|         'notcallback'   => array('HTML_QuickForm2_Rule_NotCallback', null),
 | |
|         'notregex'      => array('HTML_QuickForm2_Rule_NotRegex', null)
 | |
|     );
 | |
| 
 | |
| 
 | |
|    /**
 | |
|     * Registers a new element type
 | |
|     *
 | |
|     * @param    string  Type name (treated case-insensitively)
 | |
|     * @param    string  Class name
 | |
|     * @param    string  File containing the class, leave empty if class already loaded
 | |
|     */
 | |
|     public static function registerElement($type, $className, $includeFile = null)
 | |
|     {
 | |
|         self::$elementTypes[strtolower($type)] = array($className, $includeFile);
 | |
|     }
 | |
| 
 | |
| 
 | |
|    /**
 | |
|     * Checks whether an element type is known to factory
 | |
|     *
 | |
|     * @param    string  Type name (treated case-insensitively)
 | |
|     * @return   bool
 | |
|     */
 | |
|     public static function isElementRegistered($type)
 | |
|     {
 | |
|         return isset(self::$elementTypes[strtolower($type)]);
 | |
|     }
 | |
| 
 | |
| 
 | |
|    /**
 | |
|     * Creates a new element object of the given type
 | |
|     *
 | |
|     * @param    string  Type name (treated case-insensitively)
 | |
|     * @param    mixed   Element name (passed to element's constructor)
 | |
|     * @param    mixed   Element attributes (passed to element's constructor)
 | |
|     * @param    array   Element-specific data (passed to element's constructor)
 | |
|     * @return   HTML_QuickForm2_Node     A created element
 | |
|     * @throws   HTML_QuickForm2_InvalidArgumentException If type name is unknown
 | |
|     * @throws   HTML_QuickForm2_NotFoundException If class for the element can
 | |
|     *           not be found and/or loaded from file
 | |
|     */
 | |
|     public static function createElement($type, $name = null, $attributes = null,
 | |
|                                          array $data = array())
 | |
|     {
 | |
|         $type = strtolower($type);
 | |
|         if (!isset(self::$elementTypes[$type])) {
 | |
|             throw new HTML_QuickForm2_InvalidArgumentException("Element type '$type' is not known");
 | |
|         }
 | |
|         list($className, $includeFile) = self::$elementTypes[$type];
 | |
|         if (!class_exists($className)) {
 | |
|             HTML_QuickForm2_Loader::loadClass($className, $includeFile);
 | |
|         }
 | |
|         return new $className($name, $attributes, $data);
 | |
|     }
 | |
| 
 | |
| 
 | |
|    /**
 | |
|     * Registers a new rule type
 | |
|     *
 | |
|     * @param    string  Rule type name (treated case-insensitively)
 | |
|     * @param    string  Class name
 | |
|     * @param    string  File containing the class, leave empty if class already loaded
 | |
|     * @param    mixed   Configuration data for rules of the given type
 | |
|     */
 | |
|     public static function registerRule($type, $className, $includeFile = null,
 | |
|                                         $config = null)
 | |
|     {
 | |
|         self::$registeredRules[strtolower($type)] = array($className, $includeFile, $config);
 | |
|     }
 | |
| 
 | |
| 
 | |
|    /**
 | |
|     * Checks whether a rule type is known to Factory
 | |
|     *
 | |
|     * @param    string  Rule type name (treated case-insensitively)
 | |
|     * @return   bool
 | |
|     */
 | |
|     public static function isRuleRegistered($type)
 | |
|     {
 | |
|         return isset(self::$registeredRules[strtolower($type)]);
 | |
|     }
 | |
| 
 | |
| 
 | |
|    /**
 | |
|     * Creates a new Rule of the given type
 | |
|     *
 | |
|     * @param    string                  Rule type name (treated case-insensitively)
 | |
|     * @param    HTML_QuickForm2_Node    Element to validate by the rule
 | |
|     * @param    string                  Message to display if validation fails
 | |
|     * @param    mixed                   Configuration data for the rule
 | |
|     * @return   HTML_QuickForm2_Rule    A created Rule
 | |
|     * @throws   HTML_QuickForm2_InvalidArgumentException If rule type is unknown
 | |
|     * @throws   HTML_QuickForm2_NotFoundException        If class for the rule
 | |
|     *           can't be found and/or loaded from file
 | |
|     */
 | |
|     public static function createRule($type, HTML_QuickForm2_Node $owner,
 | |
|                                       $message = '', $config = null)
 | |
|     {
 | |
|         $type = strtolower($type);
 | |
|         if (!isset(self::$registeredRules[$type])) {
 | |
|             throw new HTML_QuickForm2_InvalidArgumentException("Rule '$type' is not known");
 | |
|         }
 | |
|         list($className, $includeFile) = self::$registeredRules[$type];
 | |
|         if (!class_exists($className)) {
 | |
|             HTML_QuickForm2_Loader::loadClass($className, $includeFile);
 | |
|         }
 | |
|         if (isset(self::$registeredRules[$type][2])) {
 | |
|             $config = call_user_func(array($className, 'mergeConfig'), $config,
 | |
|                                      self::$registeredRules[$type][2]);
 | |
|         }
 | |
|         return new $className($owner, $message, $config);
 | |
|     }
 | |
| }
 | |
| ?>
 |