]> git.llucax.com Git - mecon/ai.git/blobdiff - lib/AI/DBTreeObject.php
Se agrega el checkbox para abrir en ventana nueva.
[mecon/ai.git] / lib / AI / DBTreeObject.php
index 5d86cba46356b00d62c79a816cb0d7a5be80e574..b322043309fac634c86b56a86b7886471f1012b2 100644 (file)
 // $Id$
 //
 
 // $Id$
 //
 
-// +X2C includes
 require_once 'AI/DBObject.php';
 require_once 'AI/DBObject.php';
-// ~X2C
 
 
-// +X2C Class 524 :AI_DBTreeObject
 /**
  * @package AI
  * @access public
 /**
  * @package AI
  * @access public
@@ -57,30 +54,32 @@ class AI_DBTreeObject extends AI_DBObject {
         return $this->_hijos;
     }
 
         return $this->_hijos;
     }
 
-    // ~X2C
-
-    // +X2C Operation 526
     /**
      * @param  int $id Identificador del objecto.
     /**
      * @param  int $id Identificador del objecto.
-     * @param  string $confFile Configuracin del objeto.
+     * @param  string $confFile Configuración del objeto.
      *
      * @return void
      * @access public
      */
      *
      * @return void
      * @access public
      */
-    function AI_DBTreeObject($id = 0, $confFile = '') // ~X2C
+    function AI_DBTreeObject($id = 0, $confFile = '')
     {
         parent::AI_DBObject($id, $confFile);
     }
     {
         parent::AI_DBObject($id, $confFile);
     }
-    // -X2C
 
 
-    // +X2C Operation 527
     /**
     /**
+     * Carga hijos de un objeto.
+     * Si hubo error devuelve un PEAR_Error, si no hubo error, devuleve un
+     * array de objetos (los hijos).
+     *
      * @param  mixed $db Base de datos o resultado de donde cargar los hijos.
      * @param  mixed $db Base de datos o resultado de donde cargar los hijos.
+     * @param  bool $soloHabilitados Si es true, se cargan solo los hijos con
+     *                               el flag habilitado.
+     * @param  string $orden Indica cómo ordenar los hijos cargados.
      *
      *
-     * @return PEAR_Error
+     * @return mixed
      * @access public
      */
      * @access public
      */
-    function cargarHijos($db) // ~X2C
+    function cargarHijos($db, $soloHabilitados = true, $orden = 'nombre')
     {
         $id_field = $this->conf['id'];
         $id_padre = $this->conf['padre'];
     {
         $id_field = $this->conf['id'];
         $id_padre = $this->conf['padre'];
@@ -91,7 +90,14 @@ class AI_DBTreeObject extends AI_DBObject {
             $db     = $result->dbh;
         // Si no es un resultado, hago el query.
         } else {
             $db     = $result->dbh;
         // Si no es un resultado, hago el query.
         } else {
-            $result   = $db->query("SELECT * FROM $tabla WHERE $id_padre = $id");
+            $query = "SELECT * FROM $tabla WHERE $id_padre = $id";
+            if ($soloHabilitados) {
+                $query .= ' AND ' . $this->conf['habilitado'] . ' = 1';
+            }
+            if ($orden) {
+                $query .= ' ORDER BY ' . $orden;
+            }
+            $result = $db->query($query);
             if (DB::isError($result)) {
                 return $result;
             }
             if (DB::isError($result)) {
                 return $result;
             }
@@ -106,14 +112,47 @@ class AI_DBTreeObject extends AI_DBObject {
         }
         // Si no hay mas resultados, entonces terminó bien.
         if (AI_Error::isError($err)
         }
         // Si no hay mas resultados, entonces terminó bien.
         if (AI_Error::isError($err)
-                and $err->getCode() == AIERROR_NO_RESULTADOS) {
-            return true;
+                and $err->getCode() == AI_ERROR_NO_RESULTADOS) {
+            return $this->_hijos;
         }
         // Si no, se devuelve el error.
         return $err;
     }
         }
         // Si no, se devuelve el error.
         return $err;
     }
-    // -X2C
 
 
-} // -X2C Class :AI_DBTreeObject
+    /**
+     * Borra el objeto de la base de datos verificando que no tenga hijos.
+     *
+     * @param  DB $db Base de datos de la cual borrar el objeto.
+     *
+     * @return PEAR_Error
+     * @access public
+     */
+    function borrar($db)
+    {
+               $id_field = $this->conf['id'];
+               $id_padre = $this->conf['padre'];
+        $tabla = $this->conf['base'].'.'.$this->conf['tabla'];
+        $id = intval($this->$id_field);
+        if ($id) {
+            // Verifico si tiene hijos.
+            $hijos = $db->getOne("
+                SELECT $id_field
+                FROM   $tabla
+                WHERE  $id_padre = $id");
+            if (DB::isError($hijos)) {
+                return $hijos;
+            } elseif ($hijos) {
+                // Si tiene hijos, da error.
+                return new AI_Error(AI_ERROR_TIENE_HIJOS,
+                    "El elemento de identificador $id todavía tiene hijos.");
+            } else {
+                // Si no tiene hijos, lo borro.
+                return parent::borrar($db);
+            }
+        }
+        return PEAR::raiseError('No hay un identificador válido para borrar');
+    }
+
+}
 
 ?>
\ No newline at end of file
 
 ?>
\ No newline at end of file