1 <?php /* vim: set binary expandtab tabstop=4 shiftwidth=4 textwidth=80:
2 -------------------------------------------------------------------------------
5 -------------------------------------------------------------------------------
6 This file is part of meconlib.
8 meconlib is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 2 of the License, or (at your option)
13 meconlib is distributed in the hope that it will be useful, but WITHOUT
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15 FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License; if not,
18 write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
19 Boston, MA 02111-1307 USA
20 -------------------------------------------------------------------------------
21 Creado: jue jul 17 15:32:52 ART 2003
22 Autor: Gonzalo Merayo <gmeray@mecon.gov.ar>
23 Leandro Lucarella <llucar@mecon.gov.ar>
24 -------------------------------------------------------------------------------
26 -----------------------------------------------------------------------------*/
28 require_once 'HTML/Table.php';
29 require_once 'MECON/HTML/Image.php';
36 class MECON_HTML_Arbol extends HTML_Table
58 * @var string $link_append
66 * @param array $datos Datos con los cuales construir el árbol.
67 * @param string $titulo Título.
68 * @param string $link_append DESC.
73 function MECON_HTML_Arbol($datos, $titulo, $link_append = '')
75 parent::HTML_Table(array(
80 'bgcolor' => '#003868'));
81 $this->datos = $datos;
82 $this->titulo = $titulo;
83 $this->link_append = $link_append;
87 * Devuelve el path del stylesheet de esta clase
93 return '/MECON/css/html/arbol';
99 * @param TIPO $dat DESC
100 * @param TIPO $n DESC
101 * @param TIPO &$tabla DESC
106 function expandir($dat, $n, &$tabla)
110 '/MECON/images/arbol_bullet_1.gif',
111 '/MECON/images/arbol_bullet_2.gif',
112 '/MECON/images/arbol_bullet_3.gif'
120 $classes = array('mecon_html_arbol_menu', 'mecon_html_arbol_menu1',
121 'mecon_html_arbol_menu1', 'mecon_html_arbol_menu2');
125 'width' => $n * $tabulados,
130 $margen = new MECON_HTML_Image('/MECON/images/blanco.gif', str_repeat(' ', $n), $atr);
131 $margen = $margen->toHtml();
135 $imagen = new MECON_HTML_Image($bullets[$n], @$alts[$n]);
136 $imagen = $imagen->toHtml();
138 foreach ($dat as $e) {
139 $titulo = $e['titulo'];
140 if(isset($e['activo']) && $e['activo'] != 0) $class = 'mecon_html_arbol_menu_activo';
141 else $class = @$classes[$n] ? $classes[$n] : end($classes);
142 if(isset($e['bold'])) $class .= '_bold';
143 if(!is_null($e['link'])) {
145 if ($this->link_append and @$e['id']) {
146 $link .= $this->link_append . $e['id'];
148 $titulo = '<a href="'.$link.'" class="'.$class.'">'.$titulo.'</a>';
150 $titulo = '<table border=0 cellpadding=0 cellspacing=0 align="left"><tr><td valign="top">'.$margen.$imagen.'</td><td>'.$titulo.'</td></tr></table>';//TODO
151 $tabla->addRow(array($titulo), array('class' => $class));
152 if(isset($e['sub'])) {
153 $this->expandir($e['sub'], $n+1, $tabla);
159 * Devuelve el html a imprimir
166 $this->setRowCount(0);
167 $t_interna = new HTML_Table(array(
170 'cellspacing' => '2',
171 'cellpadding' => '0',
172 'class' => 'mecon_html_arbol_bodytext'));
173 $titulo = new HTML_Table(array(
177 'cellspacing' => '0',
178 'cellpadding' => '0',
180 'background' => '/MECON/images/arbol_titulo.gif'));
181 $titulo->addRow(array($this->titulo), array(
183 'class' => 'mecon_html_arbol_titulo'));
184 $this->addRow(array($titulo), array('bgcolor' => '#FFFFFF'));
185 $this->expandir($this->datos, 0, $t_interna);
186 $this->addRow(array($t_interna->toHTML()));
187 return parent::toHTML();
193 * @param TIPO $dat DESC
194 * @param TIPO $n DESC
195 * @param TIPO $filtarActivos DESC
200 function expandirArray($dat, $n, $filtrarActivos)
203 foreach ($dat as $e) {
204 // Si no tiene ID o esta activo y se filtran los activos, se
205 // continua con el proximo item.
206 if (!@$e['id'] or $filtrarActivos and @$e['activo']) {
209 $array[$e['id']] = str_repeat(' ', $n) . $e['titulo'];
211 $array += $this->expandirArray($e['sub'], $n + 1, $filtrarActivos);
220 * @param bool $filtrarActivos DESC
225 function toArray($filtrarActivos = true)
227 return $this->expandirArray($this->datos, 0, $filtrarActivos);
233 * @param TIPO $dat DESC
234 * @param TIPO $n DESC
235 * @param TIPO $filtarActivos DESC
240 function expandirString($dat, $n, $filtrarActivos)
244 for ($i = 0; $i < $tot; $i++) {
246 // Si no tiene ID o esta activo y se filtran los activos, se
247 // continua con el proximo item.
248 if (!@$e['id'] or $filtrarActivos and @$e['activo']) {
251 $indent = str_repeat('| ', $n);
252 if ($i == ($tot - 1)) {
257 $str .= $indent . $e['titulo'] . "\n";
259 $str .= $this->expandirString($e['sub'], $n + 1, $filtrarActivos);
268 * @param bool $filtrarActivos DESC
273 function toString($filtrarActivos = true)
275 return $this->expandirString($this->datos, 0, $filtrarActivos);
279 * Activa un nodo del árbol.
281 * @param int $id Id del nodo a modificar.
282 * @param bool $activo Nuevo valor, true si está activo, false si no.
284 * @return bool True si se pudo modificar.
287 function setActivo($id, $activo = 1) {
288 return $this->modificarNodo($this->datos, $id, 'activo', $activo);
292 * Modifica un nodo del array.
294 * @param array $datos Datos del árbol a modificar.
295 * @param int $id Id del elemento a modificar.
296 * @param string $key Clave del dato a modificar.
297 * @param mixed $val Nuevo valor.
299 * @return bool True si se pudo modificar.
302 function modificarNodo(&$datos, $id, $key, $val) {
303 foreach (array_keys($datos) as $k) {
304 if (@$datos[$k]['id'] == $id) {
305 $datos[$k][$key] = $val;
307 } elseif (@$datos[$k]['sub']
308 and $this->modificarNodo($datos[$k]['sub'], $id, $key, $val)) {