コード例 #1
0
ファイル: actions.class.php プロジェクト: mediasadc/alba
 /**
  * Muestra la cuenta, los alumnos y los responsables
  **/
 public function executeVerCompleta()
 {
     $c = new Criteria();
     $c->add(CuentaPeer::ID, $this->getRequestParameter('id'));
     $this->cuenta = CuentaPeer::doSelectOne($c);
     $this->forward404Unless($this->cuenta);
     $c = new Criteria();
     $c->add(AlumnoPeer::FK_CUENTA_ID, $this->getRequestParameter('id'));
     $this->aAlumno = AlumnoPeer::doSelect($c);
     $c = new Criteria();
     $c->add(ResponsablePeer::FK_CUENTA_ID, $this->getRequestParameter('id'));
     $this->aResponsable = ResponsablePeer::doSelect($c);
 }
コード例 #2
0
ファイル: actions.class.php プロジェクト: mediasadc/alba
 /**
  * @param array $aVariable
  * @returns array
  */
 private function llenarVariables($aVariable)
 {
     $aDato = array();
     foreach ($aVariable as $idx => $result) {
         //Recorrer las variables
         switch ($idx) {
             // me fijo que variables debo enviar al template de resultado
             case 'cuenta':
                 if (array_key_exists('loop', $result) and $result['loop'] == 1) {
                     $criteria = new Criteria();
                     $cuentas = CuentaPeer::doSelect($criteria);
                     foreach ($cuentas as $cuenta) {
                         $aDato['cuenta'][] = $cuenta->toArray();
                     }
                 } else {
                     if ($this->getRequestParameter('cuenta_id')) {
                         $cuenta = CuentaPeer::retrieveByPk($this->getRequestParameter('cuenta_id'));
                         $aDato['cuenta'] = $cuenta->toArray();
                     }
                 }
                 break;
             case 'responsable':
                 if (array_key_exists('loop', $result) and $result['loop'] == 1) {
                     $criteria = new Criteria();
                     if ($this->getRequestParameter('fk_cuenta_id')) {
                         $criteria->add(ResponsablePeer::FK_CUENTA_ID, $this->getRequestParameter('fk_cuenta_id'));
                     }
                     $responsables = ResponsablePeer::doSelect($criteria);
                     foreach ($responsables as $responsable) {
                         $aDato['responsable'][] = $responsable->toArray();
                     }
                 } else {
                     if ($this->getRequestParameter('responsable_id')) {
                         $responsable = ResponsablePeer::retrieveByPk($this->getRequestParameter('responsable_id'));
                         $aDato['responsable'] = $responsable->toArray();
                     }
                 }
                 break;
             case 'alumno':
                 //dependiendo si es una variables de cilcos
                 if (array_key_exists('loop', $result) and $result['loop'] == 1) {
                     $criteria = new Criteria();
                     if ($this->getRequestParameter('division_id')) {
                         $criteria->add(DivisionPeer::ID, $this->getRequestParameter('division_id'));
                     }
                     if ($this->getRequestParameter('fk_cuenta_id')) {
                         $criteria->add(AlumnoPeer::FK_CUENTA_ID, $this->getRequestParameter('fk_cuenta_id'));
                     }
                     $criteria->addJoin(RelAlumnoDivisionPeer::FK_ALUMNO_ID, AlumnoPeer::ID);
                     $criteria->addJoin(RelAlumnoDivisionPeer::FK_DIVISION_ID, DivisionPeer::ID);
                     $criteria->addAscendingOrderByColumn(AlumnoPeer::APELLIDO);
                     $alumnos = AlumnoPeer::doSelect($criteria);
                     foreach ($alumnos as $alumno) {
                         $aDato['alumno'][] = $alumno->toArrayInforme();
                     }
                 } else {
                     if ($this->getRequestParameter('alumno_id')) {
                         $alumno = AlumnoPeer::retrieveByPk($this->getRequestParameter('alumno_id'));
                         $aDato['alumno'] = $alumno->toArrayInforme();
                     }
                 }
                 break;
             case 'division':
                 if ($this->getRequestParameter('division_id')) {
                     $d = DivisionPeer::retrieveByPK($this->getRequestParameter('division_id'));
                 } else {
                     $c = new Criteria();
                     $c->add(RelAlumnoDivisionPeer::FK_ALUMNO_ID, $this->getRequestParameter('alumno_id'));
                     $relAlumnoDivision = RelAlumnoDivisionPeer::doSelectOne($c);
                     $d = $relAlumnoDivision->getDivision();
                 }
                 $aDato['division'] = $d->toArrayInforme();
                 break;
             case 'establecimiento':
                 if ($this->getUser()->getAttribute('fk_establecimiento_id')) {
                     $establecimiento = EstablecimientoPeer::retrieveByPk($this->getUser()->getAttribute('fk_establecimiento_id'));
                     $aDato['establecimiento'] = $establecimiento->toArrayInforme();
                 }
                 break;
             case 'ciclolectivo':
                 if ($this->getUser()->getAttribute('fk_ciclolectivo_id')) {
                     $ciclolectivo_id = $this->getUser()->getAttribute('fk_ciclolectivo_id');
                     $ciclolectivo = CiclolectivoPeer::retrieveByPk($ciclolectivo_id);
                     $aDato['ciclolectivo'] = $ciclolectivo->toArray();
                 }
                 break;
             case 'locacion':
                 if (array_key_exists('loop', $result) and $result['loop'] == 1 and $this->getUser()->getAttribute('fk_establecimiento_id')) {
                     $c = new Criteria();
                     $c->add(RelEstablecimientoLocacionPeer::FK_ESTABLECIMIENTO_ID, $this->getUser()->getAttribute('fk_establecimiento_id'));
                     $c->addJoin(RelEstablecimientoLocacionPeer::FK_LOCACION_ID, LocacionPeer::ID);
                     $locaciones = LocacionPeer::doSelect($c);
                     foreach ($locaciones as $locacion) {
                         $aDato['locacion'][] = $locacion->toArray();
                     }
                 } else {
                     if ($this->getRequestParameter('locacion_id')) {
                         $c = new Criteria();
                         $c->add(LocacionPeer::ID, $this->getRequestParameter('locacion_id'));
                         $locacion = LocacionPeer::doSelect($c);
                         $aDato['locacion'] = $locacion->toArray();
                     }
                 }
                 break;
             case 'espacio':
                 if (array_key_exists('loop', $result) and $result['loop'] == 1 and $this->getUser()->getAttribute('fk_establecimiento_id')) {
                     $c = new Criteria();
                     $c->add(RelEstablecimientoLocacionPeer::FK_ESTABLECIMIENTO_ID, $this->getUser()->getAttribute('fk_establecimiento_id'));
                     $c->addJoin(RelEstablecimientoLocacionPeer::FK_LOCACION_ID, LocacionPeer::ID);
                     if ($this->getRequestParameter('locacion_id')) {
                         $c->add(LocacionPeer::ID, $this->getRequestParameter('locacion_id'));
                     }
                     $c->addJoin(EspacioPeer::FK_LOCACION_ID, LocacionPeer::ID);
                     $espacios = EspacioPeer::doSelect($c);
                     foreach ($espacios as $espacio) {
                         $aDato['espacio'][] = $espacio->toArray();
                     }
                 } else {
                     if ($this->getRequestParameter('espacio_id')) {
                         $c = new Criteria();
                         $c->add(EspacioPeer::ID, $this->getRequestParameter('espacio_id'));
                         $espacio = EspacioPeer::doSelect($c);
                         $aDato['espacio'] = $espacio->toArray();
                     }
                 }
                 break;
             case 'organizacion':
                 if ($this->getUser()->getAttribute('fk_establecimiento_id')) {
                     $c = new Criteria();
                     $c->add(EstablecimientoPeer::ID, $this->getUser()->getAttribute('fk_establecimiento_id'));
                     $c->addJoin(EstablecimientoPeer::FK_ORGANIZACION_ID, OrganizacionPeer::ID);
                     $organizacion = OrganizacionPeer::doSelectOne($c);
                     $aDato['organizacion'] = $organizacion->toArray();
                 }
                 break;
             case 'usuario':
                 if ($this->getUser()->getAttribute('id')) {
                     $usuario = UsuarioPeer::retrieveByPk($this->getUser()->getAttribute('id'));
                     $aUsuario = $usuario->toArray();
                     //por seguridad: para no mostrar otros datos del usuario como clave, preguntas, etc
                     $aDato['usuario'] = array('Usuario' => $aUsuario['Usuario'], 'Email' => $aUsuario['Email']);
                 }
                 break;
             case 'docente':
                 if (array_key_exists('loop', $result) and $result['loop'] == 1) {
                     $c = new Criteria();
                     $docentes = DocentePeer::doSelect($c);
                     foreach ($docentes as $docente) {
                         $aDato['docente'][] = $docente->toArray();
                     }
                 } else {
                     if ($this->getRequestParameter('docente_id')) {
                         $docente = DocentePeer::retrieveByPK($this->getRequestParameter('docente_id'));
                         $aDato['docente'] = $docente->toArray();
                     }
                 }
                 break;
             case 'boletin':
                 break;
             default:
         }
     }
     return $aDato;
 }
コード例 #3
0
 public function getResponsablesJoinRolResponsable($criteria = null, $con = null, $join_behavior = Criteria::LEFT_JOIN)
 {
     if ($criteria === null) {
         $criteria = new Criteria(NivelInstruccionPeer::DATABASE_NAME);
     } elseif ($criteria instanceof Criteria) {
         $criteria = clone $criteria;
     }
     if ($this->collResponsables === null) {
         if ($this->isNew()) {
             $this->collResponsables = array();
         } else {
             $criteria->add(ResponsablePeer::FK_NIVEL_INSTRUCCION_ID, $this->id);
             $this->collResponsables = ResponsablePeer::doSelectJoinRolResponsable($criteria, $con, $join_behavior);
         }
     } else {
         $criteria->add(ResponsablePeer::FK_NIVEL_INSTRUCCION_ID, $this->id);
         if (!isset($this->lastResponsableCriteria) || !$this->lastResponsableCriteria->equals($criteria)) {
             $this->collResponsables = ResponsablePeer::doSelectJoinRolResponsable($criteria, $con, $join_behavior);
         }
     }
     $this->lastResponsableCriteria = $criteria;
     return $this->collResponsables;
 }
コード例 #4
0
 public static function retrieveByPKs($pks, PropelPDO $con = null)
 {
     if ($con === null) {
         $con = Propel::getConnection(ResponsablePeer::DATABASE_NAME, Propel::CONNECTION_READ);
     }
     $objs = null;
     if (empty($pks)) {
         $objs = array();
     } else {
         $criteria = new Criteria(ResponsablePeer::DATABASE_NAME);
         $criteria->add(ResponsablePeer::ID, $pks, Criteria::IN);
         $objs = ResponsablePeer::doSelect($criteria, $con);
     }
     return $objs;
 }
コード例 #5
0
ファイル: BaseResponsable.php プロジェクト: mediasadc/alba
 public function fromArray($arr, $keyType = BasePeer::TYPE_PHPNAME)
 {
     $keys = ResponsablePeer::getFieldNames($keyType);
     if (array_key_exists($keys[0], $arr)) {
         $this->setId($arr[$keys[0]]);
     }
     if (array_key_exists($keys[1], $arr)) {
         $this->setNombre($arr[$keys[1]]);
     }
     if (array_key_exists($keys[2], $arr)) {
         $this->setApellido($arr[$keys[2]]);
     }
     if (array_key_exists($keys[3], $arr)) {
         $this->setApellidoMaterno($arr[$keys[3]]);
     }
     if (array_key_exists($keys[4], $arr)) {
         $this->setDireccion($arr[$keys[4]]);
     }
     if (array_key_exists($keys[5], $arr)) {
         $this->setDireccionLaboral($arr[$keys[5]]);
     }
     if (array_key_exists($keys[6], $arr)) {
         $this->setCiudad($arr[$keys[6]]);
     }
     if (array_key_exists($keys[7], $arr)) {
         $this->setCodigoPostal($arr[$keys[7]]);
     }
     if (array_key_exists($keys[8], $arr)) {
         $this->setFkProvinciaId($arr[$keys[8]]);
     }
     if (array_key_exists($keys[9], $arr)) {
         $this->setTelefono($arr[$keys[9]]);
     }
     if (array_key_exists($keys[10], $arr)) {
         $this->setTelefonoLaboral($arr[$keys[10]]);
     }
     if (array_key_exists($keys[11], $arr)) {
         $this->setTelefonoMovil($arr[$keys[11]]);
     }
     if (array_key_exists($keys[12], $arr)) {
         $this->setNroDocumento($arr[$keys[12]]);
     }
     if (array_key_exists($keys[13], $arr)) {
         $this->setFkTipodocumentoId($arr[$keys[13]]);
     }
     if (array_key_exists($keys[14], $arr)) {
         $this->setSexo($arr[$keys[14]]);
     }
     if (array_key_exists($keys[15], $arr)) {
         $this->setEmail($arr[$keys[15]]);
     }
     if (array_key_exists($keys[16], $arr)) {
         $this->setObservacion($arr[$keys[16]]);
     }
     if (array_key_exists($keys[17], $arr)) {
         $this->setAutorizacionRetiro($arr[$keys[17]]);
     }
     if (array_key_exists($keys[18], $arr)) {
         $this->setLlamarEmergencia($arr[$keys[18]]);
     }
     if (array_key_exists($keys[19], $arr)) {
         $this->setFkCuentaId($arr[$keys[19]]);
     }
     if (array_key_exists($keys[20], $arr)) {
         $this->setFkRolresponsableId($arr[$keys[20]]);
     }
     if (array_key_exists($keys[21], $arr)) {
         $this->setOcupacion($arr[$keys[21]]);
     }
     if (array_key_exists($keys[22], $arr)) {
         $this->setFechaNacimiento($arr[$keys[22]]);
     }
     if (array_key_exists($keys[23], $arr)) {
         $this->setFkNivelInstruccionId($arr[$keys[23]]);
     }
 }
コード例 #6
0
ファイル: actions.class.php プロジェクト: mediasadc/alba
 public function executeIrCuenta()
 {
     //Obtener el id de cuenta.
     $c = new Criteria();
     $c->add(ResponsablePeer::ID, $this->getRequestParameter('id'));
     $Resp = ResponsablePeer::doSelectOne($c);
     return $this->redirect('cuenta/verCompleta?id=' . $Resp->getFkCuentaId());
 }
コード例 #7
0
 public static function doSelectJoinAllExceptAlumno(Criteria $c, $con = null, $join_behavior = Criteria::LEFT_JOIN)
 {
     $c = clone $c;
     if ($c->getDbName() == Propel::getDefaultDB()) {
         $c->setDbName(self::DATABASE_NAME);
     }
     RelRolresponsableResponsablePeer::addSelectColumns($c);
     $startcol2 = RelRolresponsableResponsablePeer::NUM_COLUMNS - RelRolresponsableResponsablePeer::NUM_LAZY_LOAD_COLUMNS;
     RolResponsablePeer::addSelectColumns($c);
     $startcol3 = $startcol2 + (RolResponsablePeer::NUM_COLUMNS - RolResponsablePeer::NUM_LAZY_LOAD_COLUMNS);
     ResponsablePeer::addSelectColumns($c);
     $startcol4 = $startcol3 + (ResponsablePeer::NUM_COLUMNS - ResponsablePeer::NUM_LAZY_LOAD_COLUMNS);
     $c->addJoin(array(RelRolresponsableResponsablePeer::FK_ROLRESPONSABLE_ID), array(RolResponsablePeer::ID), $join_behavior);
     $c->addJoin(array(RelRolresponsableResponsablePeer::FK_RESPONSABLE_ID), array(ResponsablePeer::ID), $join_behavior);
     $stmt = BasePeer::doSelect($c, $con);
     $results = array();
     while ($row = $stmt->fetch(PDO::FETCH_NUM)) {
         $key1 = RelRolresponsableResponsablePeer::getPrimaryKeyHashFromRow($row, 0);
         if (null !== ($obj1 = RelRolresponsableResponsablePeer::getInstanceFromPool($key1))) {
         } else {
             $omClass = RelRolresponsableResponsablePeer::getOMClass();
             $cls = substr('.' . $omClass, strrpos('.' . $omClass, '.') + 1);
             $obj1 = new $cls();
             $obj1->hydrate($row);
             RelRolresponsableResponsablePeer::addInstanceToPool($obj1, $key1);
         }
         $key2 = RolResponsablePeer::getPrimaryKeyHashFromRow($row, $startcol2);
         if ($key2 !== null) {
             $obj2 = RolResponsablePeer::getInstanceFromPool($key2);
             if (!$obj2) {
                 $omClass = RolResponsablePeer::getOMClass();
                 $cls = substr('.' . $omClass, strrpos('.' . $omClass, '.') + 1);
                 $obj2 = new $cls();
                 $obj2->hydrate($row, $startcol2);
                 RolResponsablePeer::addInstanceToPool($obj2, $key2);
             }
             $obj2->addRelRolresponsableResponsable($obj1);
         }
         $key3 = ResponsablePeer::getPrimaryKeyHashFromRow($row, $startcol3);
         if ($key3 !== null) {
             $obj3 = ResponsablePeer::getInstanceFromPool($key3);
             if (!$obj3) {
                 $omClass = ResponsablePeer::getOMClass();
                 $cls = substr('.' . $omClass, strrpos('.' . $omClass, '.') + 1);
                 $obj3 = new $cls();
                 $obj3->hydrate($row, $startcol3);
                 ResponsablePeer::addInstanceToPool($obj3, $key3);
             }
             $obj3->addRelRolresponsableResponsable($obj1);
         }
         $results[] = $obj1;
     }
     $stmt->closeCursor();
     return $results;
 }
コード例 #8
0
 public function getResponsable(PropelPDO $con = null)
 {
     if ($this->aResponsable === null && $this->fk_responsable_id !== null) {
         $c = new Criteria(ResponsablePeer::DATABASE_NAME);
         $c->add(ResponsablePeer::ID, $this->fk_responsable_id);
         $this->aResponsable = ResponsablePeer::doSelectOne($c, $con);
     }
     return $this->aResponsable;
 }