src/Controller/GestionComerciale/ConcurrenceController.php line 206

Open in your IDE?
  1. <?php
  2. namespace App\Controller\GestionComerciale;
  3. use App\Entity\GestionComerciale\Commande;
  4. use App\Entity\GestionComerciale\Concurrence;
  5. use App\Form\GestionComerciale\SupprimerConcurrenceType;
  6. use App\Form\GestionComerciale\ConcurrenceType;
  7. use App\Library\Datatable\Util\Datatable;
  8. use App\Security\Voter\EntityVoter;
  9. use Doctrine\ORM\EntityManagerInterface;
  10. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  11. use Symfony\Component\HttpFoundation\Request;
  12. use Symfony\Component\HttpFoundation\JsonResponse;
  13. use Symfony\Component\HttpFoundation\Response;
  14. use Symfony\Component\Routing\Annotation\Route;
  15. use Symfony\Component\Validator\Validator\ValidatorInterface;
  16. use Symfony\Contracts\Translation\TranslatorInterface;
  17. class ConcurrenceController extends AbstractController
  18. {
  19.     
  20.     /**
  21.      * @Route("/concurrence-commande/nouveau/{id}/{type}", name="dtc_concurrence_commande_ajouter")
  22.      */
  23.     public function ajouterAction(Request $request$id,$type=""EntityManagerInterface $emTranslatorInterface $translatorValidatorInterface $validator)
  24.     {
  25.            $url "";
  26.         $titre_modal =$translator->trans("Nouvelle concurrence");
  27.         $repo_objet $em->getRepository(Commande::class);
  28.         $get $request->query->all();
  29.         $concurrence = new Concurrence();
  30.             
  31.         $objet $repo_objet->find($id);
  32.         if(is_object($objet)){
  33.             $concurrence->setCommande($objet);
  34.             //$concurrence->setLibelle($objet->getLibelle());
  35.         }
  36.             
  37.         $user $this->getUser();
  38.         //$concurrence->setUtilisateur($user);
  39.         $form $this->createForm(ConcurrenceType::class, $concurrence);
  40.         $errors "";
  41.         $form->handleRequest($request);
  42.         if ($form->isSubmitted()) {
  43.             if ($form->isValid()) {
  44.          
  45.                 $em->persist($concurrence);
  46.                 $em->flush();
  47.                 if (array_key_exists('table'$get) && $get["table"]!="") {
  48.                       return new JsonResponse(['rendu' =>'''valide' =>'1''url' =>$url'type' =>'recharger_datatable''id_datatable' =>$get["table"]]);
  49.                   }
  50.                   else {
  51.                   $this->addFlash('notice',$translator->trans('Concurrence ajoutée avec succès !'));
  52.                   return new JsonResponse(['rendu' =>'''valide' =>'1''url' =>$url]);
  53.                   }   
  54.             }
  55.             else {
  56.                 $errors $validator->validate($concurrence);
  57.                 $rendu $this->renderView('GestionComerciale/Concurrence/ajouter.html.twig', ['form' => $form->createView(), 'errors' =>$errors'id' =>$id'type' =>$type'concurrence' =>$concurrence]
  58.                 );
  59.                 return new JsonResponse(['rendu' =>$rendu'valide' =>'0''url' =>'''titre' =>$titre_modal]);
  60.             }
  61.         }        
  62.         $rendu $this->renderView('GestionComerciale/Concurrence/ajouter.html.twig', ['form' => $form->createView(), 'errors' =>$errors'id' =>$id'type' =>$type'concurrence' =>$concurrence]
  63.         );
  64.         return new JsonResponse(['rendu' =>$rendu'valide' =>'0''url' =>'''titre' =>$titre_modal]);
  65.         //return $this->render('GestionComerciale/Concurrence/ajouter.html.twig', array('form' => $form->createView(),'errors'=>$errors,'id'=>$id,'type'=>$type));
  66.     }
  67.     
  68.     /**
  69.      * @Route("/concurrence-commande/modifier/{objet}/{id}/{type}", name="dtc_concurrence_commande_modifier")
  70.      */
  71.     public function modifierAction(Request $requestConcurrence $objet,$id,$typeEntityManagerInterface $emTranslatorInterface $translatorValidatorInterface $validator)
  72.     {
  73.         $url "";
  74.         $concurrence $objet;
  75.         $titre_modal =$translator->trans("Modifier la concurrence");
  76.         $get $request->query->all();
  77.         $user $this->getUser();
  78.         //$concurrence->setUtilisateur($user);
  79.         $form $this->createForm(ConcurrenceType::class, $concurrence);
  80.         $errors "";
  81.         $form->handleRequest($request);
  82.         if ($form->isSubmitted()) {
  83.             
  84.             $droit $this->isGranted(EntityVoter::UPDATEConcurrence::class);
  85.             /*
  86.             if(!$droit) {
  87.                 $rendu = $this->renderView('GestionComerciale/Concurrence/ajouter.html.twig', array('form' => $form->createView(),'errors'=>$errors,'id'=>$id,'type'=>$type,'objet'=>$objet));
  88.                 return new Response(json_encode(array('rendu'=>$rendu,'valide'=>'0','url'=>'','titre'=>$titre_modal)), 200, array('Content-Type'=>'application/json'));
  89.             }
  90.             */
  91.             if ($form->isValid()) {
  92.                 
  93.                 $em->persist($concurrence);
  94.                 $em->flush();
  95.                       
  96.                 if (array_key_exists('table'$get) && $get["table"]!="") {
  97.                       return new JsonResponse(['rendu' =>'''valide' =>'1''url' =>$url'type' =>'recharger_datatable''id_datatable' =>$get["table"]]);
  98.                   }
  99.                   else {
  100.                   $this->addFlash('notice',$translator->trans('Concurrence modifiée avec succès !'));
  101.                   return new JsonResponse(['rendu' =>'''valide' =>'1''url' =>$url]);
  102.                   }
  103.             }
  104.             else {
  105.                 $errors $validator->validate($concurrence);
  106.                 $rendu $this->renderView('GestionComerciale/Concurrence/ajouter.html.twig', ['form' => $form->createView(), 'errors' =>$errors'id' =>$id'type' =>$type'objet' =>$objet'concurrence' =>$concurrence]
  107.                 );
  108.                 return new JsonResponse(['rendu' =>$rendu'valide' =>'0''url' =>'''titre' =>$titre_modal]);
  109.   
  110.             }
  111.         }        
  112.         $rendu $this->renderView('GestionComerciale/Concurrence/ajouter.html.twig', ['form' => $form->createView(), 'errors' =>$errors'id' =>$id'type' =>$type'objet' =>$objet'concurrence' =>$concurrence]
  113.         );
  114.         return new JsonResponse(['rendu' =>$rendu'valide' =>'0''url' =>'''titre' =>$titre_modal]);
  115.     }
  116.     /**
  117.      * @Route("/concurrence-commande/supprimer/{objet}/{id}/{type}", name="dtc_concurrence_commande_supprimer")
  118.      */
  119.     public function supprimerAction(Request $requestConcurrence $objet,$id,$typeEntityManagerInterface $emTranslatorInterface $translatorValidatorInterface $validator) {
  120.         
  121.         $concurrence $objet;
  122.         $titre_modal =$translator->trans("Demande de confirmation");
  123.         $get $request->query->all();
  124.         $user $this->getUser();
  125.         $form $this->createForm(SupprimerConcurrenceType::class, $concurrence);
  126.         $errors "";
  127.         $form->handleRequest($request);
  128.         if ($form->isSubmitted()) {
  129.             
  130.             if ($form->isValid()) {
  131.                 $em->remove($concurrence);
  132.                 $em->flush();                    
  133.                 $url "";                
  134.                 if (array_key_exists('table'$get) && $get["table"]!="") {
  135.                       return new JsonResponse(['rendu' =>'''valide' =>'1''url' =>$url'type' =>'recharger_datatable''id_datatable' =>$get["table"]]);
  136.                   }
  137.                   else {
  138.                   $this->addFlash('notice',$translator->trans('Concurrence supprimée avec succès !'));
  139.                   return new JsonResponse(['rendu' =>'''valide' =>'1''url' =>$url]);
  140.                   }
  141.             }
  142.             else {                 
  143.                 $errors $validator->validate($concurrence);
  144.                 $rendu $this->renderView('FO/Supprimer/supprimer.html.twig', ['form' => $form->createView(), 'errors' =>$errors'id' =>$id'type' =>$type'objet' =>$objet]);
  145.                 return new JsonResponse(['rendu' =>$rendu'valide' =>'0''url' =>'''titre' =>$titre_modal]);
  146.             }
  147.         }
  148.         $rendu $this->renderView('FO/Supprimer/supprimer.html.twig', ['form' => $form->createView(), 'errors' =>$errors'id' =>$id'type' =>$type'objet' =>$objet]);
  149.         return new JsonResponse(['rendu' =>$rendu'valide' =>'0''url' =>'''titre' =>$titre_modal]);
  150.     }
  151.     /**
  152.      * @Route("/concurrence-commande/charger-tableau/{id}/{type}", name="dtc_concurrence_commande_charger_tableau")
  153.      */
  154.     public function chargerTableauAction(Request $request$id="0",$type="a") {
  155.                       
  156.            $rendu $this->renderView('GestionComerciale/Concurrence/charger_tableau.html.twig', ["id" =>$id"type" =>$type]);
  157.         return new JsonResponse(['rendu' =>$rendu], 200, ['Content-Type' =>'application/json']);
  158.       
  159.        }
  160.     
  161.     /**
  162.      * @Route("/concurrence-commande", name="dtc_concurrence_commande_liste")
  163.      */
  164.     public function listerAction(Request $request$id="0",$type="a"EntityManagerInterface $emDatatable $datatableTranslatorInterface $translator)
  165.     {                
  166.         $tableau_class_cellule = [];
  167.         $tableau_class_cellule[]= ["searchable" => false"className" =>"visible_export colonne_id text-center""targets" => [0], "visible" =>true];
  168.         $tableau_class_cellule[]= ["searchable" => false"className" =>"visible_export colonne_id ""targets" => [1], "visible" =>true];
  169.         $tableau_class_cellule[]= ["searchable" => false"className" =>"visible_export colonne_id text-right""targets" => [2], "visible" =>true];
  170.         $tableau_class_cellule[]= ["searchable" => false"className" =>"visible_export colonne_id text-right""targets" => [3], "visible" =>true];
  171.         $tableau_class_cellule[]= ["orderable" =>false"searchable" => false"className" =>"visible_export colonne_id""targets" => [4], "visible" =>true];
  172.             
  173.         $modal $request->query->get('modal');        
  174.         $qte $request->query->get('qte');
  175.         if($type == "commande")  $repo_objet $em->getRepository(Commande::class);
  176.         $objet $repo_objet->find($id);     
  177.         if(is_object($objet)) {                
  178.             if($type == "commande") {                    
  179.                 $this->datatableCommande($objet,$type$datatable$translator);
  180.             }                
  181.             return $this->render('GestionComerciale/Concurrence/lister.html.twig', ['tableauClassColonne' =>$tableau_class_cellule"id" =>$id"type" =>$type]);
  182.         }            
  183.     }    
  184.     
  185.     
  186.     /**
  187.      * set datatable configs
  188.      *
  189.      * @return \App\Library\Datatable\Util\Datatable
  190.      */
  191.     private function datatableCommande($objet,$type=""Datatable $datatableTranslatorInterface $translator)
  192.     {
  193.         $type_jointure 'x.'.$type;
  194.         $datatable  ->setDatatableId('dta-concurrence')
  195.                     ->setEntity(Concurrence::class, "x")
  196.                     ->setFields(
  197.                         [
  198.                                 //$translator->trans("ID") =>  'x.id',
  199.                                $translator->trans("Date") =>  'x.date',
  200.                                $translator->trans("Date offre") =>  'x.dateOffre',
  201.                                $translator->trans("Concurrent") =>  'x.libelle',                                                                                                                                                                                                   
  202.                                $translator->trans("Montant") =>  'x.montant',                                                                                                                                                                                                   
  203.                                $translator->trans("Actions") =>  'x.id',                                    
  204.                                    "_identifier_" => 'x.id'
  205.                         ]
  206.                             )  
  207.                     //->addJoin('x.devise', 'd', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)      
  208.                     //->addJoin('x.utilisateur', 'u', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)      
  209.                     //    ->addJoin('f.devise', 'd', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
  210.                     //    ->addJoin('x.uniteMesure', 'u', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
  211.                      /*->setWhere(                                                     
  212.                              $type_jointure.' = :objet',
  213.                              array('objet' => $objet)
  214.                         )
  215.                        */
  216.                      ->setWhere(
  217.                         'x.commande = :objet',
  218.                         ['objet' => $objet]
  219.                         )
  220.                     ->setRenderers(
  221.                         [
  222.                                 
  223.                                 => [
  224.                                     'view' => 'FO/DataTable/date.html.twig',
  225.                                 ],
  226.                                 => [
  227.                                     'view' => 'FO/DataTable/date.html.twig',
  228.                                 ],
  229.                                 => [
  230.                                     'view' => 'FO/DataTable/prix.html.twig',
  231.                                     'params' => [
  232.                                         'afficher_total'=>false,
  233.                                     ],
  234.                                 ],
  235.                                 => [
  236.                                 'view' => 'FO/DataTable/prix.html.twig',
  237.                                 'params' => [
  238.                                 ]
  239.                                 ],
  240.                                 4=> [
  241.                                     'view' => 'FO/DataTable/actions_modal.html.twig',
  242.                                     'params' => [
  243.                                             'edit_route'  => 'dtc_concurrence_commande_modifier'
  244.                                             'supprimer_route'  => 'dtc_concurrence_commande_supprimer',  
  245.                                             'id'    => $objet->getId(), 
  246.                                             'type'    => $type
  247.                                             'table'    => "dta-concurrence"
  248.                                             'entite'    => ''
  249.                                             'objet' => Concurrence::class,
  250.                                             'width_modal'=>800
  251.                                     ],
  252.                                 ],
  253.                         ]
  254.                     )
  255.                     ->setOrder("x.id""desc")
  256.                     ->setSearch(true)
  257.                     //->setSearchFields(array(1,2))
  258.                     ;   
  259.         return $datatable;                                    
  260.     }
  261.     
  262.     
  263.     /**
  264.      * @Route("/concurrence-commande/grid/{id}/{type}", name="dtc_concurrence_commande_liste_grid")
  265.      */
  266.     public function gridAction(Request $request$id="",$type=""EntityManagerInterface $emDatatable $datatableTranslatorInterface $translator)
  267.     {
  268.         if($type == "commande"$repo_objet $em->getRepository(Commande::class);
  269.         $objet $repo_objet->find($id); 
  270.         
  271.         if(is_object($objet) and $type == "commande") return $this->datatableCommande($objet,$type$datatable$translator)->execute();
  272.     }
  273. }