home *** CD-ROM | disk | FTP | other *** search
- <?php
- /**
- * The renderer that creates an array of visible menu entries.
- *
- * PHP versions 4 and 5
- *
- * LICENSE: This source file is subject to version 3.01 of the PHP license
- * that is available through the world-wide-web at the following URI:
- * http://www.php.net/license/3_01.txt If you did not receive a copy of
- * the PHP License and are unable to obtain it through the web, please
- * send a note to license@php.net so we can mail you a copy immediately.
- *
- * @category HTML
- * @package HTML_Menu
- * @author Alexey Borzov <avb@php.net>
- * @copyright 2001-2007 The PHP Group
- * @license http://www.php.net/license/3_01.txt PHP License 3.01
- * @version CVS: $Id: ArrayRenderer.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 creates an array of visible menu entries.
- *
- * The resultant array can be used with e.g. a template engine to produce
- * a completely custom menu look.
- * All menu types except 'rows' are "rendered" into a one-dimensional array
- * of entries:
- * <pre>
- * array(
- * 'entry1',
- * ...
- * 'entryN'
- * )
- * </pre>
- * while 'rows' produce a two-dimensional array:
- * <pre>
- * array(
- * array('entry 1 for row 1', ..., 'entry M_1 for row 1'),
- * ...
- * array('entry 1 for row N', ..., 'entry M_N for row 1')
- * )
- * </pre>
- * Here entry is
- * <pre>
- * array(
- * 'url' => url element of menu entry
- * 'title' => title element of menu entry
- * 'level' => entry's depth in the tree structure
- * 'type' => type of entry, one of HTML_MENU_ENTRY_* constants
- * // if the nodes in the original menu array contained keys other
- * // than 'url', 'title' and 'sub', they will be copied here, too
- * )
- * </pre>
- *
- * @category HTML
- * @package HTML_Menu
- * @author Alexey Borzov <avb@php.net>
- * @version Release: 2.1.4
- */
- class HTML_Menu_ArrayRenderer extends HTML_Menu_Renderer
- {
- /**
- * Generated array
- * @var array
- * @access private
- */
- var $_ary = array();
-
- /**
- * Array for the current "menu", that is moved into $_ary by finishMenu(),
- * makes sense mostly for 'rows
- * @var array
- * @access private
- */
- var $_menuAry = array();
-
- function finishMenu($level)
- {
- if ('rows' == $this->_menuType) {
- $this->_ary[] = $this->_menuAry;
- } else {
- $this->_ary = $this->_menuAry;
- }
- $this->_menuAry = array();
- }
-
-
- function renderEntry($node, $level, $type)
- {
- unset($node['sub']);
- $node['level'] = $level;
- $node['type'] = $type;
- $this->_menuAry[] = $node;
- }
-
-
- /**
- * Returns the resultant array
- *
- * @access public
- * @return array
- */
- function toArray()
- {
- return $this->_ary;
- }
- }
- ?>
-