* @copyright 2001-2007 VIKO team and contributors * @license http://www.gnu.org/licenses/gpl.html GPL 2.0 */ /** * This class needs to create some HTML */ require_once "HTML.php"; /** * Parent class of all VIKO modules * * @abstract */ class Module { /** * Page title * * @access private * @var string */ var $_title = null; /** * Default constructor for the conveniance of subclasses * * @param array $parameters parameters to the module */ function Module_ChangePassword( $parameters ) { // nothing should be done in here } /** * Returns the module identifier string * * Must be implemented inside subclass * * @access public * @static * @abstract * @return string Identificator of module */ function getID() { trigger_error("getID not implemeneted", E_USER_ERROR); } /** * Returns text to be displayd on browser title bar * * @access public * @return string title */ function getTitle() { // To ensure, that every page has a title set, crash VIKO if it isn't if ( !isset( $this->_title ) ) { trigger_error( "Page title not defined.", E_USER_ERROR ); } return $this->_title; } /** * Sets contents of page title and returns h2 heading * * Usually the title and h2 heading on a page are exactly the same. * This method should be used to create both of them simultaneously. * * This method sets the string $title to be returned by Module::getTitle() * and also returns h2 heading element containing the value of $title. * * Sometimes you need to include some HTML inside the h2 heading, but * the title element may not contain other elements. This is easy to * overcome by using strip_tags() on the contents of title element, * and that's exactly what this method does. So you should use this * method even if the heading has to contain other HTML elements. * * @access protected * @param string $title contents of heading and title * @return string h2 heading */ function title( $title ) { $this->_title = strip_tags( $title ); return HTML::h2( $title ); } /** * Creates heading and body for general error message page * * It's almost the same as HTML::errorPage(), only difference, that * this method uses $this->title() instead of HTML::h2() to create * the heading, meaning, that this method also sets the title of * the page. * * This method should be used instead of HTML::errorPage() in all * subclasses of Module. * * @param string $error_message descriptive text about the error * @return string */ function errorPage( $error_message ) { return $this->title( _( "Error!" ) ) . HTML::error( $error_message ); } /** * Creates heading and body of access denied type of error page * * It's almost the same as HTML::accessDeniedPage(), only difference, * that this method uses $this->title() instead of HTML::h2() to * create the heading, meaning, that this method also sets the title * of the page. * * This method should be used instead of HTML::accessDeniedPage() in * all subclasses of Module. * * @param string $error_message descriptive text about the error * @return string */ function accessDeniedPage( $error_message ) { return $this->title( _( "Access denied!" ) ) . HTML::error( $error_message ); } /** * Returns array containing module-specific stylesheets * * This method may be implemented in modules, that need to have * their special stylesheet in addition to default VIKO stylesheet. * * Each stylesheet is represented as an associative array * with a following structure: * *
     * array(
     *     'uri'   => '/css/my-styles.css',
     *     'media' => 'all',       # the default
     *     'rel'   => 'stylesheet' # the default
     * )
     * 
* * Only the uri is required, the others are optional. * * @access public * @return array list of stylesheets */ function getStylesheets() { return array(); } /** * Returns Module in HTML * * Requires implementation in subclasses. * * @return string HTML fragment */ function toHTML() { trigger_error("Unimplemented", E_USER_ERROR); } } ?>