* @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'; /** * The action for a 'next' button of wizard-type multipage form. * * @category HTML * @package HTML_QuickForm_Controller * @author Alexey Borzov * @version Release: 1.0.9 */ class HTML_QuickForm_Action_Next extends HTML_QuickForm_Action { function perform(&$page, $actionName) { // save the form values and validation status to the session $page->isFormBuilt() or $page->buildForm(); $pageName = $page->getAttribute('id'); $data =& $page->controller->container(); $data['values'][$pageName] = $page->exportValues(); if (PEAR::isError($valid = $page->validate())) { return $valid; } $data['valid'][$pageName] = $valid; // Modal form and page is invalid: don't go further if ($page->controller->isModal() && !$data['valid'][$pageName]) { return $page->handle('display'); } // More pages? if (null !== ($nextName = $page->controller->getNextName($pageName))) { $next =& $page->controller->getPage($nextName); return $next->handle('jump'); // Consider this a 'finish' button, if there is no explicit one } elseif($page->controller->isModal()) { if ($page->controller->isValid()) { return $page->handle('process'); } else { // this should redirect to the first invalid page return $page->handle('jump'); } } else { return $page->handle('display'); } } } ?>