First commit
This commit is contained in:
		
						commit
						c6e2478c40
					
				
					 13918 changed files with 2303184 additions and 0 deletions
				
			
		
							
								
								
									
										214
									
								
								sites/all/modules/civicrm/packages/HTML/QuickForm/Page.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										214
									
								
								sites/all/modules/civicrm/packages/HTML/QuickForm/Page.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,214 @@ | |||
| <?php | ||||
| /* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */ | ||||
| 
 | ||||
| /** | ||||
|  * Class representing a page of a multipage form. | ||||
|  *  | ||||
|  * PHP versions 4 and 5 | ||||
|  * | ||||
|  * LICENSE: This source file is subject to version 3.01 of the PHP license | ||||
|  * that is available through the world-wide-web at the following URI: | ||||
|  * http://www.php.net/license/3_01.txt If you did not receive a copy of | ||||
|  * the PHP License and are unable to obtain it through the web, please | ||||
|  * send a note to license@php.net so we can mail you a copy immediately. | ||||
|  * | ||||
|  * @category    HTML | ||||
|  * @package     HTML_QuickForm_Controller | ||||
|  * @author      Alexey Borzov <avb@php.net> | ||||
|  * @author      Bertrand Mansion <bmansion@mamasam.com> | ||||
|  * @copyright   2003-2007 The PHP Group | ||||
|  * @license     http://www.php.net/license/3_01.txt PHP License 3.01 | ||||
|  * @version     CVS: $Id: Page.php,v 1.7 2007/05/18 09:34:18 avb Exp $ | ||||
|  * @link        http://pear.php.net/package/HTML_QuickForm_Controller | ||||
|  */ | ||||
| 
 | ||||
| /** | ||||
|  * Create, validate and process HTML forms | ||||
|  */ | ||||
| require_once 'HTML/QuickForm.php'; | ||||
| 
 | ||||
| /** | ||||
|  * Class representing a page of a multipage form. | ||||
|  * | ||||
|  * Generally you'll need to subclass this and define your buildForm() | ||||
|  * method that will build the form. While it is also possible to instantiate | ||||
|  * this class and build the form manually, this is not the recommended way. | ||||
|  * | ||||
|  * @category    HTML | ||||
|  * @package     HTML_QuickForm_Controller | ||||
|  * @author      Alexey Borzov <avb@php.net> | ||||
|  * @author      Bertrand Mansion <bmansion@mamasam.com> | ||||
|  * @version     Release: 1.0.9 | ||||
|  */ | ||||
| class HTML_QuickForm_Page extends HTML_QuickForm | ||||
| { | ||||
|    /** | ||||
|     * Contains the mapping of actions to corresponding HTML_QuickForm_Action objects | ||||
|     * @var array | ||||
|     */ | ||||
|     var $_actions = array(); | ||||
| 
 | ||||
|    /** | ||||
|     * Contains a reference to a Controller object containing this page | ||||
|     * @var      HTML_QuickForm_Controller | ||||
|     * @access   public | ||||
|     */ | ||||
|     var $controller = null; | ||||
| 
 | ||||
|    /** | ||||
|     * Should be set to true on first call to buildForm() | ||||
|     * @var bool | ||||
|     */ | ||||
|     var $_formBuilt = false; | ||||
| 
 | ||||
|    /** | ||||
|     * Class constructor | ||||
|     * | ||||
|     * @access public | ||||
|     */ | ||||
|     function __construct($formName, $method = 'post', $target = '', $attributes = null) | ||||
|     { | ||||
|         parent::__construct($formName, $method, '', $target, $attributes); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|    /** | ||||
|     * Registers a handler for a specific action. | ||||
|     * | ||||
|     * @access public | ||||
|     * @param  string                name of the action | ||||
|     * @param  HTML_QuickForm_Action the handler for the action | ||||
|     */ | ||||
|     function addAction($actionName, &$action) | ||||
|     { | ||||
|         $this->_actions[$actionName] =& $action; | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|    /** | ||||
|     * Handles an action. | ||||
|     * | ||||
|     * If an Action object was not registered here, controller's handle() | ||||
|     * method will be called. | ||||
|     * | ||||
|     * @access public | ||||
|     * @param  string Name of the action | ||||
|     * @throws PEAR_Error | ||||
|     */ | ||||
|     function handle($actionName) | ||||
|     { | ||||
|         if (isset($this->_actions[$actionName])) { | ||||
|             return $this->_actions[$actionName]->perform($this, $actionName); | ||||
|         } else { | ||||
|             return $this->controller->handle($this, $actionName); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|    /** | ||||
|     * Returns a name for a submit button that will invoke a specific action. | ||||
|     * | ||||
|     * @access public | ||||
|     * @param  string  Name of the action | ||||
|     * @return string  "name" attribute for a submit button | ||||
|     */ | ||||
|     function getButtonName($actionName, $subActionName = null) | ||||
|     { | ||||
|         if ( $subActionName != null ) { | ||||
|             return '_qf_' . $this->getAttribute('id') . '_' . $actionName . '_' . $subActionName; | ||||
|         } else { | ||||
|             return '_qf_' . $this->getAttribute('id') . '_' . $actionName; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|    /** | ||||
|     * Loads the submit values from the array. | ||||
|     * | ||||
|     * The method is NOT intended for general usage. | ||||
|     * | ||||
|     * @param array  'submit' values | ||||
|     * @access public | ||||
|     */ | ||||
|     function loadValues($values) | ||||
|     { | ||||
|         $this->_flagSubmitted = true; | ||||
|         $this->_submitValues = $values; | ||||
|         foreach (array_keys($this->_elements) as $key) { | ||||
|             $this->_elements[$key]->onQuickFormEvent('updateValue', null, $this); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|    /** | ||||
|     * Builds a form. | ||||
|     * | ||||
|     * You should override this method when you subclass HTML_QuickForm_Page, | ||||
|     * it should contain all the necessary addElement(), applyFilter(), addRule() | ||||
|     * and possibly setDefaults() and setConstants() calls. The method will be | ||||
|     * called on demand, so please be sure to set $_formBuilt property to true to | ||||
|     * assure that the method works only once. | ||||
|     * | ||||
|     * @access public | ||||
|     * @abstract | ||||
|     */ | ||||
|     function buildForm() | ||||
|     { | ||||
|         $this->_formBuilt = true; | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|    /** | ||||
|     * Checks whether the form was already built. | ||||
|     * | ||||
|     * @access public | ||||
|     * @return bool | ||||
|     */ | ||||
|     function isFormBuilt() | ||||
|     { | ||||
|         return $this->_formBuilt; | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|    /** | ||||
|     * Sets the default action invoked on page-form submit | ||||
|     * | ||||
|     * This is necessary as the user may just press Enter instead of | ||||
|     * clicking one of the named submit buttons and then no action name will | ||||
|     * be passed to the script. | ||||
|     * | ||||
|     * @access public | ||||
|     * @param  string    default action name | ||||
|     */ | ||||
|     function setDefaultAction($actionName) | ||||
|     { | ||||
|         if ($this->elementExists('_qf_default')) { | ||||
|             $element =& $this->getElement('_qf_default'); | ||||
|             $element->setValue($this->getAttribute('id') . ':' . $actionName); | ||||
|         } else { | ||||
|             $this->addElement('hidden', '_qf_default', $this->getAttribute('id') . ':' . $actionName); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|    /** | ||||
|     * Returns 'safe' elements' values | ||||
|     * | ||||
|     * @param   mixed   Array/string of element names, whose values we want. If not set then return all elements. | ||||
|     * @param   bool    Whether to remove internal (_qf_...) values from the resultant array | ||||
|     */ | ||||
|     function exportValues($elementList = null, $filterInternal = false) | ||||
|     { | ||||
|         $values = parent::exportValues($elementList); | ||||
|         if ($filterInternal) { | ||||
|             foreach (array_keys($values) as $key) { | ||||
|                 if (0 === strpos($key, '_qf_')) { | ||||
|                     unset($values[$key]); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return $values; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| ?>
 | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue