Exemple #1
0
 public function executeUsuaris(sfWebRequest $request)
 {
     $this->setLayout('hospici');
     $accio = $request->getParameter('accio', 'inici');
     $this->IDU = $this->getUser()->getSessionPar('idU');
     $this->IDS = SitesPeer::HOSPICI_ID;
     $this->SECCIO = "";
     switch ($accio) {
         case 'inici':
             $this->SECCIO = 'INICI';
             break;
             //Modificació de les dades de l'usuari.
         //Modificació de les dades de l'usuari.
         case 'update':
             $RS = $request->getParameter('usuaris');
             if ($RS['UsuariID'] == $this->IDU) {
                 $FU = UsuarisPeer::initialize($this->IDU, $this->IDS, false, true);
                 $FU->bind($RS);
                 if ($FU->isValid()) {
                     $FU->save();
                     $this->MISSATGE1 = "OK";
                 }
             }
             $this->SECCIO = 'USUARI';
             break;
             //Usuari que compra o reserva una entrada
         //Usuari que compra o reserva una entrada
         case 'compra_entrada':
             //Des de l'Hospici només es pot reservar una entrada. Més endavant s'haurà d'abonar l'import.
             $RS = $request->getParameter('entrades');
             $OER = EntradesReservaPeer::initialize()->getObject();
             $OA = ActivitatsPeer::retrieveByPK($RS['idA']);
             $idS = 0;
             if ($OA instanceof Activitats) {
                 $idS = $OA->getSiteid();
             }
             $this->MISSATGE2 = 'OK';
             try {
                 //Si no existeix una compra per aquest usuari, la fem, altrament, no fem res.
                 if (!EntradesReservaPeer::ExisteixenEntradesComprades($this->IDU, $RS['idA'])) {
                     //Falta mirar si hi ha entrades disponibles.
                     $OER->setUsuariid($this->IDU);
                     $OER->setActivitatsid($RS['idA']);
                     $OER->setQuantes($RS['num']);
                     $OER->setData(date('Y-m-d H:i', time()));
                     $OER->setEstat(EntradesReservaPeer::CONFIRMADA);
                     $OER->setActiu(true);
                     $OER->setSiteid($idS);
                     $OER->save();
                     UsuarisPeer::addSite($this->IDU, $idS);
                 } else {
                     $this->MISSATGE2 = 'ENTRADA_REPE';
                 }
             } catch (Exception $e) {
                 $this->MISSATGE2 = 'ERROR';
             }
             $this->SECCIO = 'COMPRA_ENTRADA';
             break;
             //Usuari que anul·la una entrada prèviament reservada
         //Usuari que anul·la una entrada prèviament reservada
         case 'anula_entrada':
             $RS = $request->getParameter('idER');
             $OER = EntradesReservaPeer::retrieveByPK($RS);
             $idu = $OER->getUsuariid();
             $act = $OER->getActiu();
             if ($idu == $this->IDU && $act) {
                 $OER->setEstat(EntradesReservaPeer::ANULADA);
                 $OER->save();
             }
             $this->SECCIO = 'COMPRA_ENTRADA';
             break;
             //Nova matrícula a un curs
         //Nova matrícula a un curs
         case 'nova_matricula':
             //Capturem el codi del curs i el codi del descompte
             $idC = $request->getParameter('idC');
             $idD = $request->getParameter('idD');
             $OC = CursosPeer::retrieveByPK($idC);
             //Si el curs és correcte
             if ($OC instanceof Cursos) {
                 //Generem la matícula en procés.
                 $OM = MatriculesPeer::saveNewMatricula($this->IDU, $idC, 0, 'Matrícula hospici', $idD);
                 $this->SECCIO = 'MATRICULA';
                 if ($OM instanceof Matricules) {
                     if ($OM->getEstat() == MatriculesPeer::EN_ESPERA) {
                         //El curs en qüestió ja està ple. Mostrem el llistat però el missatge de "en espera"
                         $this->MISSATGE3 = 'ESPERA';
                     } elseif ($OM->getEstat() == MatriculesPeer::EN_PROCES) {
                         //La matrícula s'ha de cobrar amb targeta, només.
                         try {
                             //Carreguem les dades de l'usuari que està fent la matrícula
                             $OU = UsuarisPeer::retrieveByPK($this->IDU);
                             //Carreguem el TPV
                             $this->TPV = MatriculesPeer::getTPV(CursosPeer::CalculaPreu($idC, $idD, $OC->getSiteId()), $OU->getNomComplet(), $OM->getIdmatricules(), $this->IDS, true);
                         } catch (Exception $e) {
                             $this->MISSATGE3 = 'KO';
                             /* Faltarà enviar un missatge de mail */
                         }
                         $this->URL = OptionsPeer::getString('TPV_URL', $OC->getSiteId());
                         $this->setLayout('blanc');
                         $this->setTemplate('pagament');
                     } else {
                         //Tot correcte. Mostrem el llistat de matrícules i el missatge que ha anat bé.
                         $this->MISSATGE3 = "OK";
                     }
                 } else {
                     if ($OM == 1) {
                         $this->MISSATGE3 = "JA_EXISTEIX";
                     } else {
                         $this->MISSATGE3 = "KO";
                     }
                 }
             } else {
                 $this->MISSATGE3 = "CURS_NO_EXISTEIX";
             }
             break;
             //S'ha matriculat correctament i TPV ok
         //S'ha matriculat correctament i TPV ok
         case 'matricula_OK':
             $this->MISSATGE3 = "OK";
             $this->SECCIO = 'MATRICULA';
             break;
             //No s'ha matriculat correctament o error a TPV
         //No s'ha matriculat correctament o error a TPV
         case 'matricula_KO':
             $this->MISSATGE3 = "KO";
             $this->SECCIO = 'MATRICULA';
             break;
             //Gestió del que retorna el TPV
         //Gestió del que retorna el TPV
         case 'GET_TPV':
             //Comprovem que vingui la crida per POST i que la resposta sigui 0000. Tot OK.
             //if( $request->getParameter('Ds_Response') == '0000' )
             if ($request->isMethod() == 'POST' && $request->getParameter('Ds_Response') == '0000') {
                 $idM = $request->getParameter('Ds_MerchantData', null);
                 $OM = MatriculesPeer::retrieveByPK($idM);
                 if ($OM instanceof Matricules) {
                     $from = OptionsPeer::getString('MAIL_FROM', $OM->getSiteId());
                     //Un cop sabem que la matrícula existeix, comprovem la signatura i si és correcta, marquem com a pagat.
                     if (MatriculesPeer::valTPV($request->getParameter('Ds_Amount'), $request->getParameter('Ds_Order'), $request->getParameter('Ds_MerchantCode'), $request->getParameter('Ds_Currency'), $request->getParameter('Ds_Response'), $request->getParameter('Ds_Signature'), OptionsPeer::getString('TPV_PASSWORD', $OM->getSiteid()))) {
                         $MailMat = MatriculesPeer::MailMatricula($OM, $OM->getSiteid());
                         $subject = 'Hospici :: Nova matrícula';
                         $OM->setEstat(MatriculesPeer::ACCEPTAT_PAGAT);
                         $OM->setTpvOperacio($request->getParameter('Ds_AuthorisationCode'));
                         $OM->setTpvOrder($request->getParameter('Ds_Order'));
                         $OM->save();
                         $this->sendMail($from, $OM->getUsuaris()->getEmail(), $subject, $MailMat);
                         $this->sendMail($from, '*****@*****.**', $subject, $MailMat);
                     } else {
                         $this->sendMail($from, '*****@*****.**', 'HASH ERRONI', $idM);
                     }
                 } else {
                     $this->sendMail('*****@*****.**', '*****@*****.**', 'CODI MATRÍCULA ERRONI', $idM);
                 }
             }
             break;
             //Mostra totes les reserves que s'han fet
         //Mostra totes les reserves que s'han fet
         case 'llista_reserves':
             $this->SECCIO = 'RESERVA';
             $this->MISSATGE4 = $request->getParameter('estat', null);
             break;
             //Editem una reserva prèviament feta
         //Editem una reserva prèviament feta
         case 'edita_reserva':
             $this->SECCIO = "RESERVA";
             $OR = ReservaespaisPeer::retrieveByPK($request->getParameter('idR'));
             if ($OR instanceof Reservaespais) {
                 $this->FReserva = new HospiciReservesForm($OR, array('IDS' => $OR->getSiteid()));
                 $this->OPCIONS = 'VISUALITZA';
             } else {
                 $this->redirect('@hospici_llista_reserves');
             }
             break;
             //Creem una nova reserva, i mostrem el formulari
         //Creem una nova reserva, i mostrem el formulari
         case 'nova_reserva':
             $idE = $request->getParameter('idE');
             $OE = EspaisPeer::retrieveByPK($idE);
             $this->SECCIO = 'RESERVA';
             if ($OE instanceof Espais) {
                 $this->FReserva = ReservaespaisPeer::initializeHospici(null, $OE->getSiteid(), $OE->getEspaiid(), $this->getUser()->getSessionPar('idU'));
             } else {
                 $this->MISSATGE4 = "ERROR_ESPAI";
             }
             break;
             //Guardem la nova reserva
         //Guardem la nova reserva
         case 'save_nova_reserva':
             $RP = $request->getParameter('reservaespais');
             $idU = $this->getUser()->getSessionPar('idU');
             $this->SECCIO = 'RESERVA';
             $this->FReserva = ReservaespaisPeer::initializeHospici(null, $RP['site_id'], null, $idU);
             $this->FReserva->bind($RP);
             if ($this->FReserva->isValid()) {
                 //Guardem la reserva
                 $this->FReserva->save();
                 //Enviem mails per informar que s'ha fet una nova reserva d'espais a secretaria
                 $from = OptionsPeer::getString('MAIL_FROM', $RP['site_id']);
                 $to = OptionsPeer::getString('MAIL_SECRETARIA', $RP['site_id']);
                 $sub = "Hospici | Nova reserva d'espai";
                 $miss = "S'ha sol·licitat una nova reserva d'espai amb el codi {$RP['ReservaEspaiID']}";
                 $this->sendMail($from, $to, $sub, $miss);
                 //Vinculem l'usuari amb el site corresponent
                 UsuarisPeer::addSite($idU, $RP['site_id']);
                 $this->redirect('@hospici_llista_reserves?estat=OK');
             } else {
                 $this->MISSATGE4 = 'ERROR_SAVE';
             }
             break;
             //Alta d'un nou formulari
         //Alta d'un nou formulari
         case 'alta_formulari':
             $RP = $request->getParameter('formulari');
             $idU = $this->getUser()->getSessionPar('idU');
             $OF = FormularisRespostesPeer::initialize($RP['idF'], $idU, serialize($RP));
             $OF->save();
             //Enviem mails per informar que s'ha fet una nova reserva d'espais a secretaria
             $from = OptionsPeer::getString('MAIL_FROM', $OF->getSiteid());
             $to = OptionsPeer::getString('MAIL_ADMIN', $OF->getSiteid());
             $sub = "Hospici | Nou formulari enviat";
             $miss = "S'ha enviat la següent informació amb una reserva d'espai.<br/><br />Dades:<br /><br /> ";
             foreach ($RP as $K => $V) {
                 $miss .= $K . ': ' . $V . '<br/>';
             }
             $this->sendMail($from, $to, $sub, $miss);
             $this->sendMail($from, '*****@*****.**', $sub, $miss);
             //Vinculem l'usuari amb el site corresponent
             UsuarisPeer::addSite($idU, $OF->getSiteid());
             $this->MISSATGE6 = 'ALTA_OK';
             $this->SECCIO = "FORMULARIS";
             break;
             //Capturem el que ens arriba del mail de condicions.
         //Capturem el que ens arriba del mail de condicions.
         case 'condicions':
             $this->SECCIO = 'RESERVA';
             $RP = $request->getParameter('reservaespais');
             $idU = $this->getUser()->getSessionPar('idU');
             $OR = ReservaespaisPeer::retrieveByPK($request->getParameter('idR'));
             if ($OR instanceof Reservaespais) {
                 if ($request->hasParameter('B_ACCEPTO')) {
                     $OR->setEstat(ReservaespaisPeer::ACCEPTADA);
                     $OR->setDataacceptaciocondicions(date('Y-m-d', time()));
                     $OR->save();
                     $this->redirect('@hospici_llista_reserves?estat=RESERVA_ACCEPTADA');
                 } elseif ($request->hasParameter('B_NO_ACCEPTO')) {
                     $OR->setEstat(ReservaespaisPeer::ANULADA);
                     $OR->setDataacceptaciocondicions(date('Y-m-d', time()));
                     $OR->save();
                     $this->redirect('@hospici_llista_reserves?estat=RESERVA_ANULADA');
                 } else {
                     $this->redirect('@hospici_llista_reserves?estat=ERROR_TECNIC');
                 }
             } else {
                 $this->redirect('@hospici_llista_reserves?estat=ERROR_TECNIC');
             }
             break;
     }
     //Si ja hi hem fet operacions... carreguem l'actual, sinó en fem un de nou.
     if (isset($FU) && $FU instanceof UsuarisForm) {
         $this->FUsuari = $FU;
     } else {
         $this->FUsuari = UsuarisPeer::initialize($this->IDU, $this->IDS, false, true);
     }
     $this->LMatricules = MatriculesPeer::h_getMatriculesUsuari($this->IDU);
     $this->LReserves = ReservaespaisPeer::h_getReservesUsuaris($this->IDU, $this->IDS);
     $this->LEntrades = EntradesReservaPeer::getEntradesUsuari($this->IDU);
     $this->LFormularis = FormularisRespostesPeer::getFormularisUsuari($this->IDU);
     // $this->LMissatges = MissatgesPeer::getMissatgesUsuari();
 }
 public function executeUsuaris(sfWebRequest $request)
 {
     $this->setLayout('hospici');
     $accio = $request->getParameter('accio', 'inici');
     $this->IDU = $this->getUser()->getSessionPar('idU');
     $this->IDS = SitesPeer::HOSPICI_ID;
     $this->SECCIO = "";
     switch ($accio) {
         case 'inici':
             $this->SECCIO = 'INICI';
             break;
             //Modificació de les dades de l'usuari.
         //Modificació de les dades de l'usuari.
         case 'update':
             $RS = $request->getParameter('usuaris');
             if ($RS['UsuariID'] == $this->IDU) {
                 $FU = UsuarisPeer::initialize($this->IDU, $this->IDS, false, true);
                 $FU->bind($RS);
                 if ($FU->isValid()) {
                     $FU->save();
                     myUser::addLogTimeline('modificacio', 'Usuari (Hospici)', $FU->getObject()->getUsuariId(), 0, $FU->getObject()->getUsuariId());
                     $this->MISSATGE1 = "OK";
                 }
             }
             $this->SECCIO = 'USUARI';
             break;
             //Imprimeix el full de pagament en cas que existeixi.
         //Imprimeix el full de pagament en cas que existeixi.
         case 'printFactura':
             $OER = EntradesReservaPeer::retrieveByPK($request->getParameter('idER'));
             if (!is_null($OER)) {
                 $HTML = EntradesReservaPeer::DocReservaEntrades($OER, $OER->getSiteid());
                 myUser::Html2PDF($HTML);
                 throw new sfStopException();
             }
             //Imprimim el comprovant d'entrada.
             break;
             //Usuari que compra o reserva una entrada
             /*        case 'compra_entrada':            
                         $RA = $request->getParameter('entrades',array());
                                                               
                         $IDH = $RA['idH'];
                         $NEntrades = (int)$RA['num'];
                         $Descompte = (int)$RA['descomptes'];            
                         $TPagament = (int)$RA['tipus_pagament'];
                         
                         $OH = HorarisPeer::retrieveByPK($IDH);
                         
                         //Inicialitzem la reserva i fem el pagament
                         $OER = EntradesReservaPeer::initialize( $OH->getSiteid() , '' , null , $IDH , $this->IDU , $NEntrades , $Descompte , $TPagament )->getObject();
             
                         //Comprem o reservem l'entrada
                         $RET = EntradesReservaPeer::setCompraEntrada( $OER );
                         
                         switch( $RET['status'] ){
                             
                             //(OH incorrecte)
                             case -1:    $this->MISSATGE2 = "HORARI_INCORRECTE";         break;                
                             
                             //(OA incorrecte)
                             case -2:    $this->MISSATGE2 = "ACTIVITAT_INCORRECTE";      break;                
                             
                             //(OEP incorrecte)                
                             case -3:    $this->MISSATGE2 = "PREU_INCORRECTE";           break;                
                             
                             //(Repe)
                             case -4:    $this->MISSATGE2 = "ENTRADA_REPE";              break;                
                             
                             //(Exhaurides)
                             case -5:    $this->MISSATGE2 = "NO_QUEDEN_PROU_ENTRADES";   break;                
                             
                             //(Error TPV)
                             case -6:    $this->MISSATGE2 = "ERROR_TPV";                 break;                
                             
                             //(Es volen comprar 0 entrades)
                             case -7:    $this->MISSATGE2 = "ERROR_MINIM_ENTRADES";      break;                
                             
                             //(Compra metàl·lic o codi de barres OK)
                             case 1:     
                                 $this->MISSATGE2 = "COMPRA_OK";
                                 $this->IDER = $RET['OER']->getIdentrada();                 
                             break;
                                             
                             //(Reserva d\'entrada OK)
                             case 2:     
                                 $this->MISSATGE2 = "RESERVA_OK";                
                                 $this->IDER = $RET['OER']->getIdentrada();
                             break;
                                             
                             //(Pagament amb TPV)
                             case 3:                    
                                 $NOM  = UsuarisPeer::retrieveByPK( $RET['OER']->getUsuariid() )->getNomComplet();
                                 $PREU_TOTAL = $RET['OER']->getPagat() * $RET['OER']->getQuantitat(); 
                     			$this->TPV = MatriculesPeer::getTPV( $PREU_TOTAL , $NOM , $RET['OER']->getIdEntrada() , $RET['OER']->getSiteid() , true , true );
                                 $this->URL = OptionsPeer::getString('TPV_URL',$RET['OER']->getSiteId());                    
                                 $this->setLayout('blanc');
                                 $this->setTemplate('pagament'); 
                             break;
                                             
                             //(En llista d'espera)
                             case 4:     $this->MISSATGE2 = "LLISTA_ESPERA_OK";          break;
                                             
                             //(Pagament amb domiciliació) || Aquest encara s'ha d'aplicar correctament.
                             case 5:     $this->MISSATGE2 = "DOMICILIACIO_OK";           break;
                             
                         }   
                                     
                         $this->SECCIO = 'COMPRA_ENTRADA';
                                                             
                     break;
                     
                     //Usuari que anul·la una entrada prèviament reservada
                     case 'anula_entrada':            
                         $RS = $request->getParameter('idER');
                         $OER = EntradesReservaPeer::retrieveByPK($RS);
                         $idu = $OER->getUsuariid();
                         $act = $OER->getActiu();
                         
                         if($idu == $this->IDU && $act):
                             $OER->setEstat(EntradesReservaPeer::ANULADA);
                             $OER->save();
                         endif;                        
                                                 
                         $this->SECCIO = 'COMPRA_ENTRADA';
                                                             
                     break;        
             */
             //Nova matrícula a un curs
         //Usuari que compra o reserva una entrada
         /*        case 'compra_entrada':            
                     $RA = $request->getParameter('entrades',array());
                                                           
                     $IDH = $RA['idH'];
                     $NEntrades = (int)$RA['num'];
                     $Descompte = (int)$RA['descomptes'];            
                     $TPagament = (int)$RA['tipus_pagament'];
                     
                     $OH = HorarisPeer::retrieveByPK($IDH);
                     
                     //Inicialitzem la reserva i fem el pagament
                     $OER = EntradesReservaPeer::initialize( $OH->getSiteid() , '' , null , $IDH , $this->IDU , $NEntrades , $Descompte , $TPagament )->getObject();
         
                     //Comprem o reservem l'entrada
                     $RET = EntradesReservaPeer::setCompraEntrada( $OER );
                     
                     switch( $RET['status'] ){
                         
                         //(OH incorrecte)
                         case -1:    $this->MISSATGE2 = "HORARI_INCORRECTE";         break;                
                         
                         //(OA incorrecte)
                         case -2:    $this->MISSATGE2 = "ACTIVITAT_INCORRECTE";      break;                
                         
                         //(OEP incorrecte)                
                         case -3:    $this->MISSATGE2 = "PREU_INCORRECTE";           break;                
                         
                         //(Repe)
                         case -4:    $this->MISSATGE2 = "ENTRADA_REPE";              break;                
                         
                         //(Exhaurides)
                         case -5:    $this->MISSATGE2 = "NO_QUEDEN_PROU_ENTRADES";   break;                
                         
                         //(Error TPV)
                         case -6:    $this->MISSATGE2 = "ERROR_TPV";                 break;                
                         
                         //(Es volen comprar 0 entrades)
                         case -7:    $this->MISSATGE2 = "ERROR_MINIM_ENTRADES";      break;                
                         
                         //(Compra metàl·lic o codi de barres OK)
                         case 1:     
                             $this->MISSATGE2 = "COMPRA_OK";
                             $this->IDER = $RET['OER']->getIdentrada();                 
                         break;
                                         
                         //(Reserva d\'entrada OK)
                         case 2:     
                             $this->MISSATGE2 = "RESERVA_OK";                
                             $this->IDER = $RET['OER']->getIdentrada();
                         break;
                                         
                         //(Pagament amb TPV)
                         case 3:                    
                             $NOM  = UsuarisPeer::retrieveByPK( $RET['OER']->getUsuariid() )->getNomComplet();
                             $PREU_TOTAL = $RET['OER']->getPagat() * $RET['OER']->getQuantitat(); 
                 			$this->TPV = MatriculesPeer::getTPV( $PREU_TOTAL , $NOM , $RET['OER']->getIdEntrada() , $RET['OER']->getSiteid() , true , true );
                             $this->URL = OptionsPeer::getString('TPV_URL',$RET['OER']->getSiteId());                    
                             $this->setLayout('blanc');
                             $this->setTemplate('pagament'); 
                         break;
                                         
                         //(En llista d'espera)
                         case 4:     $this->MISSATGE2 = "LLISTA_ESPERA_OK";          break;
                                         
                         //(Pagament amb domiciliació) || Aquest encara s'ha d'aplicar correctament.
                         case 5:     $this->MISSATGE2 = "DOMICILIACIO_OK";           break;
                         
                     }   
                                 
                     $this->SECCIO = 'COMPRA_ENTRADA';
                                                         
                 break;
                 
                 //Usuari que anul·la una entrada prèviament reservada
                 case 'anula_entrada':            
                     $RS = $request->getParameter('idER');
                     $OER = EntradesReservaPeer::retrieveByPK($RS);
                     $idu = $OER->getUsuariid();
                     $act = $OER->getActiu();
                     
                     if($idu == $this->IDU && $act):
                         $OER->setEstat(EntradesReservaPeer::ANULADA);
                         $OER->save();
                     endif;                        
                                             
                     $this->SECCIO = 'COMPRA_ENTRADA';
                                                         
                 break;        
         */
         //Nova matrícula a un curs
         case 'nova_matricula':
             //Gestionem el pagament d'una matrícula.
             $RP = $request->getParameter('matricula');
             $idU = $this->getUser()->getSessionPar('idU');
             $idC = $RP['idC'];
             $idD = $RP['idD'];
             $idP = $RP['idP'];
             $CCC = $RP['iban'] . $RP['ccc1'] . $RP['ccc2'] . $RP['ccc3'] . $RP['ccc4'];
             $titular = $RP['titular'];
             $tutor_dni = $RP['dni_tutor'];
             $tutor_nom = $RP['nom_tutor'];
             $RET = MatriculesPeer::saveNewMatricula($idU, $idC, "Hospici", $idD, $idP);
             $AVISOS = $RET['AVISOS'];
             $this->SECCIO = 'MATRICULA';
             $this->getUser()->addLogAction('SAVE_MATRICULA', 'gMatricules', $RET['OM']->getIdmatricules());
             //Si la matrícula surt amb algun error greu, redireccionem i mostrem un missatge.
             $this->redirectIf(array_key_exists('ERR_USUARI', $AVISOS), 'web/cursos?accio=detall_curs&idC=' . $idC . '&mis=ERR_USUARI');
             $this->redirectIf(array_key_exists('ERR_CURS', $AVISOS), 'web/cursos?accio=detall_curs&idC=' . $idC . '&mis=ERR_CURS');
             $this->redirectIf(array_key_exists('ERR_JA_TE_UNA_MATRICULA', $AVISOS), 'web/cursos?accio=detall_curs&idC=' . $idC . '&mis=ERR_JA_TE_UNA_MATRICULA');
             //Si la matrícula surt amb un error o OK normal, mostrem el missatge.
             if (array_key_exists('CURS_PLE', $AVISOS)) {
                 $this->MISSATGE3 = "CURS_PLE";
             } elseif (array_key_exists('CURS_PLE_LLISTA_ESPERA', $AVISOS)) {
                 $this->MISSATGE3 = "CURS_PLE_LLISTA_ESPERA";
             } elseif (array_key_exists('RESERVA_OK', $AVISOS)) {
                 $this->MISSATGE3 = "OK";
             } elseif (array_key_exists('MATRICULA_METALIC_OK', $AVISOS)) {
                 $this->MISSATGE3 = 'OK';
             } elseif (array_key_exists('MATRICULA_DOMICILIACIO_OK', $AVISOS)) {
                 $this->MISSATGE3 = 'OK';
             } elseif (array_key_exists('MATRICULA_CODI_BARRES', $AVISOS)) {
                 $this->MISSATGE3 = 'OK';
             }
             //Si la matrícula es paga amb TPV posem les dades per a fer el pagament.
             if (array_key_exists('PAGAMENT_TPV', $AVISOS)) {
                 $NOM = UsuarisPeer::retrieveByPK($RET['OM']->getUsuarisUsuariid())->getNomComplet();
                 $this->TPV = MatriculesPeer::getTPV($RET['OM']->getPagat(), $NOM, $RET['OM']->getIdmatricules(), $RET['OM']->getSiteid(), true);
                 $this->URL = OptionsPeer::getString('TPV_URL', $RET['OM']->getSiteId());
                 $this->setLayout('blanc');
                 $this->setTemplate('pagament');
             }
             //Si el pagament és amb domiciliació, hem d'afegir el compte corrent i després el podrem donar per validada.
             if (array_key_exists('MATRICULA_DOMICILIACIO_OK', $AVISOS)) {
                 //Consultem el curs per saber el Siteid
                 $OC = CursosPeer::retrieveByPK($idC);
                 //Afegim el compte corrent
                 $ODB = DadesBancariesPeer::addCCC($CCC, $OC->getSiteId(), $idU, "", $titular);
                 $RET['OM']->setIddadesbancaries($ODB->getIddada());
                 $RET['OM']->save();
             }
             //Si tenim dades del tutor, les guardem.
             if (!empty($tutor_dni) || !empty($tutor_nom)) {
                 $RET['OM']->setTutordni($tutor_dni);
                 $RET['OM']->setTutornom($tutor_nom);
                 $RET['OM']->save();
             }
             if (empty($this->MISSATGE3)) {
                 $this->MISSATGE3 = "KO";
             }
             //Si no hi ha cap error i no és un pagament amb targeta, marquem com a matrícula feta
             if ($this->MISSATGE3 == 'OK' && !array_key_exists('PAGAMENT_TPV', $AVISOS)) {
                 myUser::addLogTimeline('alta', 'Matricules (Hospici)', $RET['OM']->getUsuarisUsuariid(), $RET['OM']->getSiteId(), $RET['OM']->getIdmatricules());
             }
             break;
             //S'ha matriculat correctament i TPV ok
         //S'ha matriculat correctament i TPV ok
         case 'matricula_OK':
             $this->MISSATGE3 = "OK";
             $this->SECCIO = 'MATRICULA';
             break;
             //No s'ha matriculat correctament o error a TPV
         //No s'ha matriculat correctament o error a TPV
         case 'matricula_KO':
             $this->MISSATGE3 = "KO";
             $this->SECCIO = 'MATRICULA';
             break;
             //Mostra totes les reserves que s'han fet
         //Mostra totes les reserves que s'han fet
         case 'llista_reserves':
             $this->SECCIO = 'RESERVA';
             $this->MISSATGE4 = $request->getParameter('estat', null);
             break;
             //Editem una reserva prèviament feta
         //Editem una reserva prèviament feta
         case 'edita_reserva':
             $this->SECCIO = "RESERVA";
             $OR = ReservaespaisPeer::retrieveByPK($request->getParameter('idR'));
             if ($OR instanceof Reservaespais) {
                 $this->FReserva = new HospiciReservesForm($OR, array('IDS' => $OR->getSiteid()));
                 $this->OPCIONS = 'VISUALITZA';
             } else {
                 $this->redirect('@hospici_llista_reserves');
             }
             break;
             //Creem una nova reserva, i mostrem el formulari
         //Creem una nova reserva, i mostrem el formulari
         case 'nova_reserva':
             $idE = $request->getParameter('idE');
             $OE = EspaisPeer::retrieveByPK($idE);
             $this->SECCIO = 'RESERVA';
             if ($OE instanceof Espais) {
                 $this->FReserva = ReservaespaisPeer::initializeHospici(null, $OE->getSiteid(), $OE->getEspaiid(), $this->getUser()->getSessionPar('idU'));
             } else {
                 $this->MISSATGE4 = "ERROR_ESPAI";
             }
             break;
             //Guardem la nova reserva
         //Guardem la nova reserva
         case 'save_nova_reserva':
             $RP = $request->getParameter('reservaespais');
             $EP = $request->getParameter('extres');
             $idU = $this->getUser()->getSessionPar('idU');
             $this->SECCIO = 'RESERVA';
             $this->FReserva = ReservaespaisPeer::initializeHospici(null, $RP['site_id'], null, $idU);
             $this->FReserva->bind($RP);
             if ($this->FReserva->isValid()) {
                 //Guardem la reserva
                 $this->FReserva->save();
                 $ORE = $this->FReserva->getObject();
                 //A partir d'aquí guardem camps extres que surten del formulari
                 $ORE->setHasDifusio($EP['sidifu']);
                 $ORE->setWebDescripcio($EP['descweb']);
                 $ORE->save();
                 $Img = $request->getFiles('img');
                 $Pdf = $request->getFiles('pdf');
                 $nom_img_final = getcwd() . '/uploads/arxius/' . 'RE-' . $ORE->getReservaespaiid() . '-IMG-' . $Img['name'];
                 $nom_pdf_final = getcwd() . '/uploads/arxius/' . 'RE-' . $ORE->getReservaespaiid() . '-PDF-' . $Pdf['name'];
                 move_uploaded_file($Img['tmp_name'], $nom_img_final);
                 move_uploaded_file($Pdf['tmp_name'], $nom_pdf_final);
                 //Finalitzem l'emmagatzematge
                 $idReserva = $this->FReserva->getObject()->getReservaespaiid();
                 //Enviem mails per informar que s'ha fet una nova reserva d'espais a secretaria
                 $from = OptionsPeer::getString('MAIL_FROM', $RP['site_id']);
                 $to = OptionsPeer::getString('MAIL_SECRETARIA', $RP['site_id']);
                 $sub = "Hospici | Nova reserva d'espai";
                 $miss = "S'ha sol·licitat una nova reserva d'espai amb el codi {$idReserva}";
                 $this->sendMail($from, $to, $sub, $miss);
                 //Guardem el registre al timeline
                 myUser::addLogTimeline('alta', 'Reserva (Hospici)', $idU, $RP['site_id'], $this->FReserva->getObject()->getReservaespaiid());
                 //Vinculem l'usuari amb el site corresponent
                 UsuarisPeer::addSite($idU, $RP['site_id']);
                 $this->redirect('@hospici_llista_reserves?estat=OK');
             } else {
                 $this->MISSATGE4 = 'ERROR_SAVE';
             }
             break;
             //Alta d'un nou formulari
         //Alta d'un nou formulari
         case 'alta_formulari':
             $RP = $request->getParameter('formulari');
             $idU = $this->getUser()->getSessionPar('idU');
             $OF = FormularisRespostesPeer::initialize($RP['idF'], $idU, serialize($RP));
             $OF->save();
             //Enviem mails per informar que s'ha fet una nova reserva d'espais a secretaria
             $from = OptionsPeer::getString('MAIL_FROM', $OF->getSiteid());
             $to = OptionsPeer::getString('MAIL_ADMIN', $OF->getSiteid());
             $sub = "Hospici | Nou formulari enviat";
             $miss = "S'ha enviat la següent informació amb una reserva d'espai.<br/><br />Dades:<br /><br /> ";
             foreach ($RP as $K => $V) {
                 $miss .= $K . ': ' . $V . '<br/>';
             }
             $this->sendMail($from, $to, $sub, $miss);
             $this->sendMail($from, '*****@*****.**', $sub, $miss);
             //Vinculem l'usuari amb el site corresponent
             UsuarisPeer::addSite($idU, $OF->getSiteid());
             $this->MISSATGE6 = 'ALTA_OK';
             $this->SECCIO = "FORMULARIS";
             break;
             //Capturem si accepta o no accepta les condicions des del seu usuari.
         //Capturem si accepta o no accepta les condicions des del seu usuari.
         case 'condicions':
             $this->SECCIO = 'RESERVA';
             $RP = $request->getParameter('reservaespais');
             $idU = $this->getUser()->getSessionPar('idU');
             $OR = ReservaespaisPeer::retrieveByPK($request->getParameter('idR'));
             if ($OR instanceof Reservaespais) {
                 if ($request->hasParameter('B_ACCEPTO')) {
                     $OR->setEstat(ReservaespaisPeer::ACCEPTADA);
                     $OR->setDataacceptaciocondicions(date('Y-m-d', time()));
                     $OR->save();
                     myUser::addLogTimeline('acceptada', 'Reserva (Hospici)', $idU, $OR->getSiteId(), $OR->getReservaespaiid());
                     //Enviem un mail a secretaria informant de l'acceptació de les condicions
                     $this->sendMail(OptionsPeer::getString('MAIL_FROM', $OR->getSiteid()), OptionsPeer::getString('MAIL_SECRETARIA', $OR->getSiteid()), "RESERVA " . $OR->getCodi() . " ACCEPTADA", "Les condicions per a la reserva amb codi " . $OR->getCodi() . " organitzada per " . $OR->getOrganitzadors() . " han estat <b>ACCEPTADES</b>. <br /> Per poder accedir-hi podeu clicar el següent <a href=\"http://www.casadecultura.cat/gestio/gReserves/accio/E/IDR/" . $OR->getReservaespaiid() . "\">enllaç</a> havent entrat prèviament a la intranet.");
                     $this->redirect('@hospici_llista_reserves?estat=RESERVA_ACCEPTADA');
                 } elseif ($request->hasParameter('B_NO_ACCEPTO')) {
                     $OR->setEstat(ReservaespaisPeer::ANULADA);
                     $OR->setDataacceptaciocondicions(date('Y-m-d', time()));
                     $OR->save();
                     myUser::addLogTimeline('no_acceptada', 'Reserva (Hospici)', $idU, $OR->getSiteId(), $OR->getReservaespaiid());
                     //Enviem un mail a secretaria informant del rebuig de les condicions
                     $this->sendMail(OptionsPeer::getString('MAIL_FROM', $OR->getSiteid()), OptionsPeer::getString('MAIL_SECRETARIA', $OR->getSiteid()), "RESERVA " . $OR->getCodi() . " REBUTJADA", "Les condicions per a la reserva amb codi " . $OR->getCodi() . " organitzada per " . $OR->getOrganitzadors() . " han estat <b>REBUTJADES</b>. <br /> Per poder accedir-hi podeu clicar el següent <a href=\"http://www.casadecultura.cat/gestio/gReserves/accio/E/IDR/" . $OR->getReservaespaiid() . "\">enllaç</a> havent entrat prèviament a la intranet.");
                     $this->redirect('@hospici_llista_reserves?estat=RESERVA_ANULADA');
                 } else {
                     $this->redirect('@hospici_llista_reserves?estat=ERROR_TECNIC');
                 }
             } else {
                 $this->redirect('@hospici_llista_reserves?estat=ERROR_TECNIC');
             }
             break;
     }
     //Si ja hi hem fet operacions... carreguem l'actual, sinó en fem un de nou.
     if (isset($FU) && $FU instanceof UsuarisForm) {
         $this->FUsuari = $FU;
     } else {
         $this->FUsuari = UsuarisPeer::initialize($this->IDU, $this->IDS, false, true);
     }
     $this->LMatricules = MatriculesPeer::h_getMatriculesUsuari($this->IDU);
     $this->LReserves = ReservaespaisPeer::h_getReservesUsuaris($this->IDU, $this->IDS);
     //$this->LEntrades = EntradesReservaPeer::getEntradesUsuari($this->IDU);
     $this->LFormularis = FormularisRespostesPeer::getFormularisUsuari($this->IDU);
     $file = fopen(OptionsPeer::getString('SF_WEBSYSROOT', 1) . 'documents/Notes-1.csv', "r");
     $RET = array();
     $FIRST = true;
     $DNI = $this->FUsuari->getObject()->getDni();
     if ($file) {
         while (($data = fgetcsv($file, 0, ";", '"')) !== FALSE) {
             if (!$FIRST && strtoupper($DNI) == strtoupper($data[4])) {
                 $RET[] = array_map("utf8_encode", $data);
             }
             $FIRST = false;
         }
         fclose($file);
         $this->LResultats = $RET;
     } else {
         $this->LResultats = array();
     }
 }