Display.php 3.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <?php
  2. /* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
  3. /**
  4. * This action handles output of the form.
  5. *
  6. * PHP versions 4 and 5
  7. *
  8. * LICENSE: This source file is subject to version 3.01 of the PHP license
  9. * that is available through the world-wide-web at the following URI:
  10. * http://www.php.net/license/3_01.txt If you did not receive a copy of
  11. * the PHP License and are unable to obtain it through the web, please
  12. * send a note to license@php.net so we can mail you a copy immediately.
  13. *
  14. * @category HTML
  15. * @package HTML_QuickForm_Controller
  16. * @author Alexey Borzov <avb@php.net>
  17. * @copyright 2003-2009 The PHP Group
  18. * @license http://www.php.net/license/3_01.txt PHP License 3.01
  19. * @version SVN: $Id: Display.php 289084 2009-10-02 06:53:09Z avb $
  20. * @link http://pear.php.net/package/HTML_QuickForm_Controller
  21. */
  22. /**
  23. * Class representing an action to perform on HTTP request.
  24. */
  25. require_once 'HTML/QuickForm/Action.php';
  26. /**
  27. * This action handles output of the form.
  28. *
  29. * If you want to customize the form display, subclass this class and
  30. * override the _renderForm() method, you don't need to change the perform()
  31. * method itself.
  32. *
  33. * @category HTML
  34. * @package HTML_QuickForm_Controller
  35. * @author Alexey Borzov <avb@php.net>
  36. * @version Release: 1.0.10
  37. */
  38. class HTML_QuickForm_Action_Display extends HTML_QuickForm_Action
  39. {
  40. function perform(&$page, $actionName)
  41. {
  42. $pageName = $page->getAttribute('id');
  43. // If the original action was 'display' and we have values in container then we load them
  44. // BTW, if the page was invalid, we should later call validate() to get the errors
  45. list(, $oldName) = $page->controller->getActionName();
  46. if ('display' == $oldName) {
  47. // If the controller is "modal" we should not allow direct access to a page
  48. // unless all previous pages are valid (see also bug #2323)
  49. if ($page->controller->isModal() && !$page->controller->isValid($page->getAttribute('id'))) {
  50. $target =& $page->controller->getPage($page->controller->findInvalid());
  51. // Modified by Chamilo team, 16-MAR-2010.
  52. //$target->handle('jump');
  53. return $target->handle('jump');
  54. //
  55. }
  56. $data =& $page->controller->container();
  57. if (!empty($data['values'][$pageName])) {
  58. $page->loadValues($data['values'][$pageName]);
  59. $validate = false === $data['valid'][$pageName];
  60. }
  61. }
  62. // set "common" defaults and constants
  63. $page->controller->applyDefaults($pageName);
  64. $page->isFormBuilt() or $page->buildForm();
  65. // if we had errors we should show them again
  66. if (isset($validate) && $validate) {
  67. if (PEAR::isError($err = $page->validate())) {
  68. return $err;
  69. }
  70. }
  71. // Modified by Chamilo team, 16-MAR-2010.
  72. //$this->_renderForm($page);
  73. return $this->_renderForm($page);
  74. //
  75. }
  76. /**
  77. * Actually outputs the form.
  78. *
  79. * If you want to customize the form's appearance (you most certainly will),
  80. * then you should override this method. There is no need to override perform()
  81. *
  82. * @access private
  83. * @param HTML_QuickForm_Page the page being processed
  84. */
  85. function _renderForm(&$page)
  86. {
  87. $page->display();
  88. }
  89. }
  90. ?>