]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/HTML/Arbol/ArbolDB.php
Ahora en las secciones "Padre" se puede agregar una clave subhijos cuyo contenido...
[mecon/meconlib.git] / lib / MECON / HTML / Arbol / ArbolDB.php
index 111c4e5cd69f80950f0aa92efacf9b2191fd3183..78dfd5fe7c1fff0530a58e0735cfb0786beac90f 100644 (file)
@@ -20,6 +20,7 @@ Boston, MA  02111-1307  USA
 -------------------------------------------------------------------------------
 Creado: jue jul 17 15:33:41 ART 2003
 Autor:  Gonzalo Merayo <gmeray@mecon.gov.ar>
+        Leandro Lucarella <llucar@mecon.gov.ar>
 -------------------------------------------------------------------------------
 $Id$
 -----------------------------------------------------------------------------*/
@@ -29,45 +30,48 @@ require_once 'DB.php';
 
 class HTML_ArbolDB extends HTML_Arbol
 {
-        var $padre = null;
-       var $tabla;
-       var $nombre;
-       var $id;
-       var $link = null;
-       var $prepend_link = null;
-       var $where = '';
-       var $order = '';
-       var $db;
+    var $padre = '';
+    var $tabla;
+    var $nombre;
+    var $id;
+    var $id_activo;
+    var $link = '';
+    var $link_append = '';
+    var $where = '';
+    var $order = '';
+    var $db;
     
-    function HTML_ArbolDB($dbdata, $imagen)
+    function HTML_ArbolDB($dbdata, $titulo, $link_append = '')
     {
         if(isset($dbdata['id_padre']))
-          $this->padre = $dbdata['id_padre'];
-       $this->tabla = $dbdata['tabla'];
-       $this->nombre = $dbdata['nombre'];
-       $this->id = $dbdata['id'];
+            $this->padre = $dbdata['id_padre'];
+        $this->tabla = $dbdata['tabla'];
+        $this->nombre = $dbdata['nombre'];
+        $this->id = $dbdata['id'];
+        $this->id_activo = @$dbdata['id_activo'];
+        // FIXME - Deprecated!
         if(isset($dbdata['prepend_link']))
-         $this->prepend_link = $dbdata['prepend_link']; 
+            $link_append = $dbdata['prepend_link']; 
         if(isset($dbdata['link']))
-         $this->link = $dbdata['link']; 
+            $this->link = $dbdata['link']; 
         if(isset($dbdata['where']))
-         $this->where = $dbdata['where'];
+            $this->where = $dbdata['where'];
         if(isset($dbdata['order']))
-         $this->order = ' ORDER BY '.$dbdata['nombre'].' '.$dbdata['order']; 
-       $this->db = $dbdata['db']; 
-       $dat = $this->BuscarHijos(0);
-        parent::HTML_Arbol($dat, $imagen);
+            $this->order = ' ORDER BY '.$dbdata['nombre'].' '.$dbdata['order']; 
+        $this->db = $dbdata['db']; 
+        parent::HTML_Arbol(array(), $titulo, $link_append);
+        $this->datos = $this->BuscarHijos(0);
     }
   
     function BuscarHijos($id)
     {
         $sql = "SELECT $this->nombre, $this->id ";
-        if(!is_null($this->link))
-        $sql .=  ", $this->link ";
+        if($this->link)
+            $sql .=  ", $this->link ";
         $sql .=  "FROM $this->tabla ";
-        if(!is_null($this->padre) or $this->where)
+        if($this->padre or $this->where)
           $sql .= 'WHERE ';
-        if(!is_null($this->padre)) {
+        if($this->padre) {
           $sql .= "$this->padre = '$id'";
           if ($this->where)
             $sql .= ' AND';
@@ -82,15 +86,19 @@ class HTML_ArbolDB extends HTML_Arbol
        {
            $titulo = $row[0];
            $id = $row[1];
-           if(is_null($this->padre)) $sub = array();
+           if(!$this->padre) $sub = array();
            else $sub = $this->BuscarHijos($id);
-           if(!is_null($this->link))  $link = $this->prepend_link.$row[2];
-           else $link = $this->prepend_link.$id;
-           $dat[] = array(
-               'titulo'=> $titulo,
-               'link' => $link,
-               'sub' => $sub 
+           $link = strval(@$row[2]);
+           $d = array(
+            'titulo'=> $titulo,
+            'link' => $link,
+            'id' => $id,
+            'sub' => $sub 
            );
+        if (!is_null($this->id_activo) and $id == $this->id_activo) {
+            $d['activo'] = 1;
+        }
+        $dat[] = $d;
        }
        return $dat;