* @copyright 2001-2007 The PHP Group * @license http://www.php.net/license/3_01.txt PHP License 3.01 * @version CVS: $Id: SigmaRenderer.php,v 1.3 2007/05/18 20:54:33 avb Exp $ * @link http://pear.php.net/package/HTML_Menu */ /** * Abstract base class for HTML_Menu renderers */ require_once 'HTML/Menu/Renderer.php'; /** * The renderer that uses HTML_Template_Sigma instance for menu output. * * @category HTML * @package HTML_Menu * @author Alexey Borzov * @version Release: 2.1.4 */ class HTML_Menu_SigmaRenderer extends HTML_Menu_Renderer { /**#@+ * @access private */ /** * Template object used for output * @var HTML_Template_Sigma */ var $_tpl; /** * Mapping from HTML_MENU_ENTRY_* constants to template block names * @var array */ var $_typeNames = array( HTML_MENU_ENTRY_INACTIVE => 'inactive', HTML_MENU_ENTRY_ACTIVE => 'active', HTML_MENU_ENTRY_ACTIVEPATH => 'activepath', HTML_MENU_ENTRY_PREVIOUS => 'previous', HTML_MENU_ENTRY_NEXT => 'next', HTML_MENU_ENTRY_UPPER => 'upper', HTML_MENU_ENTRY_BREADCRUMB => 'breadcrumb' ); /** * Prefix for template blocks and placeholders * @var string */ var $_prefix; /**#@-*/ /** * Class constructor. * * Sets the template object to use and sets prefix for template blocks * and placeholders. We use prefix to avoid name collisions with existing * template blocks and it is customisable to allow output of several menus * into one template. * * @access public * @param HTML_Template_Sigma template object to use for output * @param string prefix for template blocks and placeholders */ function HTML_Menu_SigmaRenderer(&$tpl, $prefix = 'mu_') { $this->_tpl =& $tpl; $this->_prefix = $prefix; } function finishMenu($level) { if ('rows' == $this->_menuType && $this->_tpl->blockExists($this->_prefix . ($level + 1) . '_menu_loop')) { $this->_tpl->parse($this->_prefix . ($level + 1) . '_menu_loop'); } elseif ($this->_tpl->blockExists($this->_prefix . 'menu_loop')) { $this->_tpl->parse($this->_prefix . 'menu_loop'); } } function finishRow($level) { if ('rows' == $this->_menuType && $this->_tpl->blockExists($this->_prefix . ($level + 1) . '_row_loop')) { $this->_tpl->parse($this->_prefix . ($level + 1) . '_row_loop'); } elseif ($this->_tpl->blockExists($this->_prefix . 'row_loop')) { $this->_tpl->parse($this->_prefix . 'row_loop'); } } function renderEntry($node, $level, $type) { if (in_array($this->_menuType, array('tree', 'sitemap', 'rows')) && $this->_tpl->blockExists($this->_prefix . ($level + 1) . '_' . $this->_typeNames[$type])) { $blockName = $this->_prefix . ($level + 1) . '_' . $this->_typeNames[$type]; } else { $blockName = $this->_prefix . $this->_typeNames[$type]; } if (('tree' == $this->_menuType || 'sitemap' == $this->_menuType) && $this->_tpl->blockExists($blockName . '_indent')) { for ($i = 0; $i < $level; $i++) { $this->_tpl->touchBlock($blockName . '_indent'); $this->_tpl->parse($blockName . '_indent'); } } foreach ($node as $k => $v) { if ('sub' != $k && $this->_tpl->placeholderExists($this->_prefix . $k, $blockName)) { $this->_tpl->setVariable($this->_prefix . $k, $v); } } $this->_tpl->parse($blockName); if ('rows' == $this->_menuType && $this->_tpl->blockExists($this->_prefix . ($level + 1) . '_entry_loop')) { $this->_tpl->parse($this->_prefix . ($level + 1) . '_entry_loop'); } else { $this->_tpl->parse($this->_prefix . 'entry_loop'); } } } ?>