X-Git-Url: https://git.llucax.com/mecon/ai.git/blobdiff_plain/d734a389cf0d4b80a22887fd27c8a88379b01527..69a744cc170e8e853ec7946e9b61e7f35f0b2ae7:/lib/AI/DBTreeObject.php?ds=sidebyside diff --git a/lib/AI/DBTreeObject.php b/lib/AI/DBTreeObject.php index c8752c8..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; } @@ -106,8 +113,8 @@ class AI_DBTreeObject extends AI_DBObject { } // 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;