]> git.llucax.com Git - mecon/meconlib.git/blobdiff - lib/MECON/Dependencia.php
Se completa documentacion y se arreglan bugs.
[mecon/meconlib.git] / lib / MECON / Dependencia.php
index e0f88c488da66e7780bdf86a969197afe2ec815b..ec590ea33727d1a4c829dacb372534208550efd7 100644 (file)
@@ -28,7 +28,7 @@ $Id$
 require_once 'MECON/Agente.php';
 require_once 'DB.php';
 
 require_once 'MECON/Agente.php';
 require_once 'DB.php';
 
-// +X2C Class 145 :Dependencia
+// +X2C Class 145 :MECON_Dependencia
 /**
  * @access protected
  */
 /**
  * @access protected
  */
@@ -51,6 +51,14 @@ class MECON_Dependencia {
      */
     var $nombre_breve;
 
      */
     var $nombre_breve;
 
+    /**
+     * Id de la dependencia en la base.
+     *
+     * @var    int $dependencia_id
+     * @access public
+     */
+    var $dependencia_id = null;
+
     // ~X2C
 
     // +X2C Operation 147
     // ~X2C
 
     // +X2C Operation 147
@@ -67,7 +75,7 @@ class MECON_Dependencia {
         $db = DB::connect($dsn);
         if (DB::isError($db))
             die ($db->getMessage("No pudo conectarse a la base"));
         $db = DB::connect($dsn);
         if (DB::isError($db))
             die ($db->getMessage("No pudo conectarse a la base"));
-        $sql = "SELECT nombre, nombre_breve
+        $sql = "SELECT nombre, nombre_breve, dependencia_id
                FROM Dependencias
                WHERE codigo_actual = '$this->codep' AND
                dependencia_esta_activa = 1";
                FROM Dependencias
                WHERE codigo_actual = '$this->codep' AND
                dependencia_esta_activa = 1";
@@ -78,6 +86,7 @@ class MECON_Dependencia {
             $row = $result->fetchRow(DB_FETCHMODE_ASSOC);
             $this->nombre = $row['nombre'];
             $this->nombre_breve = $row['nombre_breve'];
             $row = $result->fetchRow(DB_FETCHMODE_ASSOC);
             $this->nombre = $row['nombre'];
             $this->nombre_breve = $row['nombre_breve'];
+            $this->dependencia_id = $row['dependencia_id'];
         }
     }
     // -X2C
         }
     }
     // -X2C
@@ -167,5 +176,67 @@ class MECON_Dependencia {
     }
     // -X2C
 
     }
     // -X2C
 
-} // -X2C Class :Dependencia
-?>
+    // +X2C Operation 167
+    /**
+     * Buscar dependencias por el codep.
+     *
+     * @param  db &$dbh Base de Datos
+     * @param  string $codep COdigo de dependencia, o parte del mismo seguido del comodIn (*)
+     *
+     * @return array
+     * @access public
+     * @static
+     */
+    function buscarPorCodigo(&$dbh, $codep) // ~X2C
+    {
+       //Reemplazar el comodIn
+       $codep = preg_replace ('/\*/', '%', $codep);    
+    
+       $sql = " SELECT codigo_actual, codigo_comdoc, nombre, dependencia_id 
+                FROM CODEP.Dependencias
+                WHERE dependencia_esta_activa = 1 
+                       AND codigo_actual LIKE '$codep' 
+                ORDER BY codigo_actual ";
+
+        $dbh->setFetchMode(DB_FETCHMODE_ASSOC);
+        $result = $dbh->query($sql);
+       
+       return $result;
+    }
+    // -X2C
+
+    // +X2C Operation 168
+    /**
+     * @param  db &$dbh Base de Datos
+     * @param  string $clave Cadena de palabras clave del nombre de la dependencia.
+     *
+     * @return array
+     * @access public
+     * @static
+     */
+    function buscarPorNombre(&$dbh, $clave) // ~X2C
+    {
+       //ReducciOn de espacios en blanco
+       $clave = preg_replace ('/\s+/', ' ', $clave);   
+    
+       $sql = " SELECT codigo_actual, codigo_comdoc, nombre, dependencia_id
+                FROM CODEP.Dependencias
+                WHERE  dependencia_esta_activa = 1 ";
+
+        //Separar la cadena de palabras clave
+       $items = split(' ', $clave);
+       foreach ($items as $i){
+           $sql.= " AND nombre like '%$i%' ";
+       }
+
+       $sql.= " ORDER BY codigo_actual";
+
+        $dbh->setFetchMode(DB_FETCHMODE_ASSOC);
+        $result = $dbh->query($sql);
+       
+       return $result;
+    }
+    // -X2C
+
+} // -X2C Class :MECON_Dependencia
+?>
\ No newline at end of file