public function reservationAction() { $em = $this->getDoctrine()->getManager(); $request = $this->getRequest(); $user = $this->get('security.context')->getToken()->getUser(); if ($this->container->get('security.context')->isGranted('IS_AUTHENTICATED_FULLY') && !is_null($user->getClient())) { $client = $user->getClient(); } else { $client = $this->container->get('users')->getPassager(); } $reservation = new MaritimeReservation(); $reservation->setClient($client)->setNomPrenom($client->getNomPrenom())->setTel($client->getTel1()); if (!is_null($client->getUser())) { $reservation->setEmail($client->getUser()->getEmail()); } $form = $this->createForm(new MaritimeReservationType(), $reservation); if ($request->isMethod('POST')) { $form->submit($request); if ($form->isValid()) { $reservation = $form->getData(); $em->persist($reservation->setEtat(1)->setFrontOffice(1)); $em->flush(); return $this->redirect($this->generateUrl('front_maritime_succees', array('id' => $reservation->getId()))); } } return $this->render('FrontGeneralBundle:maritime:reservation.html.twig', array('csrf_token' => $this->container->get('form.csrf_provider')->generateCsrfToken('authenticate'), 'form' => $form->createView())); }
public function validerAction(MaritimeReservation $reservation) { $user = $this->get('security.context')->getToken()->getUser(); $em = $this->getDoctrine()->getManager(); $request = $this->getRequest(); $session = $this->getRequest()->getSession(); $pieces = $em->getRepository('BackCommercialBundle:Piece')->findBy(array('client' => $reservation->getClient(), 'regle' => FALSE)); if ($user->getId() != $reservation->getResponsable()->getId() || $reservation->getEtat() == 2) { return $this->redirect($this->generateUrl("back_maritime_reservation_consultation", array('id' => $reservation->getId()))); } $form = $this->createFormBuilder()->add("piece", new PieceType()); foreach ($pieces as $piece) { $form->add('piece' . $piece->getId(), 'checkbox', array('label' => $piece->getNumero(), 'required' => FALSE)); } $form = $form->getForm(); if ($request->isMethod("POST")) { $form->submit($request); $data = $form->getData(); foreach ($pieces as $piece) { if ($data['piece' . $piece->getId()] && $reservation->getMontantRestant() > 0) { $reglement = new Reglement(); if ($piece->getMontant() <= $reservation->getMontantRestant()) { $reglement->setMontant($piece->getMontant()); $em->persist($piece->setRegle(TRUE)->setDateReglement(new \DateTime())->setMontant(0)); } else { $reglement->setMontant($reservation->getMontantRestant()); $em->persist($piece->setMontant($piece->getMontant() - $reservation->getMontantRestant())); } $reglement->setPiece($piece); $reglement->setReservationMaritime($reservation); $reglement->setDateCreation(new \DateTime()); $em->persist($reglement); $reservation->addReglement($reglement); } } if ($reservation->getMontantRestant() > 0 && !is_null($data['piece']->getModeReglement()) && !is_null($data['piece']->getMontantOrigine())) { if ($data['piece']->getMontantOrigine() > 0) { $reglement = new Reglement(); $piece = $data['piece']; $piece->setClient($reservation->getClient())->setDateCreation(new \DateTime()); if ($piece->getMontantOrigine() <= $reservation->getMontantRestant()) { $reglement->setMontant($piece->getMontantOrigine()); $em->persist($piece->setRegle(TRUE)->setDateReglement(new \DateTime())->setMontant(0)); } else { $reglement->setMontant($reservation->getMontantRestant()); $em->persist($piece->setRegle(FALSE)->setMontant($piece->getMontantOrigine() - $reservation->getMontantRestant())); } $reglement->setPiece($piece); $reglement->setReservationMaritime($reservation); $reglement->setDateCreation(new \DateTime()); $em->persist($reglement); $reservation->addReglement($reglement); $session->getFlashBag()->add('success', "Votre piéce a été ajoutée avec succès"); } else { $session->getFlashBag()->add('danger', "Le montant de la piéce doit étre suppérieure à 0"); } } if ($reservation->getMontantRestant() == 0) { $em->persist($reservation->setEtat(2)->setValidated(new \DateTime())); $em->flush(); $session->getFlashBag()->add('success', " Votre Réservation a été validée avec succès "); $this->container->get('mailerservice')->validation($reservation, 'M'); return $this->redirect($this->generateUrl("back_maritime_reservation_consultation", array('id' => $reservation->getId()))); } else { $session->getFlashBag()->add('info', " Votre Réservation n'a pas été encore validée, reste encore <strong>" . $reservation->getMontantRestant() . " DT </strong> a payé"); } $em->flush(); return $this->redirect($this->generateUrl("back_maritime_reservation_validation", array('id' => $reservation->getId()))); } return $this->render('BackBilletterieMaritimeBundle:maritime:validation.html.twig', array('reservation' => $reservation, 'form' => $form->createView(), 'pieces' => $pieces)); }