예제 #1
0
 /**
  * Funció que permet gestionar la venta d'entrades
  *   
  * */
 public function executeGEntrades(sfWebRequest $request)
 {
     $this->setLayout('gestio');
     $this->IDS = $this->getUser()->getSessionPar('idS');
     $this->P = $this->getUser()->ParReqSesForm($request, 'P', 1);
     $this->URL = $this->getController()->genUrl('gestio/ajaxUsuaris', true);
     $accio = $request->getParameter('accio', 'LH');
     //Treiem el llistat d'activitats amb les entrades venudes i tmabé els seus horaris si n'hi ha. Aquí només visualitzem... si hem de modificar clicquem un enllaç cap al calendari.
     switch ($accio) {
         //Llista els que han reservat
         case 'LR':
             $this->MODE = 'LLISTA_ENTRADES';
             $this->LLISTAT_ENTRADES = EntradesReservaPeer::getEntradesVenudes($request->getParameter('IDA'), $request->getParameter('IDH'), true);
             $this->LLISTAT_ENTRADES_ANULADES = EntradesReservaPeer::getEntradesNoComptades($request->getParameter('IDA'), $request->getParameter('IDH'));
             break;
             //Anul·la la reserva
         //Anul·la la reserva
         case 'AR':
             $IDR = $request->getParameter('IDR');
             $IDA = 0;
             try {
                 $OR = EntradesReservaPeer::retrieveByPK($IDR);
                 $OR->setEstat(EntradesReservaPeer::ESTAT_ENTRADA_ANULADA);
                 $OR->save();
                 $IDH = $OR->getEntradesPreusHorariId();
             } catch (Exception $e) {
             }
             $this->MODE = 'LLISTA_ENTRADES';
             $this->redirect('gestio/gEntrades?accio=LR&IDH=' . $IDH);
             break;
             //Compra o reserva d'una entrada
         //Compra o reserva d'una entrada
         case 'VE':
             $this->MODE = 'EDITA_ENTRADA';
             //Comprem una entrada o guardem una modificació.
             if ($request->hasParameter('BRESERVASAVE')) {
                 $RS = $request->getParameter('entrades_reserva');
                 $this->FReserva = EntradesReservaPeer::initialize($this->IDS, $this->URL, $RS['idEntrada'], $RS['entrades_preus_horari_id']);
                 $this->FReserva->bind($RS);
                 if ($this->FReserva->isValid()) {
                     try {
                         $is_new = $this->FReserva->isNew();
                         $RET = $this->FReserva->saveMy();
                         $OER = $RET['OER'];
                         //Si hem pagat amb targeta
                         switch ($RET['status']) {
                             //Hem fet una actualització de l'entrada
                             case 0:
                                 $this->redirect('gestio/gEntrades?accio=LR&IDH=' . $OER->getEntradesPreusHorariId());
                                 break;
                                 //Compra en metàl·lic o targeta
                             //Compra en metàl·lic o targeta
                             case 1:
                                 $this->redirect('gestio/gEntrades?accio=OK&code=FACT&Ds_MerchantData=' . $OER->getIdentrada());
                                 break;
                                 //Reserva d'entrada ok
                             //Reserva d'entrada ok
                             case 2:
                                 $this->redirect('gestio/gEntrades?accio=OK&code=FACT&Ds_MerchantData=' . $OER->getIdentrada());
                                 break;
                                 //Pagament amb TPV
                             //Pagament amb TPV
                             case 3:
                                 if ($is_new) {
                                     $this->TPV = MatriculesPeer::getTPV($OER->getPagat(), $OER->getNomUsuari(), $OER->getIdentrada(), $OER->getSiteId(), false, true);
                                     $this->URL = OptionsPeer::getString('TPV_URL', $OER->getSiteId());
                                     $this->setLayout('blank');
                                     $this->setTemplate('pagament');
                                 }
                                 break;
                                 //En llista d'espera
                             //En llista d'espera
                             case 4:
                                 $this->redirect('gestio/gEntrades?accio=OK&code=LLISTA_ESPERA&Ds_MerchantData=' . $OER->getIdentrada());
                                 break;
                                 //Domiciliació
                             //Domiciliació
                             case 5:
                                 $this->redirect('gestio/gEntrades?accio=OK&code=DOMICILIACIO&Ds_MerchantData=' . $OER->getIdentrada());
                                 break;
                         }
                     } catch (Exception $e) {
                         $this->MISSATGE = $e->getMessage();
                     }
                 }
             } else {
                 $IDR = $request->getParameter('IDR', 0);
                 $IDH = $request->getParameter('IDH', 0);
                 $this->FReserva = EntradesReservaPeer::initialize($this->IDS, $this->URL, $IDR, $IDH, 0);
             }
             break;
             //Un cop hem fet una compra d'una entrada, hem de mostrar aquesta pantalla.
         //Un cop hem fet una compra d'una entrada, hem de mostrar aquesta pantalla.
         case 'OK':
             $this->idER = $request->getParameter('Ds_MerchantData', 0);
             $OER = EntradesReservaPeer::retrieveByPK($this->idER);
             if ($OER instanceof EntradesReserva) {
                 switch ($request->getParameter('code')) {
                     case 'FACT':
                         $this->MISSATGE = "ENTRADA_METALIC";
                         break;
                     case 'LLISTA_ESPERA':
                         $this->MISSATGE = "ENTRADA_LLISTA_ESPERA";
                         break;
                     case 'DOMICILIACIO':
                         $this->MISSATGE = "ENTRADA_DOMICILIACIO";
                         break;
                     case 'TPV':
                         $this->MISSATGE = "ENTRADA_OK";
                         break;
                 }
                 $email = $OER->getEmail();
                 $MailEnt = EntradesReservaPeer::DocReservaEntrades($OER, $OER->getSiteId());
                 if ($email != "") {
                     $this->sendMail($from, $email, $subject, $MailEnt);
                 }
                 $this->sendMail($from, OptionsPeer::getString('MAIL_ADMIN', $idS), $subject, $MailEnt);
             } else {
                 $this->MISSATGE = "ENTRADA_NO_TROBADA";
             }
             $this->MODE = 'MISSATGE';
             break;
         case 'KO':
             $this->MISSATGE = "PROBLEMA_PAGANT";
             $this->MODE = 'MISSATGE';
             break;
         case 'PRINT':
             $idER = $request->getParameter('idER');
             $OER = EntradesReservaPeer::retrieveByPK($idER);
             $HTML = EntradesReservaPeer::DocReservaEntrades($OER, $this->IDS);
             myUser::Html2PDF($HTML);
             throw new sfStopException();
             break;
         case 'PRINT_LLISTAT':
             $HTML = EntradesReservaPeer::DocLlistatEntrades($request->getParameter('IDH'), $request->getParameter('IDA'), $this->IDS);
             myUser::Html2PDF($HTML);
             throw new sfStopException();
             break;
             //Llisto els horaris que disposen d'entrades
         //Llisto els horaris que disposen d'entrades
         default:
             //Agafo els horaris que tenen entrades a la venta i els ordeno per data
             $this->LLISTAT_ENTRADES_PREUS = EntradesPreusPeer::getActivitatsAmbEntrades($this->IDS, $this->P);
             $this->MODE = "LLISTA_ACTIVITATS";
             break;
     }
 }
예제 #2
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();
                     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();
     }
 }