|
TYPO3 API
SVNRelease
|
00001 <?php 00002 /*************************************************************** 00003 * Copyright notice 00004 * 00005 * (c) 2010-2011 TYPO3 Tree Team <http://forge.typo3.org/projects/typo3v4-extjstrees> 00006 * All rights reserved 00007 * 00008 * This script is part of the TYPO3 project. The TYPO3 project is 00009 * free software; you can redistribute it and/or modify 00010 * it under the terms of the GNU General Public License as published by 00011 * the Free Software Foundation; either version 2 of the License, or 00012 * (at your option) any later version. 00013 * 00014 * The GNU General Public License can be found at 00015 * http://www.gnu.org/copyleft/gpl.html. 00016 * A copy is found in the textfile GPL.txt and important notices to the license 00017 * from the author is found in LICENSE.txt distributed with these scripts. 00018 * 00019 * 00020 * This script is distributed in the hope that it will be useful, 00021 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00022 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00023 * GNU General Public License for more details. 00024 * 00025 * This copyright notice MUST APPEAR in all copies of the script! 00026 ***************************************************************/ 00027 00028 /** 00029 * Renderer for unordered lists 00030 * 00031 * @author Steffen Ritter <info@steffen-ritter.net> 00032 * @package TYPO3 00033 * @subpackage t3lib 00034 */ 00035 class t3lib_tree_Renderer_UnorderedList extends t3lib_tree_Renderer_Abstract { 00036 /** 00037 * recursion level 00038 * 00039 * @var int 00040 */ 00041 protected $recursionLevel = 0; 00042 00043 /** 00044 * Renders a node recursive or just a single instance 00045 * 00046 * @param t3lib_tree_RepresentationNode $node 00047 * @param bool $recursive 00048 * @return mixed 00049 */ 00050 public function renderNode(t3lib_tree_RepresentationNode $node, $recursive = TRUE) { 00051 $code = '<li><span class="' . $node->getIcon() . '"> </span>' . $node->getLabel(); 00052 if ($recursive && $node->getChildNodes() !== NULL) { 00053 $this->recursionLevel++; 00054 $code .= $this->renderNodeCollection($node->getChildNodes()); 00055 $this->recursionLevel--; 00056 00057 } 00058 $code .= '</li>'; 00059 00060 return $code; 00061 } 00062 00063 /** 00064 * Renders a node collection recursive or just a single instance 00065 * 00066 * @param t3lib_tree_NodeCollection $node 00067 * @param bool $recursive 00068 * @return mixed 00069 */ 00070 public function renderTree(t3lib_tree_AbstractTree $tree, $recursive = TRUE) { 00071 $this->recursionLevel = 0; 00072 $code = '<ul class="level' . $this->recursionLevel . '" style="margin-left:10px">'; 00073 $code .= $this->renderNode($tree->getRoot(), $recursive); 00074 $code .= '</ul>'; 00075 00076 return $code; 00077 } 00078 00079 /** 00080 * Renders an tree recursive or just a single instance 00081 * 00082 * @param t3lib_tree_AbstractTree $node 00083 * @param bool $recursive 00084 * @return mixed 00085 */ 00086 public function renderNodeCollection(t3lib_tree_NodeCollection $collection, $recursive = TRUE) { 00087 $code = '<ul class="level' . $this->recursionLevel . '" style="margin-left:10px">'; 00088 foreach ($collection as $node) { 00089 $code .= $this->renderNode($node, $recursive); 00090 } 00091 $code .= '</ul>'; 00092 00093 return $code; 00094 } 00095 } 00096 00097 ?>
1.8.0