X-Git-Url: https://git.llucax.com/mecon/ai.git/blobdiff_plain/b4fb39ec82b3c1e0f904ab0fe39d61f5ec62e10a..89f9ee9162349d9d5027d60f6db398a8c2767f17:/lib/AI/DBTreeObject.php?ds=sidebyside diff --git a/lib/AI/DBTreeObject.php b/lib/AI/DBTreeObject.php index 71689bc..66f0507 100644 --- a/lib/AI/DBTreeObject.php +++ b/lib/AI/DBTreeObject.php @@ -75,12 +75,15 @@ class AI_DBTreeObject extends AI_DBObject { // +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 bool $soloHabilitados Si es true, se cargan solo los hijos con el flag habilitado. * - * @return PEAR_Error + * @return mixed * @access public */ - function cargarHijos($db) // ~X2C + function cargarHijos($db, $soloHabilitados = true) // ~X2C { $id_field = $this->conf['id']; $id_padre = $this->conf['padre']; @@ -91,7 +94,11 @@ class AI_DBTreeObject extends AI_DBObject { $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'; + } + $result = $db->query($query); if (DB::isError($result)) { return $result; } @@ -107,7 +114,7 @@ class AI_DBTreeObject extends AI_DBObject { // Si no hay mas resultados, entonces terminó bien. if (AI_Error::isError($err) and $err->getCode() == AI_ERROR_NO_RESULTADOS) { - return true; + return $this->_hijos; } // Si no, se devuelve el error. return $err;