* @copyright 2003-2007 The PHP Group * @license http://www.php.net/license/3_01.txt PHP License 3.01 * @version CVS: $Id$ * @link http://pear.php.net/package/HTML_QuickForm_Controller */ /** * Class representing an action to perform on HTTP request. */ require_once 'HTML/QuickForm/Action.php'; /** * This action handles output of the form. * * If you want to customize the form display, subclass this class and * override the _renderForm() method, you don't need to change the perform() * method itself. * * @category HTML * @package HTML_QuickForm_Controller * @author Alexey Borzov * @version Release: 1.0.9 */ class HTML_QuickForm_Action_Display extends HTML_QuickForm_Action { function perform(&$page, $actionName) { $pageName = $page->getAttribute('id'); // If the original action was 'display' and we have values in container then we load them // BTW, if the page was invalid, we should later call validate() to get the errors list(, $oldName) = $page->controller->getActionName(); if ('display' == $oldName) { // If the controller is "modal" we should not allow direct access to a page // unless all previous pages are valid (see also bug #2323) if ($page->controller->isModal() && !$page->controller->isValid($page->getAttribute('id'))) { $target =& $page->controller->getPage($page->controller->findInvalid()); return $target->handle('jump'); } $data =& $page->controller->container(); if (!empty($data['values'][$pageName])) { $page->loadValues($data['values'][$pageName]); $validate = false === $data['valid'][$pageName]; } } // set "common" defaults and constants $page->controller->applyDefaults($pageName); $page->isFormBuilt() or $page->buildForm(); // if we had errors we should show them again if (isset($validate) && $validate) { if (PEAR::isError($err = $page->validate())) { return $err; } } return $this->_renderForm($page); } /** * Actually outputs the form. * * If you want to customize the form's appearance (you most certainly will), * then you should override this method. There is no need to override perform() * * @access private * @param HTML_QuickForm_Page the page being processed */ function _renderForm(&$page) { $page->display(); } } ?>