| // +----------------------------------------------------------------------+ // // $Id$ require_once 'HTML/QuickForm/Action.php'; /** * The action handles the HTTP redirect to a specific page. * * @author Alexey Borzov * @package HTML_QuickForm_Controller * @version $Revision: 1.4 $ */ class HTML_QuickForm_Action_Jump extends HTML_QuickForm_Action { function perform(&$page, $actionName) { // check whether the page is valid before trying to go to it if ($page->controller->isModal()) { // we check whether *all* pages up to current are valid // if there is an invalid page we go to it, instead of the // requested one $pageName = $page->getAttribute('id'); if (!$page->controller->isValid($pageName)) { $pageName = $page->controller->findInvalid(); } $current =& $page->controller->getPage($pageName); } else { $current =& $page; } // generate the URL for the page 'display' event and redirect to it $action = $current->getAttribute('action'); $url = $action . (false === strpos($action, '?')? '?': '&') . $current->getButtonName('display') . '=true' . ((!defined('SID') || '' == SID || ini_get('session.use_only_cookies'))? '': '&' . SID); header('Location: ' . $url); exit; } } ?>