, * Bertrand Mansion * 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 * @author Bertrand Mansion * @license http://opensource.org/licenses/bsd-license.php New BSD License * @version SVN: $Id: QuickForm2.php 299706 2010-05-24 18:32:37Z avb $ * @link http://pear.php.net/package/HTML_QuickForm2 */ /** * Abstract base class for QuickForm2 containers */ // require_once 'HTML/QuickForm2/Container.php'; /** * Data source for HTML_QuickForm2 objects based on superglobal arrays */ // require_once 'HTML/QuickForm2/DataSource/SuperGlobal.php'; /** * Class representing a HTML form * * @category HTML * @package HTML_QuickForm2 * @author Alexey Borzov * @author Bertrand Mansion * @version Release: @package_version@ */ class HTML_QuickForm2 extends HTML_QuickForm2_Container { /** * Data sources providing values for form elements * @var array */ protected $datasources = array(); /** * We do not allow setting "method" and "id" other than through constructor * @var array */ protected $watchedAttributes = array('id', 'method'); /** * Class constructor, form's "id" and "method" attributes can only be set here * * @param string "id" attribute of
tag * @param string HTTP method used to submit the form * @param mixed Additional attributes (either a string or an array) * @param bool Whether to track if the form was submitted by adding * a special hidden field */ public function __construct($id, $method = 'post', $attributes = null, $trackSubmit = true) { $method = ('GET' == strtoupper($method))? 'get': 'post'; if (empty($id)) { $id = self::generateId(''); $trackSubmit = false; } else { self::storeId($id); } $this->attributes = array_merge( self::prepareAttributes($attributes), array('id' => (string)$id, 'method' => $method) ); if (!isset($this->attributes['action'])) { $this->attributes['action'] = $_SERVER['PHP_SELF']; } if ($trackSubmit && isset($_REQUEST['_qf__' . $id]) || !$trackSubmit && ('get' == $method && !empty($_GET) || 'post' == $method && (!empty($_POST) || !empty($_FILES)))) { $this->addDataSource(new HTML_QuickForm2_DataSource_SuperGlobal( $method, get_magic_quotes_gpc() )); } if ($trackSubmit) { $this->appendChild(HTML_QuickForm2_Factory::createElement( 'hidden', '_qf__' . $id )); } } protected function onAttributeChange($name, $value = null) { throw new HTML_QuickForm2_InvalidArgumentException( 'Attribute \'' . $name . '\' is read-only' ); } protected function setContainer(HTML_QuickForm2_Container $container = null) { throw new HTML_QuickForm2_Exception('Form cannot be added to container'); } public function setId($id = null) { throw new HTML_QuickForm2_InvalidArgumentException( "Attribute 'id' is read-only" ); } /** * Adds a new data source to the form * * @param HTML_QuickForm2_DataSource Data source */ public function addDataSource(HTML_QuickForm2_DataSource $datasource) { $this->datasources[] = $datasource; $this->updateValue(); } /** * Replaces the list of form's data sources with a completely new one * * @param array A new data source list * @throws HTML_QuickForm2_InvalidArgumentException if given array * contains something that is not a valid data source */ public function setDataSources(array $datasources) { foreach ($datasources as $ds) { if (!$ds instanceof HTML_QuickForm2_DataSource) { throw new HTML_QuickForm2_InvalidArgumentException( 'Array should contain only DataSource instances' ); } } $this->datasources = $datasources; $this->updateValue(); } /** * Returns the list of data sources attached to the form * * @return array */ public function getDataSources() { return $this->datasources; } public function getType() { return 'form'; } public function setValue($value) { throw new HTML_QuickForm2_Exception('Not implemented'); } /** * Performs the server-side validation * * @return boolean Whether all form's elements are valid */ public function validate() { $isSubmitted = false; foreach ($this->datasources as $ds) { if ($ds instanceof HTML_QuickForm2_DataSource_Submit) { $isSubmitted = true; break; } } return $isSubmitted? parent::validate(): false; } /** * Renders the form using the given renderer * * @param HTML_QuickForm2_Renderer Renderer instance * @return HTML_QuickForm2_Renderer */ public function render(HTML_QuickForm2_Renderer $renderer) { $renderer->startForm($this); $renderer->getJavascriptBuilder()->startForm($this); foreach ($this as $element) { $element->render($renderer); } $renderer->finishForm($this); return $renderer; } } ?>