home *** CD-ROM | disk | FTP | other *** search
/ Cricao de Sites - 650 Layouts Prontos / WebMasters.iso / Servidores / xampp-win32-1.6.7-installer.exe / php / PEAR / HTML / QuickForm / Action / Next.php < prev    next >
Encoding:
PHP Script  |  2008-07-02  |  2.6 KB  |  74 lines

  1. <?php
  2. /* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
  3.  
  4. /**
  5.  * The action for a 'next' button of wizard-type multipage form.
  6.  * 
  7.  * PHP versions 4 and 5
  8.  *
  9.  * LICENSE: This source file is subject to version 3.01 of the PHP license
  10.  * that is available through the world-wide-web at the following URI:
  11.  * http://www.php.net/license/3_01.txt If you did not receive a copy of
  12.  * the PHP License and are unable to obtain it through the web, please
  13.  * send a note to license@php.net so we can mail you a copy immediately.
  14.  *
  15.  * @category    HTML
  16.  * @package     HTML_QuickForm_Controller
  17.  * @author      Alexey Borzov <avb@php.net>
  18.  * @copyright   2003-2007 The PHP Group
  19.  * @license     http://www.php.net/license/3_01.txt PHP License 3.01
  20.  * @version     CVS: $Id: Next.php,v 1.6 2007/05/18 09:34:18 avb Exp $
  21.  * @link        http://pear.php.net/package/HTML_QuickForm_Controller
  22.  */
  23.  
  24. /**
  25.  * Class representing an action to perform on HTTP request.
  26.  */
  27. require_once 'HTML/QuickForm/Action.php';
  28.  
  29. /**
  30.  * The action for a 'next' button of wizard-type multipage form.
  31.  *
  32.  * @category    HTML
  33.  * @package     HTML_QuickForm_Controller
  34.  * @author      Alexey Borzov <avb@php.net>
  35.  * @version     Release: 1.0.8
  36.  */
  37. class HTML_QuickForm_Action_Next extends HTML_QuickForm_Action
  38. {
  39.     function perform(&$page, $actionName)
  40.     {
  41.         // save the form values and validation status to the session
  42.         $page->isFormBuilt() or $page->buildForm();
  43.         $pageName =  $page->getAttribute('id');
  44.         $data     =& $page->controller->container();
  45.         $data['values'][$pageName] = $page->exportValues();
  46.         if (PEAR::isError($valid = $page->validate())) {
  47.             return $valid;
  48.         }
  49.         $data['valid'][$pageName] = $valid;
  50.  
  51.         // Modal form and page is invalid: don't go further
  52.         if ($page->controller->isModal() && !$data['valid'][$pageName]) {
  53.             return $page->handle('display');
  54.         }
  55.         // More pages?
  56.         if (null !== ($nextName = $page->controller->getNextName($pageName))) {
  57.             $next =& $page->controller->getPage($nextName);
  58.             return $next->handle('jump');
  59.         // Consider this a 'finish' button, if there is no explicit one
  60.         } elseif($page->controller->isModal()) {
  61.             if ($page->controller->isValid()) {
  62.                 return $page->handle('process');
  63.             } else {
  64.                 // this should redirect to the first invalid page
  65.                 return $page->handle('jump');
  66.             }
  67.         } else {
  68.             return $page->handle('display');
  69.         }
  70.     }
  71. }
  72.  
  73. ?>
  74.