src/Controller/AdminController.php line 421

Open in your IDE?
  1. <?php
  2. // src/Controller/EntrepriseController.php
  3. namespace App\Controller;
  4. use App\Entity\AppUser;
  5. use App\Entity\SlidePhoto;
  6. use App\Entity\ImageArticleBlog;
  7. use App\Entity\CategorieArticle;
  8. use App\Entity\FactureAcompte;
  9. use App\Entity\ProductPhoto;
  10. use App\Form\ArticleEditType;
  11. use App\Form\ArticleType;
  12. use App\Entity\Article;
  13. use App\Entity\Product;
  14. use App\Entity\ProductOrder;
  15. use App\Entity\TVA;
  16. use App\Entity\Pays;
  17. use App\Form\TVAEditType;
  18. use App\Form\TVAType;
  19. use App\Entity\PaymentMethod;
  20. use App\Form\PaymentMethodEditType;
  21. use App\Form\PaymentMethodType;
  22. use App\Form\ProduitType;
  23. use App\Form\ProduitEditType;
  24. use App\Form\SujetFAQType;
  25. use App\Form\SujetFAQEditType;
  26. use App\Entity\Entreprise;
  27. use App\Form\ProductType;
  28. use App\Form\ProductEditType;
  29. use App\Entity\Tiers;
  30. use App\Entity\Produit;
  31. use App\Entity\ProduitCommande;
  32. use App\Entity\Category;
  33. use App\Entity\SubCategory;
  34. use App\Form\CategorieProduitType;
  35. use App\Form\CategorieArticleEditType;
  36. use App\Form\CategorieArticleType;
  37. use App\Form\CategoryType;
  38. use App\Entity\ShippingMethod;
  39. use App\Form\ShippingMethodType;
  40. use App\Form\ShippingMethodEditType;
  41. use App\Form\CategoryEditType;
  42. use App\Form\SubCategoryType;
  43. use App\Form\SubCategoryEditType;
  44. use App\Form\ArticleAideType;
  45. use App\Entity\ArticleAide;
  46. use App\Entity\Boutique;
  47. use App\Form\ArticleAideEditType;
  48. use App\Entity\Coupon;
  49. use App\Entity\PrixProduit;
  50. use App\Form\CouponType;
  51. use App\Form\CouponEditType;
  52. use App\Form\BoutiqueType;
  53. use App\Form\CategorieProduitEditType;
  54. use App\Entity\Commande;
  55. use App\Entity\CategorieProduit;
  56. use App\Form\TiersType;
  57. use App\Form\TiersEditType;
  58. use App\Entity\ModeleReglement;
  59. use App\Entity\Payment;
  60. use App\Entity\ValiditeService;
  61. use App\Entity\UserBoutique;
  62. use App\Form\CategorieArticleAideType;
  63. use App\Form\CategorieArticleAideEditType;
  64. use App\Entity\Ticket;
  65. use App\Form\TicketType;
  66. use App\Entity\CommentaireTicket;
  67. use App\Form\CommentaireTicketType;
  68. use App\Services\ChiffreEnLettre;
  69. use App\Entity\RequeteAjoutBoutique;
  70. use App\Entity\EntreeDeStock;
  71. use App\Entity\ProduitEntreeDeStock;
  72. use App\Entity\Expensive;
  73. use App\Form\ExpensiveType;
  74. use App\Form\ExpensiveEditType;
  75. use App\Entity\PresenceEmploye;
  76. use App\Entity\PresenceEmployeUser;
  77. use App\Entity\RubriqueSalaire;
  78. use App\Form\RubriqueSalaireType;
  79. use App\Form\RubriqueSalaireEditType;
  80. use App\Entity\RubriqueSalaireEmploye;
  81. use App\Entity\Conge;
  82. use App\Entity\Compte;
  83. use App\Form\CompteType;
  84. use App\Form\EcritureComptableType;
  85. use App\Form\JournalComptabiliteType;
  86. use App\Form\JournalComptabiliteEditType;
  87. use App\Entity\JournalComptabilite;
  88. use App\Entity\EcritureComptable;
  89. use App\Entity\RubriqueSalairePaiement;
  90. use App\Entity\PaiementSalaire;
  91. use App\Entity\GroupeEcritureComptable;
  92. use App\Form\CategorieDepenseType;
  93. use App\Entity\CategorieDepense;
  94. use App\Form\CategorieDepenseEditType;
  95. use App\Form\VisiteType;
  96. use App\Entity\Visite;
  97. use App\Form\VisiteEditType;
  98. use App\Entity\VisitePhoto;
  99. use App\Form\EmployeType;
  100. use App\Form\EmployeEditType;
  101. use App\Entity\Photo;
  102. use App\Entity\DroitUtilisateur;
  103. use Symfony\Component\HttpFoundation\Response;
  104. use Symfony\Component\HttpFoundation\Request;
  105. use Symfony\Component\HttpFoundation\JsonResponse;
  106. use Symfony\Component\Routing\Annotation\Route;
  107. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  108. use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
  109. use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
  110. use Symfony\Component\HttpKernel\KernelInterface;
  111. use Spipu\Html2Pdf\Html2Pdf;
  112. /**
  113.  * @Route("/{_locale}/dashboard")
  114.  */
  115. class AdminController extends AbstractController
  116. {    
  117.     private $kernel;
  118.     
  119.     public function  __construct(KernelInterface $kernel)
  120.     {
  121.         $this->kernel $kernel;
  122.         
  123.     }
  124.     
  125.     /**
  126.      * @Route("/shop/{slug}", name="admin.show_shop")
  127.      * @return \Symfony\Component\HttpFoundation\Response
  128.      */
  129.     public function afficherBoutiqueAction(Request $requestBoutique $boutique)
  130.     {
  131.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  132.            return $this->redirectToRoute('security_login');
  133.         }
  134.         
  135.         
  136.         $em $this->getDoctrine()
  137.                     ->getManager();
  138.         $user $this->getUser();
  139.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  140.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  141.         $dateDebut->setTime(00);
  142.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  143.         $dateFin->setTime(2359);
  144.         
  145.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  146.         $startMonth $intervalleMois['debut'];
  147.         $endMonth $intervalleMois['fin'];
  148.         
  149.         $invoices  $em->getRepository(Commande::class)
  150.                         ->commandeParDateEtType($boutique->getId(), 'invoice'$dateDebut$dateFin);
  151.         
  152.         $startYear date('Y-01-01');
  153.         $endYear date('Y-12-31');
  154.         $userBoutique $em->getRepository(UserBoutique::class)
  155.                         ->findOneBy(
  156.                             array(
  157.                             'user' => $user->getId(),
  158.                             'boutique' => $boutique->getId()
  159.                             )
  160.                         );
  161.                         
  162.         return $this->render('admin/afficher_boutique.html.twig', [
  163.             'boutique' => $boutique,
  164.             'userBoutique' => $userBoutique,
  165.             'dateDebut' => $dateDebut,
  166.            'dateFin' => $dateFin,
  167.            'startMonth' => $startMonth,
  168.            'endMonth' => $endMonth,
  169.            'startYear' => $startYear,
  170.            'endYear' => $endYear,
  171.         ]);
  172.     }
  173.     
  174.     /**
  175.      * @Route("/shop/{slug}/mini-statistic", name="admin.mini_statistic")
  176.      * @return \Symfony\Component\HttpFoundation\Response
  177.      */
  178.     public function miniStatisticAction(Request $requestBoutique $boutique)
  179.     {
  180.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  181.            return $this->redirectToRoute('security_login');
  182.         }
  183.         
  184.         $em $this->getDoctrine()
  185.                     ->getManager();
  186.         
  187.         $user $this->getUser();
  188.               
  189.         
  190.         $mois date('mY');
  191.         $annee date('Y');
  192.         $chiffrDAffaireMois $em->getRepository(Commande::class)
  193.                         ->chiffrDAffairePeriodique($mois$boutique->getId());
  194.         
  195.         $chiffrDAffaireAnnee $em->getRepository(Commande::class)
  196.                         ->chiffrDAffairePeriodique($annee$boutique->getId());
  197.                         
  198.         $depenseMois $em->getRepository(Expensive::class)
  199.                         ->depensePeriodique($mois$boutique->getId());
  200.         $depenseAnnee $em->getRepository(Expensive::class)
  201.                         ->depensePeriodique($annee$boutique->getId());
  202.         $nombreTiers 0;
  203.         
  204.         $nombreTiers $em->getRepository(Tiers::class)
  205.                         ->nombreTiers($boutique->getId());
  206.         
  207.         $nombreProduit $em->getRepository(Produit::class)
  208.                         ->nombreProduit($boutique->getId());
  209.         
  210.         $commandParMois $em->getRepository(Commande::class)
  211.                         ->chiffrDAffaireParMois($annee$boutique->getId());
  212.         
  213.         $chiffreDAffaireSurPlsAnnees $em->getRepository(Commande::class)
  214.                         ->chiffrDAffaireSurPluisieursAnnees($boutique->getId());
  215.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  216.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  217.         $dateDebut->setTime(00);
  218.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  219.         $dateFin->setTime(2359);
  220.         if($request->getMethod() == 'POST'){
  221.             $dateDebut $request->request->get('dateDebut');
  222.             $dateDebut = new \DateTime($dateDebut);
  223.             $dateDebut->setTime(00);
  224.             $dateFin $request->request->get('dateFin');
  225.             $dateFin = new \DateTime($dateFin);
  226.             $dateFin->setTime(2359);
  227.         }
  228.         $chiffreDAffaireDUnePeriode $em->getRepository(Commande::class)
  229.                                         ->chiffreDAffaireDUnePeriode('invoice'$boutique->getId(), $dateDebut$dateFin);
  230.         
  231.         $devisPeriodique  $em->getRepository(Commande::class)
  232.                                         ->chiffreDAffaireDUnePeriode('proposal'$boutique->getId(), $dateDebut$dateFin);
  233.         
  234.         if(!empty($devisPeriodique)){
  235.             $devisPeriodique $devisPeriodique[0]['totalVente'];
  236.         }else{
  237.             $devisPeriodique 0;
  238.         }
  239.         if(!empty($chiffreDAffaireDUnePeriode)){
  240.             
  241.             $chiffreDAffaireDUnePeriode $chiffreDAffaireDUnePeriode[0]['totalVente'];
  242.         }else{
  243.             $chiffreDAffaireDUnePeriode 0;
  244.         }
  245.         $paiementDUnePeriode $em->getRepository(Payment::class)
  246.                                 ->paiementDUnePeriode($boutique$dateDebut$dateFin);
  247.         
  248.         if(!empty($paiementDUnePeriode)){
  249.             $paiementDUnePeriode $paiementDUnePeriode[0]['montantTotal'];
  250.         }else{
  251.             $paiementDUnePeriode 0;
  252.         }
  253.         $totalDepenseParDate $em->getRepository(Expensive::class)
  254.                                 ->totalDepenseParDate($boutique->getId(), $dateDebut$dateFin);
  255.         if(!empty($totalDepenseParDate)){
  256.             $totalDepenseParDate $totalDepenseParDate[0]['totalDepense'];
  257.         } else{
  258.             $totalDepenseParDate 0;
  259.         }
  260.         $soldeTimbreFNE $boutique->getSoldeTimbreFNE();
  261.         $userBoutique $em->getRepository(UserBoutique::class)
  262.                         ->findOneBy(
  263.                             array(
  264.                             'user' => $user->getId(),
  265.                             'boutique' => $boutique->getId()
  266.                             )
  267.                         );
  268.         return $this->render('admin/mini_statistic.html.twig', [
  269.            'boutique' => $boutique,
  270.            'chiffrDAffaireAnnee' => $chiffrDAffaireAnnee,
  271.            'chiffrDAffaireMois' => $chiffrDAffaireMois,
  272.            'nombreTiers' => $nombreTiers,
  273.            'nombreProduit' => $nombreProduit,
  274.            'commandParMois' => $commandParMois
  275.            'chiffreDAffaireSurPlsAnnees' => $chiffreDAffaireSurPlsAnnees,
  276.            'userBoutique' => $userBoutique,
  277.            'depenseMois' => $depenseMois,
  278.            'depenseAnnee' => $depenseAnnee,
  279.            'chiffreDAffaireDUnePeriode' => $chiffreDAffaireDUnePeriode,
  280.            'totalDepenseParDate' => $totalDepenseParDate,
  281.            'soldeTimbreFNE' => $soldeTimbreFNE,
  282.            'paiementDUnePeriode' => $paiementDUnePeriode,
  283.            'devisPeriodique' => $devisPeriodique
  284.         ]);
  285.     }
  286.     
  287.     
  288.     /**
  289.      * @Route("/sales-total/{slug}", name="admin.sales_total")
  290.      * @return \Symfony\Component\HttpFoundation\Response
  291.      */
  292.     public function salesTotal(Request $requestBoutique $boutique)
  293.     {
  294.         $em $this->getDoctrine()
  295.                     ->getManager();
  296.         
  297.         $user $this->getUser();
  298.               
  299.             
  300.         $mois date('mY');
  301.         $annee date('Y');
  302.         $chiffrDAffaireMois $em->getRepository(Commande::class)
  303.                         ->chiffrDAffairePeriodique($mois$boutique->getId());
  304.         
  305.         $chiffrDAffaireAnnee $em->getRepository(Commande::class)
  306.                         ->chiffrDAffairePeriodique($annee$boutique->getId());
  307.         $nombreTiers 0;
  308.         
  309.         $nombreTiers $em->getRepository(Tiers::class)
  310.                         ->nombreTiers($boutique->getId());
  311.         
  312.         $nombreProduit $em->getRepository(Produit::class)
  313.                         ->nombreProduit($boutique->getId());
  314.         
  315.         $commandParMois $em->getRepository(Commande::class)
  316.                         ->chiffrDAffaireParMois($annee$boutique->getId());
  317.         
  318.         $chiffreDAffaireSurPlsAnnees $em->getRepository(Commande::class)
  319.                         ->chiffrDAffaireSurPluisieursAnnees($boutique->getId());
  320.         $userBoutique $em->getRepository(UserBoutique::class)
  321.                         ->findOneBy(
  322.                             array(
  323.                             'user' => $user->getId(),
  324.                             'boutique' => $boutique->getId()
  325.                             )
  326.                         );
  327.         return $this->render('admin/sales_total.html.twig', [
  328.            'boutique' => $boutique,
  329.            'chiffrDAffaireAnnee' => $chiffrDAffaireAnnee,
  330.            'chiffrDAffaireMois' => $chiffrDAffaireMois,
  331.            'nombreTiers' => $nombreTiers,
  332.            'nombreProduit' => $nombreProduit,
  333.            'commandParMois' => $commandParMois,
  334.            'chiffreDAffaireSurPlsAnnees' => $chiffreDAffaireSurPlsAnnees,
  335.            'userBoutique' => $userBoutique
  336.         ]);
  337.     }
  338.     
  339.     
  340.     /**
  341.      * @Route("/{slug}/verifier-abonnement", name="admin.verifier_abonnement")
  342.      * @return \Symfony\Component\HttpFoundation\Response
  343.      */
  344.     public function verifierAbonnementAction(Request $requestBoutique $boutique)
  345.     {
  346.             
  347.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  348.            return $this->redirectToRoute('security_login');
  349.         }
  350.         
  351.         $em $this->getDoctrine()
  352.                     ->getManager();
  353.                     
  354.         $derniereValiditeService =  $em->getRepository(ValiditeService::class)
  355.                         ->derniereValiditeService($boutique->getId());
  356.             
  357.         $user $this->getUser();
  358.         
  359.         $nombreDeJour 0;
  360.         $aujourdhui = new \DateTime();
  361.         $interV '';
  362.         if(null !== $derniereValiditeService){
  363.                 
  364.             $interV $aujourdhui->diff($derniereValiditeService->getValableJusquAu());
  365.             
  366.             $nombreDeJour $interV->days;
  367.         }
  368.         
  369.         if($nombreDeJour <= 0){
  370.             
  371.             //return $this->redirectToRoute('choose_paied_plan');
  372.         }
  373.         $userBoutique $em->getRepository(UserBoutique::class)
  374.                         ->findOneBy(
  375.                             array(
  376.                             'user' => $user->getId(),
  377.                             'boutique' => $boutique->getId()
  378.                             )
  379.                         );
  380.         return $this->render('admin/verifier_abonnement.html.twig', [
  381.            'boutique' => $boutique,
  382.            'derniereValiditeService' => $derniereValiditeService,
  383.            'nombreDeJour' => $nombreDeJour,
  384.            'userBoutique' => $userBoutique
  385.         ]);
  386.     }
  387.     
  388.     
  389.     //Proposals
  390.     /**
  391.      * @Route("/{slug}/proposals", name="admin.proposals")
  392.      * @return \Symfony\Component\HttpFoundation\Response
  393.      */
  394.     public function proposalsActionRequest $requestBoutique $boutique)
  395.     {
  396.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  397.            return $this->redirectToRoute('security_login');
  398.         }
  399.         
  400.         $em $this->getDoctrine()
  401.                     ->getManager();
  402.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  403.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  404.         $dateDebut->setTime(00);
  405.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  406.         $dateFin->setTime(2359);
  407.         
  408.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  409.         $startMonth $intervalleMois['debut'];
  410.         $endMonth $intervalleMois['fin'];
  411.         
  412.         $proposals  $em->getRepository(Commande::class)
  413.                         ->commandeParDateEtType($boutique->getId(), 'proposal'$dateDebut$dateFin);
  414.         $user $this->getUser();
  415.         $userBoutique $em->getRepository(UserBoutique::class)
  416.                         ->findOneBy(
  417.                             array(
  418.                             'user' => $user->getId(),
  419.                             'boutique' => $boutique->getId()
  420.                             )
  421.                         );
  422.         $startYear date('Y-01-01');
  423.         $endYear date('Y-12-31');
  424.         $clients $em->getRepository(Tiers::class)
  425.                     ->findBy(
  426.                         array(
  427.                             'boutique' => $boutique->getId(),
  428.                             'estSupprime' => false
  429.                             
  430.                         ),
  431.                         array(
  432.                             'nom' => 'ASC'
  433.                         )
  434.                     );
  435.         if('POST' == $request->getMethod()){
  436.             $dateDebut $_POST['dateDebut'];
  437.             $dateFin $_POST['dateFin'];
  438.             
  439.             $dateDebut = new \DateTime($dateDebut);
  440.             $dateDebut->setTime(00);
  441.             $dateFin = new \DateTime($dateFin);
  442.             $dateFin->setTime(2359);
  443.             
  444.             $proposals  $em->getRepository(Commande::class)
  445.                         ->commandeParDateEtType($boutique->getId(), 'proposal'$dateDebut$dateFin);
  446.             
  447.             
  448.             return $this->render('admin/proposals_table_content.html.twig', [
  449.                'boutique' => $boutique,
  450.                'proposals' => $proposals,
  451.                'userBoutique' => $userBoutique
  452.             ]);
  453.             
  454.         }
  455.         
  456.         return $this->render('admin/proposals.html.twig', [
  457.            'boutique' => $boutique,
  458.            'proposals' => $proposals,
  459.            'dateDebut' => $dateDebut,
  460.            'dateFin' => $dateFin,
  461.            'startMonth' => $startMonth,
  462.            'endMonth' => $endMonth,
  463.            'startYear' => $startYear,
  464.            'endYear' => $endYear,
  465.            'userBoutique' => $userBoutique,
  466.            'clients' => $clients
  467.         ]);
  468.     }
  469.     
  470.     //Proposals
  471.     /**
  472.      * @Route("/{slug}/deposits", name="admin.deposits")
  473.      * @return \Symfony\Component\HttpFoundation\Response
  474.      */
  475.     public function depositsActionRequest $requestBoutique $boutique)
  476.     {
  477.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  478.            return $this->redirectToRoute('security_login');
  479.         }
  480.         
  481.         $em $this->getDoctrine()
  482.                     ->getManager();
  483.         
  484.             
  485.         $user $this->getUser();
  486.         $userBoutique $em->getRepository(UserBoutique::class)
  487.                         ->findOneBy(
  488.                             array(
  489.                             'user' => $user->getId(),
  490.                             'boutique' => $boutique->getId()
  491.                             )
  492.                         );
  493.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  494.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  495.         $dateDebut->setTime(00);
  496.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  497.         $dateFin->setTime(2359);
  498.         
  499.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  500.         $startMonth $intervalleMois['debut'];
  501.         $endMonth $intervalleMois['fin'];
  502.         
  503.         $deposits  $em->getRepository(FactureAcompte::class)
  504.                         ->factureParDate($boutique->getId(), $dateDebut$dateFin);
  505.         
  506.         
  507.         $startYear date('Y-01-01');
  508.         $endYear date('Y-12-31');
  509.         if('POST' == $request->getMethod()){
  510.             $dateDebut $_POST['dateDebut'];
  511.             $dateFin $_POST['dateFin'];
  512.             
  513.             $dateDebut = new \DateTime($dateDebut);
  514.             $dateDebut->setTime(00);
  515.             $dateFin = new \DateTime($dateFin);
  516.             $dateFin->setTime(2359);
  517.             
  518.             $deposits  $em->getRepository(FactureAcompte::class)
  519.                         ->factureParDate($boutique->getId(), $dateDebut$dateFin);
  520.         
  521.             return $this->render('admin/deposits_table_content.html.twig', [
  522.                'boutique' => $boutique,
  523.                'deposits' => $deposits,
  524.                 'userBoutique' => $userBoutique
  525.             ]);
  526.             
  527.         }
  528.         
  529.         
  530.     
  531.         return $this->render('admin/deposits.html.twig', [
  532.            'boutique' => $boutique,
  533.            'deposits' => $deposits,
  534.            'dateDebut' => $dateDebut,
  535.            'dateFin' => $dateFin,
  536.            'startMonth' => $startMonth,
  537.            'endMonth' => $endMonth,
  538.            'startYear' => $startYear,
  539.            'endYear' => $endYear,
  540.            'userBoutique' => $userBoutique
  541.         ]);
  542.     }
  543.     
  544.     //Proposals
  545.     /**
  546.      * @Route("/{slug}/new-deposit", name="admin.new_deposit")
  547.      * @return \Symfony\Component\HttpFoundation\Response
  548.      */
  549.     public function newDepositActionRequest $requestBoutique $boutique)
  550.     {
  551.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  552.            return $this->redirectToRoute('security_login');
  553.         }
  554.         
  555.         $responseFNE '';
  556.         $vehicules = array(1222328);
  557.         $em $this->getDoctrine()
  558.                     ->getManager();
  559.         $tvas  $em->getRepository(TVA::class)
  560.                         ->findBy(
  561.                             array(
  562.                                 'boutique' => $boutique->getId()
  563.                             )
  564.                         );
  565.         $factures  $em->getRepository(Commande::class)
  566.                         ->findBy(
  567.                             array(
  568.                                 'boutique' => $boutique->getId(),
  569.                                 'typeFacture' => 'invoice'
  570.                             )
  571.                         );
  572.                         
  573.         $editMode 'new';
  574.         $user $this->getUser();
  575.         $userBoutique $em->getRepository(UserBoutique::class)
  576.                         ->findOneBy(
  577.                             array(
  578.                             'user' => $user->getId(),
  579.                             'boutique' => $boutique->getId()
  580.                             )
  581.                         );
  582.         if($request->getMethod() == 'POST'){
  583.             $facture $_POST['facture'];
  584.             $facture $em->getRepository(Commande::class)
  585.                             ->findOneBy(
  586.                                 array(
  587.                                 'boutique' => $boutique->getId(),
  588.                                 'id' => $facture
  589.                                 )
  590.                             );
  591.         
  592.             $montant $_POST['montant'];
  593.             $valableJusquAu '';
  594.             if(isset($_POST['valableJusquAu'])){
  595.                 $valableJusquAu $_POST['valableJusquAu'];
  596.             }
  597.             
  598.             $pourcentage $_POST['pourcentage'];
  599.             $appliquerTVA false;
  600.             if(isset($_POST['appliquerTVA'])){
  601.                 $appliquerTVA = (bool) $_POST['appliquerTVA'];
  602.             }
  603.             
  604.             $tva 0;
  605.             if(isset($_POST['tva'])){
  606.                 $tva $_POST['tva'];
  607.             }
  608.             $laDate '';
  609.             if(isset($_POST['laDate'])){
  610.                 $laDate $_POST['laDate'];
  611.             }
  612.             
  613.             $deposit = new FactureAcompte;
  614.             $deposit->setTotalHT($montant);
  615.             $deposit->setPourcentage($pourcentage);
  616.             $deposit->setBoutique($boutique);
  617.             $deposit->setTiers($facture->getTiers());
  618.             $deposit->setFacture($facture);
  619.             $deposit->setLaDate(new \DateTime($laDate));
  620.             $deposit->setValableJusquAu(new \DateTime($valableJusquAu));
  621.             $deposit->setNumero($this->getNumero('deposit'$boutique));
  622.             if($appliquerTVA){
  623.                 $deposit->setTotalTVA(($montant $tva)/100);
  624.                 $ttc $montant * ($tva/100);
  625.                 $deposit->setTotalTTC($ttc);
  626.                 $deposit->setValeurTVA($tva);
  627.             } else{
  628.                 $deposit->setTotalTTC($montant);
  629.                 $deposit->setValeurTVA(0);
  630.             }
  631.             $em->persist($deposit);
  632.             $em->flush();
  633.             
  634.             $pdf = new Html2Pdf('P'$boutique->getSettings()->getFormatPapierImpression(), 'en');
  635.                     
  636.             $content $this->renderView('pdf/facture_acompte.html.twig', [
  637.                 'boutique' => $boutique,
  638.                 'facture' => $deposit,
  639.             ]);
  640.             $pdf->writeHTML($content);
  641.             $name 'deposit'.$deposit->getId().time().$boutique->getId().rand(110000).'.pdf';
  642.             $lienPhysique $deposit->getUploadRootDir().$name;
  643.             
  644.             $deposit->setLienPDF($this->getDomain().'/pdf478njkp01/'.$name);
  645.             $pdf->output($lienPhysique'F');
  646.             
  647.             $em->flush();
  648.             
  649.             return $this->render('admin/response_new_deposit.html.twig', [
  650.                    'boutique' => $boutique,
  651.                    'commande' => $deposit,
  652.                    'responseFNE' => $responseFNE,
  653.                     'vehicules' => $vehicules
  654.                 ]);
  655.         }
  656.         return $this->render('admin/new_deposit.html.twig', [
  657.            'boutique' => $boutique,
  658.            'factures' => $factures,
  659.            'editMode' => $editMode,
  660.            'tvas' => $tvas,
  661.            'userBoutique' => $userBoutique
  662.         ]);
  663.     }
  664.     
  665.     //Proposals
  666.     /**
  667.      * @Route("/{slug}/edit-deposit/{id}", name="admin.edit_deposit")
  668.      * @return \Symfony\Component\HttpFoundation\Response
  669.      */
  670.     public function editDepositActionRequest $request,  $slug$id)
  671.     {
  672.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  673.            return $this->redirectToRoute('security_login');
  674.         }
  675.         
  676.         $em $this->getDoctrine()
  677.                     ->getManager();
  678.         
  679.         $boutique  $em->getRepository(Boutique::class)
  680.                         ->findOneBySlug($slug);
  681.         $user $this->getUser();
  682.         $userBoutique $em->getRepository(UserBoutique::class)
  683.                         ->findOneBy(
  684.                             array(
  685.                             'user' => $user->getId(),
  686.                             'boutique' => $boutique->getId()
  687.                             )
  688.                         );
  689.                         
  690.         $factures  $em->getRepository(Commande::class)
  691.                         ->findBy(
  692.                             array(
  693.                                 'boutique' => $boutique->getId(),
  694.                                 'typeFacture' => 'invoice'
  695.                             )
  696.                         );
  697.         
  698.         $tvas  $em->getRepository(TVA::class)
  699.                         ->findBy(
  700.                             array(
  701.                                 'boutique' => $boutique->getId()
  702.                             )
  703.                         );
  704.         
  705.         $deposit  $em->getRepository(FactureAcompte::class)
  706.                         ->findOneBy(
  707.                             array(
  708.                                 'boutique' => $boutique->getId(),
  709.                                 'id' => $id
  710.                             )
  711.                         );
  712.         
  713.         $editMode 'edit';
  714.         if($request->getMethod() == 'POST'){
  715.         $facture $_POST['facture'];
  716.             $facture $em->getRepository(Commande::class)
  717.                             ->findOneBy(
  718.                                 array(
  719.                                 'boutique' => $boutique->getId(),
  720.                                 'id' => $facture
  721.                                 )
  722.                             );
  723.         
  724.             $montant $_POST['montant'];
  725.             $pourcentage $_POST['pourcentage'];
  726.             $appliquerTVA false;
  727.             if(isset($_POST['appliquerTVA'])){
  728.                 $appliquerTVA = (bool) $_POST['appliquerTVA'];
  729.             }
  730.             
  731.             $tva 0;
  732.             if(isset($_POST['tva'])){
  733.                 $tva $_POST['tva'];
  734.             }
  735.             
  736.             $laDate '';
  737.             if(isset($_POST['laDate'])){
  738.                 $laDate $_POST['laDate'];
  739.             }
  740.             
  741.             $deposit->setTotalHT($montant);
  742.             $deposit->setPourcentage($pourcentage);
  743.             $deposit->setBoutique($boutique);
  744.             $deposit->setTiers($facture->getTiers());
  745.             $deposit->setLaDate(new \DateTime($laDate));
  746.             if($appliquerTVA){
  747.                 $deposit->setTotalTVA(($montant $tva)/100);
  748.                 $ttc $montant * ($tva)/100;
  749.                 $deposit->setTotalTVA(($montant $tva)/100);
  750.                 $deposit->setTotalTTC($ttc);
  751.                 $deposit->setValeurTVA($tva);
  752.             } else{
  753.                 $deposit->setTotalTTC($montant);
  754.                 $deposit->setValeurTVA(0);
  755.                 $deposit->setTotalTVA(0);
  756.             }
  757.             
  758.             $em->flush();
  759.         }
  760.         return $this->render('admin/edit_deposit.html.twig', [
  761.            'boutique' => $boutique,
  762.            'factures' => $factures,
  763.            'editMode' => $editMode,
  764.            'tvas' => $tvas,
  765.            'deposit' => $deposit,
  766.            'userBoutique' => $userBoutique
  767.         ]);
  768.     }
  769.     
  770.     /**
  771.      * @Route("/{slug}/delete-deposit/{id}", name="admin.delete_deposit")
  772.      * @return \Symfony\Component\HttpFoundation\Response
  773.      */
  774.     public function deleteDepositActionRequest $request,  $slug$id)
  775.     {
  776.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  777.            return $this->redirectToRoute('security_login');
  778.         }
  779.         
  780.         $em $this->getDoctrine()
  781.                     ->getManager();
  782.         
  783.         $boutique  $em->getRepository(Boutique::class)
  784.                         ->findOneBySlug($slug);
  785.         
  786.         $user $this->getUser();
  787.         $userBoutique $em->getRepository(UserBoutique::class)
  788.                         ->findOneBy(
  789.                             array(
  790.                             'user' => $user->getId(),
  791.                             'boutique' => $boutique->getId()
  792.                             )
  793.                         );
  794.         $deposit  $em->getRepository(FactureAcompte::class)
  795.                         ->findOneBy(
  796.                             array(
  797.                                 'boutique' => $boutique->getId(),
  798.                                 'id' => $id
  799.                             )
  800.                         );
  801.         if(null != $deposit){
  802.             $em->remove($deposit);
  803.             $em->flush();
  804.         }
  805.         return $this->redirectToRoute('admin.deposits', array('slug' => $boutique->getSlug()));
  806.     }
  807.     
  808.     
  809.     /**
  810.      * @Route("/{slug}/invoices", name="admin.invoices")
  811.      * @return \Symfony\Component\HttpFoundation\Response
  812.      */
  813.     public function invoicesActionRequest $requestBoutique $boutique)
  814.     {
  815.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  816.            return $this->redirectToRoute('security_login');
  817.         }
  818.         
  819.         $em $this->getDoctrine()
  820.                     ->getManager();
  821.                     
  822.         $paymentMethods $em->getRepository(PaymentMethod::class)
  823.                     ->findBy(
  824.                         array(
  825.                             'boutique' => $boutique->getId()
  826.                         )
  827.                     );
  828.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  829.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  830.         $dateDebut->setTime(00);
  831.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  832.         $dateFin->setTime(2359);
  833.         
  834.         
  835.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  836.         $startMonth $intervalleMois['debut'];
  837.         $endMonth $intervalleMois['fin'];
  838.         
  839.         $invoices  $em->getRepository(Commande::class)
  840.                         ->commandeParDateEtType($boutique->getId(), 'invoice'$dateDebut$dateFin);
  841.         
  842.         $startYear date('Y-01-01');
  843.         $endYear date('Y-12-31');
  844.         $user $this->getUser();
  845.         
  846.         $userBoutique $em->getRepository(UserBoutique::class)
  847.                         ->findOneBy(
  848.                             array(
  849.                             'user' => $user->getId(),
  850.                             'boutique' => $boutique->getId()
  851.                             )
  852.                         );
  853.         $clients $em->getRepository(Tiers::class)
  854.                     ->findBy(
  855.                         array(
  856.                             'boutique' => $boutique->getId(),
  857.                             'estSupprime' => false
  858.                             
  859.                         ),
  860.                         array(
  861.                             'nom' => 'ASC'
  862.                         )
  863.                     );
  864.         if('POST' == $request->getMethod()){
  865.             $dateDebut $_POST['dateDebut'];
  866.             $dateFin $_POST['dateFin'];
  867.             
  868.             $dateDebut = new \DateTime($dateDebut);
  869.             $dateDebut->setTime(00);
  870.             $dateFin = new \DateTime($dateFin);
  871.             $dateFin->setTime(2359);
  872.             
  873.             $invoices  $em->getRepository(Commande::class)
  874.                         ->commandeParDateEtType($boutique->getId(), 'invoice'$dateDebut$dateFin);
  875.             
  876.             
  877.             return $this->render('admin/invoices_table_content.html.twig', [
  878.                'boutique' => $boutique,
  879.                'invoices' => $invoices,
  880.                'userBoutique' => $userBoutique
  881.             ]);
  882.             
  883.         }
  884.         
  885.         return $this->render('admin/invoices.html.twig', [
  886.            'boutique' => $boutique,
  887.            'paymentMethods' => $paymentMethods,
  888.            'invoices' => $invoices,
  889.            'dateDebut' => $dateDebut,
  890.            'dateFin' => $dateFin,
  891.            'startMonth' => $startMonth,
  892.            'endMonth' => $endMonth,
  893.            'startYear' => $startYear,
  894.            'endYear' => $endYear,
  895.            'userBoutique' => $userBoutique,
  896.            'clients' => $clients
  897.         ]);
  898.     }
  899.     /**
  900.      * @Route("/{slug}/point-par-client/{id}/{type}/{dateDebut}/{dateFin}", name="admin_point_par_client")
  901.      * @return \Symfony\Component\HttpFoundation\Response
  902.      */
  903.     public function pointParClientActionRequest $request$slug$id 0$type 'invoice'$dateDebut ''$dateFin '')
  904.     {
  905.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  906.            return $this->redirectToRoute('security_login');
  907.         }
  908.         
  909.         $em $this->getDoctrine()
  910.                     ->getManager();
  911.                         
  912.         $boutique $em->getRepository(Boutique::class)
  913.                         ->findOneBySlug($slug);
  914.         
  915.         
  916.         $user $this->getUser();
  917.         $userBoutique $em->getRepository(UserBoutique::class)
  918.                         ->findOneBy(
  919.                             array(
  920.                             'user' => $user->getId(),
  921.                             'boutique' => $boutique->getId()
  922.                             )
  923.                         );
  924.         $client $em->getRepository(Tiers::class)
  925.                     ->findOneById($id);
  926.         $dateDebut = new \DateTime($dateDebut);
  927.         $dateDebut->setTime(00);
  928.         $dateFin = new \DateTime($dateFin);
  929.         $dateFin->setTime(2359);
  930.         $invoices  $em->getRepository(Commande::class)
  931.                         ->commandeParClientDateEtType($boutique->getId(), $type$id$dateDebut$dateFin);
  932.     
  933.         if($id == 0){
  934.             return $this->render('admin/point_par_client.html.twig', [
  935.                 'boutique' => $boutique,
  936.                 
  937.                 'invoices' => $invoices,
  938.                 'dateDebut' => $dateDebut,
  939.                 'dateFin' => $dateFin,
  940.                 'userBoutique' => $userBoutique,
  941.                 ]);
  942.         }
  943.        
  944.         return $this->render('admin/point_par_client.html.twig', [
  945.            'boutique' => $boutique,
  946.            
  947.            'invoices' => $invoices,
  948.            'dateDebut' => $dateDebut,
  949.            'dateFin' => $dateFin,
  950.            'userBoutique' => $userBoutique,
  951.         ]);
  952.     }
  953.     /**
  954.      * @Route("/{slug}/imprimer-point-par-client/{id}/{type}/{dateDebut}/{dateFin}", name="admin_imprimer_point_par_client")
  955.      * @return \Symfony\Component\HttpFoundation\Response
  956.      */
  957.     public function imprimerPointParClientActionRequest $request$slug$id 0$type 'invoice'$dateDebut ''$dateFin '')
  958.     {
  959.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  960.            return $this->redirectToRoute('security_login');
  961.         }
  962.         
  963.         $em $this->getDoctrine()
  964.                     ->getManager();
  965.                         
  966.         $boutique $em->getRepository(Boutique::class)
  967.                         ->findOneBySlug($slug);
  968.         
  969.         
  970.         $user $this->getUser();
  971.         $userBoutique $em->getRepository(UserBoutique::class)
  972.                         ->findOneBy(
  973.                             array(
  974.                             'user' => $user->getId(),
  975.                             'boutique' => $boutique->getId()
  976.                             )
  977.                         );
  978.         $client $em->getRepository(Tiers::class)
  979.                     ->findOneById($id);
  980.         $dateDebut = new \DateTime($dateDebut);
  981.         $dateDebut->setTime(00);
  982.         $dateFin = new \DateTime($dateFin);
  983.         $dateFin->setTime(2359);
  984.         $invoices  $em->getRepository(Commande::class)
  985.                         ->commandeParClientDateEtType($boutique->getId(), $type$id$dateDebut$dateFin);
  986.         $pdf = new Html2Pdf('P''A4''fr');
  987.         if($id == 0){
  988.             $content $this->renderView('pdf/point_pour_tous_les_clients.html.twig', [
  989.                         'boutique' => $boutique,
  990.                         'invoices' => $invoices,
  991.                         'dateDebut' => $dateDebut,
  992.                         'dateFin' => $dateFin,
  993.                         'userBoutique' => $userBoutique,
  994.                     ]);
  995.         }else{
  996.             $content $this->renderView('pdf/point_par_client.html.twig', [
  997.                         'boutique' => $boutique,
  998.                         'client' => $client,
  999.                         'invoices' => $invoices,
  1000.                         'dateDebut' => $dateDebut,
  1001.                         'dateFin' => $dateFin,
  1002.                         'userBoutique' => $userBoutique,
  1003.                     ]);
  1004.         }
  1005.         
  1006.         $pdf->writeHTML($content);
  1007.         $name time().$boutique->getId().rand(110000).'.pdf';
  1008.         $photo = new Photo;
  1009.         $lienPhysique $photo->getUploadRootDir().$name;
  1010.                 
  1011.         $pdf->output($lienPhysique'I');
  1012.         return $this->render('pdf/point_par_client.html.twig', [
  1013.            'boutique' => $boutique,
  1014.            'client' => $client,
  1015.            'invoices' => $invoices,
  1016.            'dateDebut' => $dateDebut,
  1017.            'dateFin' => $dateFin,
  1018.            'userBoutique' => $userBoutique,
  1019.         ]);
  1020.     }
  1021.     //Proposals
  1022.     /**
  1023.      * @Route("/{slug}/detail-commande/{id}", name="admin_detail_commande")
  1024.      * @return \Symfony\Component\HttpFoundation\Response
  1025.      */
  1026.     public function detailCommandeActionRequest $request$slug$id=0)
  1027.     {
  1028.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  1029.            return $this->redirectToRoute('security_login');
  1030.         }
  1031.         $em $this->getDoctrine()
  1032.                     ->getManager();
  1033.         $boutique $em->getRepository(Boutique::class)
  1034.                         ->findOneBySlug($slug);
  1035.         $produitCommandes $em->getRepository(ProduitCommande::class)
  1036.                                 ->findBy(
  1037.                                     array(
  1038.                                         'commande' => $id
  1039.                                     )
  1040.                                 );
  1041.         return $this->render('admin/detail_commande.html.twig', [
  1042.            'produitCommandes' => $produitCommandes,
  1043.         ]);
  1044.     }
  1045.     /**
  1046.      * @Route("/{slug}/rh/tableau-de-bord", name="admin_rh_tableau_de_bord")
  1047.      * @return \Symfony\Component\HttpFoundation\Response
  1048.      */
  1049.     public function rhTableauDeBordActionRequest $requestBoutique $boutique)
  1050.     {
  1051.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  1052.            return $this->redirectToRoute('security_login');
  1053.         }  
  1054.         $em $this->getDoctrine()
  1055.                     ->getManager();
  1056.         
  1057.         $user $this->getUser();
  1058.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  1059.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  1060.         $dateDebut->setTime(00);
  1061.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  1062.         $dateFin->setTime(2359);
  1063.         
  1064.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  1065.         $startMonth $intervalleMois['debut'];
  1066.         $endMonth $intervalleMois['fin'];
  1067.         
  1068.         $startYear date('Y-01-01');
  1069.         $endYear date('Y-12-31');
  1070.         
  1071.         $estParti false;
  1072.         $nombreDEmployeActuel $em->getRepository(UserBoutique::class)
  1073.                     ->nombreDEmployeActuel($boutique->getId(), 'ROLE_EMPLOYE'$estParti);
  1074.         $nombreDEmployeActuel $nombreDEmployeActuel[0]['nombreEmploye'];
  1075.         $estParti true;
  1076.         $nombreDEmployeParti $em->getRepository(UserBoutique::class)
  1077.                     ->nombreDEmployeActuel($boutique->getId(), 'ROLE_EMPLOYE'$estParti);
  1078.         $nombreDEmployeParti $nombreDEmployeParti[0]['nombreEmploye'];
  1079.         $heureDeTravails $em->getRepository(PresenceEmployeUser::class)
  1080.                     ->heureDeTravail($boutique->getId(), $dateDebut$dateFin);
  1081.         
  1082.         $tempsDeTravail 0;
  1083.         $heureSupplementaires 0;
  1084.         
  1085.         if(!empty($heureDeTravails)){
  1086.             $tempsDeTravail $heureDeTravails[0]['tempsDeTravail'];
  1087.             $heureSupplementaires $heureDeTravails[0]['heureSupplementaire'];
  1088.         }
  1089.         
  1090.         
  1091.         $userBoutique $em->getRepository(UserBoutique::class)
  1092.                         ->findOneBy(
  1093.                             array(
  1094.                             'user' => $user->getId(),
  1095.                             'boutique' => $boutique->getId()
  1096.                             )
  1097.                         );
  1098.         
  1099.         
  1100.         return $this->render('admin/rh_tableau_de_bord.html.twig', [
  1101.            'boutique' => $boutique,
  1102.             'nombreDEmployeParti' => $nombreDEmployeParti,
  1103.            'userBoutique' => $userBoutique,
  1104.            'nombreDEmployeActuel' => $nombreDEmployeActuel,
  1105.            'tempsDeTravail' => $tempsDeTravail,
  1106.             'heureSupplementaires' => $heureSupplementaires,
  1107.             'dateDebut' => $dateDebut,
  1108.            'dateFin' => $dateFin,
  1109.            'startMonth' => $startMonth,
  1110.            'endMonth' => $endMonth,
  1111.            'startYear' => $startYear,
  1112.            'endYear' => $endYear,
  1113.         ]);
  1114.     }
  1115.     /**
  1116.      * @Route("/{slug}/rh/employees", name="admin_rh_employees")
  1117.      * @return \Symfony\Component\HttpFoundation\Response
  1118.      */
  1119.     public function employeesActionRequest $requestBoutique $boutique)
  1120.     {
  1121.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  1122.            return $this->redirectToRoute('security_login');
  1123.         }      
  1124.         $em $this->getDoctrine()
  1125.                     ->getManager();
  1126.         
  1127.         $user $this->getUser();
  1128.         
  1129.         
  1130.         $employes $em->getRepository(UserBoutique::class)
  1131.                     ->findBy(
  1132.                         array(
  1133.                             'boutique' => $boutique->getId(),
  1134.                             'estParti' => false
  1135.                         )
  1136.                     );
  1137.         
  1138.         
  1139.         $userBoutique $em->getRepository(UserBoutique::class)
  1140.                         ->findOneBy(
  1141.                             array(
  1142.                             'user' => $user->getId(),
  1143.                             'boutique' => $boutique->getId(),
  1144.                             
  1145.                             )
  1146.                         );
  1147.         
  1148.         
  1149.         return $this->render('admin/employes.html.twig', [
  1150.            'boutique' => $boutique,
  1151.             'employes' => $employes,
  1152.            'userBoutique' => $userBoutique
  1153.         ]);
  1154.     }
  1155.     /**
  1156.      * @Route("/{slug}/rh/pointage-journalier", name="admin_pointage_journalier")
  1157.      * @return \Symfony\Component\HttpFoundation\Response
  1158.      */
  1159.     public function pointageJournalierActionRequest $requestBoutique $boutique)
  1160.     {
  1161.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  1162.            return $this->redirectToRoute('security_login');
  1163.         }      
  1164.         $em $this->getDoctrine()
  1165.                     ->getManager();
  1166.         
  1167.         $user $this->getUser();
  1168.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  1169.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  1170.         
  1171.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  1172.         
  1173.         
  1174.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  1175.         $startMonth $intervalleMois['debut'];
  1176.         $endMonth $intervalleMois['fin'];
  1177.         
  1178.         $presenceEmployeParDates  $em->getRepository(PresenceEmploye::class)
  1179.                         ->presenceEmployeParDate($boutique->getId(), $dateDebut$dateFin);
  1180.         
  1181.         $startYear date('Y-01-01');
  1182.         $endYear date('Y-12-31');
  1183.         if($request->getMethod() == 'POST'){
  1184.             $dateDebut $request->request->get('dateDebut');
  1185.             $dateDebut = new \DateTime($dateDebut);
  1186.             $dateFin $request->request->get('dateFin');
  1187.             $dateFin = new \DateTime($dateFin);
  1188.             $presenceEmployeParDates  $em->getRepository(PresenceEmploye::class)
  1189.                         ->presenceEmployeParDate($boutique->getId(), $dateDebut$dateFin);
  1190.              return $this->render('admin/contenu_table_pointage_journalier.html.twig', [
  1191.                 
  1192.                 'presenceEmployeParDates' => $presenceEmployeParDates
  1193.                 
  1194.                 ]);
  1195.                     
  1196.         }
  1197.         $userBoutique $em->getRepository(UserBoutique::class)
  1198.                         ->findOneBy(
  1199.                             array(
  1200.                             'user' => $user->getId(),
  1201.                             'boutique' => $boutique->getId()
  1202.                             )
  1203.                         );
  1204.         
  1205.         
  1206.         return $this->render('admin/pointage_journalier.html.twig', [
  1207.            'boutique' => $boutique,
  1208.            'userBoutique' => $userBoutique,
  1209.            'presenceEmployeParDates' => $presenceEmployeParDates,
  1210.             'dateDebut' => $dateDebut,
  1211.            'dateFin' => $dateFin,
  1212.            'startMonth' => $startMonth,
  1213.            'endMonth' => $endMonth,
  1214.            'startYear' => $startYear,
  1215.            'endYear' => $endYear,
  1216.         ]);
  1217.     }
  1218.     /**
  1219.      * @Route("/{slug}/rh/element-pointage-journalier/{idPresence}", name="admin_element_pointage_journalier")
  1220.      * @return \Symfony\Component\HttpFoundation\Response
  1221.      */
  1222.     public function elementPointageJournalierActionRequest $requestBoutique $boutique$idPresence '')
  1223.     {
  1224.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  1225.            return $this->redirectToRoute('security_login');
  1226.         }      
  1227.         $em $this->getDoctrine()
  1228.                     ->getManager();
  1229.         
  1230.         $user $this->getUser();
  1231.         $presenceEmploye  $em->getRepository(PresenceEmploye::class)
  1232.                         ->findOneById($idPresence);
  1233.         
  1234.         $presenceEmployeUsers  $em->getRepository(PresenceEmployeUser::class)
  1235.                         ->findByPresenceEmploye($presenceEmploye);
  1236.         
  1237.         
  1238.         
  1239.         $userBoutique $em->getRepository(UserBoutique::class)
  1240.                         ->findOneBy(
  1241.                             array(
  1242.                             'user' => $user->getId(),
  1243.                             'boutique' => $boutique->getId()
  1244.                             )
  1245.                         );
  1246.         
  1247.         
  1248.         return $this->render('admin/element_pointage_journalier.html.twig', [
  1249.            'boutique' => $boutique,
  1250.            'userBoutique' => $userBoutique,
  1251.            'presenceEmployeUsers' => $presenceEmployeUsers,
  1252.         ]);
  1253.     }
  1254.     /**
  1255.      * @Route("/{slug}/rh/nouveau-pointage-journalier", name="admin_nouveau_pointage_journalier")
  1256.      * @return \Symfony\Component\HttpFoundation\Response
  1257.      */
  1258.     public function nouveauPointageJournalierActionRequest $requestBoutique $boutique)
  1259.     {
  1260.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  1261.            return $this->redirectToRoute('security_login');
  1262.         }      
  1263.         $em $this->getDoctrine()
  1264.                     ->getManager();
  1265.         
  1266.         $user $this->getUser();
  1267.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  1268.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  1269.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  1270.         
  1271.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  1272.         $startMonth $intervalleMois['debut'];
  1273.         $endMonth $intervalleMois['fin'];
  1274.         
  1275.         $presenceEmployeParDates  $em->getRepository(PresenceEmploye::class)
  1276.                         ->presenceEmployeParDate($boutique->getId(), $dateDebut$dateFin);
  1277.         
  1278.         $startYear date('Y-01-01');
  1279.         $endYear date('Y-12-31');
  1280.         
  1281.         $employes $em->getRepository(UserBoutique::class)
  1282.                         ->findBy(
  1283.                             array(
  1284.                                 'boutique' => $boutique,
  1285.                                 'estParti' => false
  1286.                             )
  1287.                         );
  1288.         if($request->getMethod() == 'POST'){
  1289.             $laDate $request->request->get('la_date');
  1290.             $laDate = new \DateTime($laDate);
  1291.             $presenceEmploye = new PresenceEmploye;
  1292.             $presenceEmploye->setBoutique($boutique);
  1293.             $presenceEmploye->setLaDate($laDate);
  1294.             $em->persist($presenceEmploye);
  1295.             $em->flush();
  1296.             foreach($employes as $employe){
  1297.                 $estPresent =  (bool)$request->request->get('est_present'.$employe->getUser()->getId());
  1298.                 $heureDebut =  $request->request->get('heure_debut'.$employe->getUser()->getId());
  1299.                 $heureDebut = new \DateTime($heureDebut);
  1300.                 $heureFin =  $request->request->get('heure_fin'.$employe->getUser()->getId());
  1301.                 $heureFin = new \DateTime($heureFin);
  1302.                 $tempsDeTravail =  (float)$request->request->get('temps_de_travail'.$employe->getUser()->getId());
  1303.                 $heureSupplementaire =  $request->request->get('heure_supplementaire'.$employe->getUser()->getId());
  1304.                 
  1305.                 if($estPresent){
  1306.                     $presenceEmployeUser = new PresenceEmployeUser;
  1307.                     $presenceEmployeUser->setUser($employe->getUser());
  1308.                     $presenceEmployeUser->setBoutique($boutique);
  1309.                     $presenceEmployeUser->setPresenceEmploye($presenceEmploye);
  1310.                     $presenceEmployeUser->setEstPresent($estPresent);
  1311.                     $presenceEmployeUser->setDatePresence($laDate);
  1312.                     $presenceEmployeUser->setHeureArrivee($heureDebut);
  1313.                     $presenceEmployeUser->setHeureDepart($heureFin);
  1314.                     $presenceEmployeUser->setHeurePassee($tempsDeTravail);
  1315.                     $presenceEmployeUser->setHeureSupplementaire($heureSupplementaire);
  1316.                     $em->persist($presenceEmployeUser);
  1317.                     $em->flush();
  1318.                     
  1319.                 }
  1320.             }
  1321.         }
  1322.         $userBoutique $em->getRepository(UserBoutique::class)
  1323.                         ->findOneBy(
  1324.                             array(
  1325.                             'user' => $user->getId(),
  1326.                             'boutique' => $boutique->getId()
  1327.                             )
  1328.                         );
  1329.         
  1330.         
  1331.         return $this->render('admin/nouveau_pointage_journalier.html.twig', [
  1332.            'boutique' => $boutique,
  1333.            'userBoutique' => $userBoutique,
  1334.            'employes' => $employes,
  1335.            'presenceEmployeParDates' => $presenceEmployeParDates,
  1336.             'dateDebut' => $dateDebut,
  1337.            'dateFin' => $dateFin,
  1338.            'startMonth' => $startMonth,
  1339.            'endMonth' => $endMonth,
  1340.            'startYear' => $startYear,
  1341.            'endYear' => $endYear,
  1342.         ]);
  1343.     }
  1344.     
  1345.     
  1346.     //Salaire
  1347.     /**
  1348.      * @Route("/{slug}/rh/salaire", name="admin_rh_salaires")
  1349.      * @return \Symfony\Component\HttpFoundation\Response
  1350.      */
  1351.     public function salairesActionRequest $requestBoutique $boutique)
  1352.     {
  1353.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  1354.            return $this->redirectToRoute('security_login');
  1355.         }      
  1356.         $em $this->getDoctrine()
  1357.                     ->getManager();
  1358.         
  1359.         $user $this->getUser();
  1360.         
  1361.         
  1362.         $employes $em->getRepository(UserBoutique::class)
  1363.                     ->findBy(
  1364.                         array(
  1365.                             'boutique' => $boutique->getId(),
  1366.                             'estParti' => false,
  1367.                             'estEmploye' => true
  1368.                         )
  1369.                     );
  1370.         
  1371.         
  1372.         $userBoutique $em->getRepository(UserBoutique::class)
  1373.                         ->findOneBy(
  1374.                             array(
  1375.                             'user' => $user->getId(),
  1376.                             'boutique' => $boutique->getId()
  1377.                             )
  1378.                         );
  1379.         
  1380.         $mois $this->getMois();
  1381.         $annees $this->getAnnee();
  1382.         $moyenDePaiements = array(
  1383.             'VIREMENT BANCAIRE''CHEQUE''ESPECE''WAVE''ORANGE MONEY''MTN MONEY''MOOV MONEY'
  1384.         );
  1385.         return $this->render('admin/salaries.html.twig', [
  1386.            'boutique' => $boutique,
  1387.             'employes' => $employes,
  1388.            'userBoutique' => $userBoutique,
  1389.            'mois' => $mois,
  1390.            'annees' => $annees,
  1391.            'moyenDePaiements' => $moyenDePaiements
  1392.         ]);
  1393.     }
  1394.     /**
  1395.      * @Route("/{slug}/rh/calculer-salaire", name="admin_rh_calcuer_salaire")
  1396.      * @return \Symfony\Component\HttpFoundation\Response
  1397.      */
  1398.     public function calculerSalaireActionRequest $requestBoutique $boutique)
  1399.     {
  1400.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  1401.            return $this->redirectToRoute('security_login');
  1402.         }      
  1403.         $em $this->getDoctrine()
  1404.                     ->getManager();
  1405.         
  1406.         $user $this->getUser();
  1407.         
  1408.         
  1409.         $rubriques = array();
  1410.         if($request->getMethod() == 'POST'){
  1411.             $idEmploye $request->request->get('idEmploye');
  1412.             $mois = (int)$request->request->get('mois');
  1413.             $annee $request->request->get('annee');
  1414.             $moyenDePaiement $request->request->get('moyenDePaiement');
  1415.             $employe $em->getRepository(UserBoutique::class)
  1416.                     ->findOneBy(
  1417.                         array(
  1418.                             'user' => $idEmploye,
  1419.                             'boutique' => $boutique->getId()
  1420.                         )    
  1421.                     );
  1422.             if($mois 10){
  1423.                 $mois '0'.$mois;
  1424.             }
  1425.             $dateDebutPaiementSalaire $annee.'-'.$mois.'-01';
  1426.             $dateDebutPaiementSalaire = new \DateTime($dateDebutPaiementSalaire);
  1427.             $laDatePaiement $annee.'-'.$mois.'-01';
  1428.             
  1429.             $datePaiementSalaire = new \DateTime($laDatePaiement);
  1430.             $datePaiementSalaire $datePaiementSalaire->modify('last day of this month');
  1431.             $anncienete $employe->getDateDePriseDeFonction()->diff($datePaiementSalaire);
  1432.             $nNombreDeJourDeTravail 30;
  1433.             $nNombreDeJourDeConge 0;
  1434.             
  1435.             //Salaire de base
  1436.             $salaireDeBase $em->getRepository(RubriqueSalaireEmploye::class)
  1437.                                         ->findOneBy(
  1438.                                             array(
  1439.                                                 'boutique' => $boutique->getId(),
  1440.                                                 'user' => $employe->getUser()->getId(),
  1441.                                                 'designation' => 'SALAIRE DE BASE'
  1442.                                             )
  1443.                                         );
  1444.             
  1445.             
  1446.             $rSalaireDeBase $salaireDeBase->getLaBase();
  1447.             
  1448.             //Congé
  1449.             $totaux = array();
  1450.             $conge $em->getRepository(Conge::class)
  1451.                         ->dernierConge($boutique->getId(), $employe->getUser()->getId());
  1452.             $bFautAjouterCongePaye false;
  1453.             if(!empty($conge)){
  1454.                 $dateDebut $conge[0]->getDateDebut();
  1455.                 $dateDiff $dateDebut->diff($datePaiementSalaire);
  1456.                 $nombreDeJour $dateDiff->format("%a");
  1457.                 if($nombreDeJour && $nombreDeJour <= 30 ){
  1458.                     $totaux['dateDebutConge'] = $conge[0]->getDateDebut();
  1459.                     $totaux['dateFinConge'] = $conge[0]->getDateFin();
  1460.                     $nNombreDeJourDeConge =  $conge[0]->getNombreDeJour();
  1461.                     $bFautAjouterCongePaye true;
  1462.                     if($datePaiementSalaire $conge[0]->getDateDebut()){
  1463.                         $nNombreDeJourDeTravail -= $nNombreDeJourDeConge;
  1464.                     }
  1465.                     $rSalaireDeBase = ($salaireDeBase->getLaBase() * $nNombreDeJourDeTravail)/30;
  1466.                 }
  1467.             }
  1468.             $rubrique = array(
  1469.                     'code' => $salaireDeBase->getCode(),
  1470.                     'designation' => $salaireDeBase->getDesignation(),
  1471.                     'nombre' => $nNombreDeJourDeTravail,
  1472.                     'base' => $rSalaireDeBase,
  1473.                     'tauxSalarial' => 0,
  1474.                     'gainSalarial' => $rSalaireDeBase,
  1475.                     'retenueSalarial' => 0,
  1476.                     'tauxPatronal' => 0,
  1477.                     'gainPatronal' => 0,
  1478.                     'retenuePatronal' => 0
  1479.                 
  1480.                 );    
  1481.                 array_push($rubriques$rubrique);
  1482.             
  1483.             
  1484.             $rIndemniteCongePaye 0;
  1485.             if($bFautAjouterCongePaye){
  1486.                 $rIndemniteCongePaye = ($salaireDeBase->getLaBase() * 12 $nNombreDeJourDeConge)/(10 30);
  1487.                 $rubrique = array(
  1488.                     'code' => '100',
  1489.                     'designation' => 'INDEMNITE CONGE PAYE',
  1490.                     'nombre' => $nNombreDeJourDeConge,
  1491.                     'base' => $rIndemniteCongePaye,
  1492.                     'tauxSalarial' => '',
  1493.                     'gainSalarial' => $rIndemniteCongePaye,
  1494.                     'retenueSalarial' => '',
  1495.                     'tauxPatronal' => '',
  1496.                     'gainPatronal' => '',
  1497.                     'retenuePatronal' => ''
  1498.                 
  1499.                 );
  1500.                 array_push($rubriques$rubrique);
  1501.                 
  1502.             }
  1503.             //Sursalaire
  1504.             $surSalaire $em->getRepository(RubriqueSalaireEmploye::class)
  1505.                                         ->findOneBy(
  1506.                                             array(
  1507.                                                 'boutique' => $boutique->getId(),
  1508.                                                 'user' => $employe->getUser()->getId(),
  1509.                                                 'designation' => 'SURSALAIRE'
  1510.                                             )
  1511.                                         );
  1512.             $rubrique = array(
  1513.                     'code' => $surSalaire->getCode(),
  1514.                     'designation' => $surSalaire->getDesignation(),
  1515.                     'nombre' => $nNombreDeJourDeTravail,
  1516.                     'base' => $surSalaire->getLaBase(),
  1517.                     'tauxSalarial' => '',
  1518.                     'gainSalarial' => $surSalaire->getLaBase(),
  1519.                     'retenueSalarial' => '',
  1520.                     'tauxPatronal' => '',
  1521.                     'gainPatronal' => '',
  1522.                     'retenuePatronal' => ''
  1523.                 
  1524.                 );    
  1525.                 array_push($rubriques$rubrique);
  1526.         
  1527.             //
  1528.             // Ancienneté
  1529.             $anciennte 0;
  1530.             $dateAnciennete $datePaiementSalaire->diff($employe->getDateDePriseDeFonction());
  1531.             $anneeAnciennete $dateAnciennete->format('%y');
  1532.             $moisAnciennete $dateAnciennete->format('%m');
  1533.             if(($anneeAnciennete >= && $moisAnciennete >= 1) || $anneeAnciennete 2){
  1534.                 $anciennte $anneeAnciennete;
  1535.             }
  1536.             $rMontantAnciennete = ($anciennte $salaireDeBase->getLaBase())/100;
  1537.             $rubrique = array(
  1538.                         'code' => $salaireDeBase->getCode(),
  1539.                         'designation' => 'ANCIENNETE',
  1540.                         'nombre' => '',
  1541.                         'base' => $salaireDeBase->getLaBase(),
  1542.                         'tauxSalarial' => $anciennte,
  1543.                         'gainSalarial' => $rMontantAnciennete,
  1544.                         'retenueSalarial' => '',
  1545.                         'tauxPatronal' => '',
  1546.                         'gainPatronal' => '',
  1547.                         'retenuePatronal' => ''
  1548.                     
  1549.                     );    
  1550.             array_push($rubriques$rubrique);
  1551.             $userBoutique $em->getRepository(UserBoutique::class)
  1552.                             ->findOneBy(
  1553.                                 array(
  1554.                                 'user' => $user->getId(),
  1555.                                 'boutique' => $boutique->getId()
  1556.                                 )
  1557.                             );
  1558.             $rTotalBrut $rSalaireDeBase +  $surSalaire->getLaBase() + $rMontantAnciennete $rIndemniteCongePaye;
  1559.             $rubrique = array(
  1560.                         'code' => '',
  1561.                         'designation' => 'TOTAL BRUT',
  1562.                         'nombre' => '',
  1563.                         'base' => '',
  1564.                         'tauxSalarial' => '',
  1565.                         'gainSalarial' => $rTotalBrut,
  1566.                         'retenueSalarial' => '',
  1567.                         'tauxPatronal' => '',
  1568.                         'gainPatronal' => '',
  1569.                         'retenuePatronal' => ''
  1570.                     
  1571.                     );    
  1572.             array_push($rubriques$rubrique);
  1573.             $rImpotNet 0;
  1574.             $rTranche1 0;
  1575.             $rTranche2 0;
  1576.             if($rTotalBrut 75000 && $rTotalBrut <= 240000){
  1577.                 $rTranche2 = (($rTotalBrut 75000)*16)/100;
  1578.             }else{
  1579.                 if($rTotalBrut 240000){
  1580.                     $rTranche2 = ((240000 75000)*16)/100;
  1581.                 }
  1582.             }
  1583.             $rTranche3 0;
  1584.             if ($rTotalBrut 240000 && $rTotalBrut <= 800000){
  1585.                 $rTranche3 = (($rTotalBrut 240000)*21)/100;
  1586.             }else{
  1587.                 if($rTotalBrut 800000){
  1588.                     $rTranche3 = ((800000 240000)*21)/100;
  1589.                 }
  1590.             }
  1591.             $rTranche4  0;
  1592.             if($rTotalBrut 800000 && $rTotalBrut <= 2400000){
  1593.                 $rTranche4 = (($rTotalBrut 800000)*24)/100;
  1594.             } else{
  1595.                 if($rTotalBrut 2400000){
  1596.                     $rTranche4 = ((2400000 800000)*24)/100;
  1597.                 }
  1598.             }
  1599.             $rTranche5 0;
  1600.             if($rTotalBrut 2400000 && $rTotalBrut <= 8000000){
  1601.                 $rTranche5 = ((rTotalBrut 2400000)*28)/100;
  1602.             } else{
  1603.                 if($rTotalBrut 8000000){
  1604.                     $rTranche5 = ((8000000 2400000)*28)/100;
  1605.                 }
  1606.             }
  1607.             $rTranche6 0;
  1608.             if($rTotalBrut 8000000){
  1609.                 $rTranche6 = ((rTotalBrut 8000000)*32)/100;
  1610.             }
  1611.             $rImpotBrut $rTranche1 $rTranche2 $rTranche3 $rTranche4 $rTranche5 $rTranche6;
  1612.             
  1613.             $rPartIGR  $employe->getIgr();
  1614.             $rReductionImpt1  0;
  1615.             $rReductionImpt2 0;
  1616.             if ($rPartIGR == 1.5){
  1617.                 $rReductionImpt2 5500;
  1618.             }
  1619.             $rReductionImpt3 0;
  1620.             if($rPartIGR == 2){
  1621.                 $rReductionImpt3 11000;
  1622.             }
  1623.             $rReductionImpt4 0;
  1624.             if($rPartIGR == 2.5){
  1625.                 $rReductionImpt4 16500;
  1626.             }
  1627.             $rReductionImpt5  0;
  1628.             if($rPartIGR == 3){
  1629.                 $rReductionImpt5 22000;
  1630.             }
  1631.             $rReductionImpt6 0;
  1632.             if($rPartIGR == 3.5){
  1633.                 $rReductionImpt6 27500;
  1634.             }
  1635.             $rReductionImpt7 0;
  1636.             if($rPartIGR == 4){
  1637.                 $rReductionImpt7 33000;
  1638.             }
  1639.             $rReductionImpt8 0;
  1640.             if($rPartIGR == 4.5){
  1641.                 $rReductionImpt8 38500;
  1642.             }
  1643.             $rReductionImpt9 0;
  1644.             if($rPartIGR == 5){
  1645.                 $rReductionImpt9 44000;
  1646.             }
  1647.             $rReduction $rReductionImpt1 $rReductionImpt2 $rReductionImpt3 $rReductionImpt4 $rReductionImpt5 $rReductionImpt6 $rReductionImpt7 $rReductionImpt8 $rReductionImpt9;
  1648.             $rImpotNet $rImpotBrut $rReduction;
  1649.             if($rImpotNet <= 0){
  1650.                 $rImpotNet 0;
  1651.             }
  1652.             $rubrique = array(
  1653.                         'code' => '04',
  1654.                         'designation' => 'IMPOT NET',
  1655.                         'nombre' => '',
  1656.                         'base' => '',
  1657.                         'tauxSalarial' => '',
  1658.                         'gainSalarial' => '',
  1659.                         'retenueSalarial' => $rImpotNet,
  1660.                         'tauxPatronal' => '',
  1661.                         'gainPatronal' => '',
  1662.                         'retenuePatronal' => ''
  1663.                     
  1664.                     );    
  1665.             array_push($rubriques$rubrique);
  1666.             
  1667.             $rCNPSSalarie 0;
  1668.             $rCNPSEmployeur 0;
  1669.             $cnps $em->getRepository(RubriqueSalaireEmploye::class)
  1670.                                             ->findOneBy(
  1671.                                                 array(
  1672.                                                     'boutique' => $boutique->getId(),
  1673.                                                     'user' => $employe->getUser()->getId(),
  1674.                                                     'designation' => 'CNPS'
  1675.                                                 )
  1676.                                             );
  1677.         $rCNPSSalarie = ($rTotalBrut 6.3)/100;
  1678.         $rCNPSEmployeur = ($rTotalBrut 7.7)/100;
  1679.         
  1680.         $rubrique = array(
  1681.                         'code' => $cnps->getCode(),
  1682.                         'designation' => $cnps->getDesignation(),
  1683.                         'nombre' => '',
  1684.                         'base' => $rTotalBrut,
  1685.                         'tauxSalarial' => 6.3,
  1686.                         'gainSalarial' => '',
  1687.                         'retenueSalarial' => $rCNPSSalarie,
  1688.                         'tauxPatronal' => 7.7,
  1689.                         'gainPatronal' => '',
  1690.                         'retenuePatronal' => $rCNPSEmployeur
  1691.                     
  1692.                     );    
  1693.         array_push($rubriques$rubrique);
  1694.         $rCMU 1000 1000 $employe->getNombreDEnfant();
  1695.         $rCMUSalarie $rCMU/2;
  1696.         $rCMUEmployeur $rCMU/2;
  1697.         $cmu $em->getRepository(RubriqueSalaireEmploye::class)
  1698.                                             ->findOneBy(
  1699.                                                 array(
  1700.                                                     'boutique' => $boutique->getId(),
  1701.                                                     'user' => $employe->getUser()->getId(),
  1702.                                                     'designation' => 'CMU'
  1703.                                                 )
  1704.                                             );
  1705.         
  1706.         $rubrique = array(
  1707.                         'code' => $cmu->getCode(),
  1708.                         'designation' => $cmu->getDesignation(),
  1709.                         'nombre' => '',
  1710.                         'base' => '',
  1711.                         'tauxSalarial' => '',
  1712.                         'gainSalarial' => '',
  1713.                         'retenueSalarial' => $rCMUSalarie,
  1714.                         'tauxPatronal' => '',
  1715.                         'gainPatronal' => '',
  1716.                         'retenuePatronal' => $rCMUEmployeur
  1717.                     
  1718.                     );
  1719.         
  1720.         array_push($rubriques$rubrique);
  1721.         $rPrestationFamiliale 0;
  1722.         $prestation $em->getRepository(RubriqueSalaireEmploye::class)
  1723.                                             ->findOneBy(
  1724.                                                 array(
  1725.                                                     'boutique' => $boutique->getId(),
  1726.                                                     'user' => $employe->getUser()->getId(),
  1727.                                                     'designation' => 'PRESTATION FAMILIALE'
  1728.                                                 )
  1729.                                             );
  1730.         $rPrestationFamiliale = ($prestation->getLaBase() * $prestation->getTaux())/100;
  1731.         $rubrique = array(
  1732.                         'code' => $prestation->getCode(),
  1733.                         'designation' => $prestation->getDesignation(),
  1734.                         'nombre' => '',
  1735.                         'base' => $prestation->getLaBase(),
  1736.                         'tauxSalarial' => '',
  1737.                         'gainSalarial' => '',
  1738.                         'retenueSalarial' => '',
  1739.                         'tauxPatronal' => $prestation->getTaux(),
  1740.                         'gainPatronal' => '',
  1741.                         'retenuePatronal' => $rPrestationFamiliale
  1742.                     
  1743.                     );
  1744.         
  1745.         array_push($rubriques$rubrique);
  1746.         $rAccidentDeTravail 0;
  1747.         $accident $em->getRepository(RubriqueSalaireEmploye::class)
  1748.                                             ->findOneBy(
  1749.                                                 array(
  1750.                                                     'boutique' => $boutique->getId(),
  1751.                                                     'user' => $employe->getUser()->getId(),
  1752.                                                     'designation' => 'ACCIDENT DE TRAVAIL'
  1753.                                                 )
  1754.                                             );
  1755.     $rAccidentDeTravail = ($accident->getLaBase() * $accident->getTaux())/100;
  1756.     $rubrique = array(
  1757.                         'code' => $accident->getCode(),
  1758.                         'designation' => $accident->getDesignation(),
  1759.                         'nombre' => '',
  1760.                         'base' => $accident->getLaBase(),
  1761.                         'tauxSalarial' => '',
  1762.                         'gainSalarial' => '',
  1763.                         'retenueSalarial' => '',
  1764.                         'tauxPatronal' => $accident->getTaux(),
  1765.                         'gainPatronal' => '',
  1766.                         'retenuePatronal' => $rAccidentDeTravail
  1767.                     
  1768.                     );
  1769.         
  1770.         array_push($rubriques$rubrique);
  1771.         $rTaxeDApprentissage 0;
  1772.         $taxeAppr $em->getRepository(RubriqueSalaireEmploye::class)
  1773.                                             ->findOneBy(
  1774.                                                 array(
  1775.                                                     'boutique' => $boutique->getId(),
  1776.                                                     'user' => $employe->getUser()->getId(),
  1777.                                                     'designation' => 'TAXE D\'APPRENTISSAGE'
  1778.                                                 )
  1779.                                             );
  1780.     $rTaxeDApprentissage = ($rTotalBrut $taxeAppr->getTaux())/100;
  1781.     $rubrique = array(
  1782.                         'code' => $taxeAppr->getCode(),
  1783.                         'designation' => $taxeAppr->getDesignation(),
  1784.                         'nombre' => '',
  1785.                         'base' => $rTotalBrut,
  1786.                         'tauxSalarial' => '',
  1787.                         'gainSalarial' => '',
  1788.                         'retenueSalarial' => '',
  1789.                         'tauxPatronal' => $taxeAppr->getTaux(),
  1790.                         'gainPatronal' => '',
  1791.                         'retenuePatronal' => $rTaxeDApprentissage
  1792.                     
  1793.                     );
  1794.         
  1795.         array_push($rubriques$rubrique);
  1796.         $rFormationContinue 0;
  1797.         $formationC $em->getRepository(RubriqueSalaireEmploye::class)
  1798.                                             ->findOneBy(
  1799.                                                 array(
  1800.                                                     'boutique' => $boutique->getId(),
  1801.                                                     'user' => $employe->getUser()->getId(),
  1802.                                                     'designation' => 'FORMATION CONTINUE'
  1803.                                                 )
  1804.                                             );
  1805.     $rFormationContinue = ($rTotalBrut $formationC->getTaux())/100;
  1806.     $rubrique = array(
  1807.                         'code' => $formationC->getCode(),
  1808.                         'designation' => $formationC->getDesignation(),
  1809.                         'nombre' => '',
  1810.                         'base' => $rTotalBrut,
  1811.                         'tauxSalarial' => '',
  1812.                         'gainSalarial' => '',
  1813.                         'retenueSalarial' => '',
  1814.                         'tauxPatronal' => $formationC->getTaux(),
  1815.                         'gainPatronal' => '',
  1816.                         'retenuePatronal' => $rFormationContinue
  1817.                     
  1818.                     );
  1819.         
  1820.         array_push($rubriques$rubrique);
  1821.         $rCE 0;
  1822.         $ce $em->getRepository(RubriqueSalaireEmploye::class)
  1823.                                             ->findOneBy(
  1824.                                                 array(
  1825.                                                     'boutique' => $boutique->getId(),
  1826.                                                     'user' => $employe->getUser()->getId(),
  1827.                                                     'designation' => 'CE'
  1828.                                                 )
  1829.                                             );
  1830.     $rCE = ($rTotalBrut *2.8 )/100;
  1831.     $rubrique = array(
  1832.                         'code' => $ce->getCode(),
  1833.                         'designation' => $ce->getDesignation(),
  1834.                         'nombre' => '',
  1835.                         'base' => '',
  1836.                         'tauxSalarial' => '',
  1837.                         'gainSalarial' => '',
  1838.                         'retenueSalarial' => '',
  1839.                         'tauxPatronal' => 2.8,
  1840.                         'gainPatronal' => '',
  1841.                         'retenuePatronal' => $rCE
  1842.                     
  1843.                     );
  1844.         
  1845.         array_push($rubriques$rubrique);
  1846.         $rChargeSalariales $rImpotNet $rCNPSSalarie $rCMUSalarie;
  1847.         $rChargeEmployeur $rCNPSEmployeur $rCE $rCMUEmployeur $rPrestationFamiliale $rAccidentDeTravail $rTaxeDApprentissage $rFormationContinue;
  1848.         
  1849.         $rubrique = array(
  1850.                         'code' => '',
  1851.                         'designation' => 'TOTAL COTISATION',
  1852.                         'nombre' => '',
  1853.                         'base' => '',
  1854.                         'tauxSalarial' => '',
  1855.                         'gainSalarial' => '',
  1856.                         'retenueSalarial' => $rChargeSalariales,
  1857.                         'tauxPatronal' => '',
  1858.                         'gainPatronal' => '',
  1859.                         'retenuePatronal' => $rChargeEmployeur
  1860.                     
  1861.                     );
  1862.         
  1863.         array_push($rubriques$rubrique);
  1864.         $primeDeTransport $em->getRepository(RubriqueSalaireEmploye::class)
  1865.                                             ->findOneBy(
  1866.                                                 array(
  1867.                                                     'boutique' => $boutique->getId(),
  1868.                                                     'user' => $employe->getUser()->getId(),
  1869.                                                     'designation' => 'PRIME DE TRANSPORT'
  1870.                                                 )
  1871.                                             );
  1872.     $rubrique = array(
  1873.                         'code' => $primeDeTransport->getCode(),
  1874.                         'designation' => $primeDeTransport->getDesignation(),
  1875.                         'nombre' => '',
  1876.                         'base' => $primeDeTransport->getLaBase(),
  1877.                         'tauxSalarial' => '',
  1878.                         'gainSalarial' => $primeDeTransport->getLaBase(),
  1879.                         'retenueSalarial' => '',
  1880.                         'tauxPatronal' => '',
  1881.                         'gainPatronal' => '',
  1882.                         'retenuePatronal' => ''
  1883.                     
  1884.                     );
  1885.         
  1886.         array_push($rubriques$rubrique);
  1887.     $rPrimeDeSalissure 0;
  1888.     $salissure $em->getRepository(RubriqueSalaireEmploye::class)
  1889.                                             ->findOneBy(
  1890.                                                 array(
  1891.                                                     'boutique' => $boutique->getId(),
  1892.                                                     'user' => $employe->getUser()->getId(),
  1893.                                                     'designation' => 'PRIME DE SALISSURE'
  1894.                                                 )
  1895.                                             );
  1896.     if($salissure != null){
  1897.         $rPrimeDeSalissure $salissure->getLaBase() * 7;
  1898.         if($rPrimeDeSalissure 0){ 
  1899.             
  1900.         $rubrique = array(
  1901.                             'code' => $salissure->getCode(),
  1902.                             'designation' => $salissure->getDesignation(),
  1903.                             'nombre' => 7,
  1904.                             'base' => $salissure->getLaBase(),
  1905.                             'tauxSalarial' => '',
  1906.                             'gainSalarial' => $rPrimeDeSalissure,
  1907.                             'retenueSalarial' => '',
  1908.                             'tauxPatronal' => '',
  1909.                             'gainPatronal' => '',
  1910.                             'retenuePatronal' => ''
  1911.                         
  1912.                         );
  1913.             
  1914.             array_push($rubriques$rubrique);
  1915.         }
  1916.     }
  1917.         $rPrimeDeTenue 0;
  1918.         $tenue $em->getRepository(RubriqueSalaireEmploye::class)
  1919.                                             ->findOneBy(
  1920.                                                 array(
  1921.                                                     'boutique' => $boutique->getId(),
  1922.                                                     'user' => $employe->getUser()->getId(),
  1923.                                                     'designation' => 'PRIME DE TENUE'
  1924.                                                 )
  1925.                                             );
  1926.         if($tenue != null){
  1927.             $rPrimeDeTenue $tenue->getLaBase() * 3;
  1928.             if($rPrimeDeTenue 0){
  1929.                 
  1930.                 $rubrique = array(
  1931.                                 'code' => $tenue->getCode(),
  1932.                                 'designation' => $tenue->getDesignation(),
  1933.                                 'nombre' => 3,
  1934.                                 'base' => $tenue->getLaBase(),
  1935.                                 'tauxSalarial' => '',
  1936.                                 'gainSalarial' => $rPrimeDeTenue,
  1937.                                 'retenueSalarial' => '',
  1938.                                 'tauxPatronal' => '',
  1939.                                 'gainPatronal' => '',
  1940.                                 'retenuePatronal' => ''
  1941.                             
  1942.                             );
  1943.                 
  1944.                 array_push($rubriques$rubrique);
  1945.             }
  1946.         }
  1947.     //Heures supplementaires
  1948.     $heureDeTravail $em->getRepository(PresenceEmployeUser::class)
  1949.                             ->heureDeTravail($boutique$dateDebutPaiementSalaire$datePaiementSalaire);
  1950.     $heuresSupplementaires 0;
  1951.     $heuresTravaillees 0;
  1952.         $rTauxHoraire 470;
  1953.         $rValeureuresSupplementaires 0;
  1954.         if(!empty($heureDeTravail)){
  1955.             $lesHeurs = (float)$heureDeTravail[0]['heureSupplementaire'];
  1956.             $heuresTravaillees $heureDeTravail[0]['tempsDeTravail'];
  1957.             $heuresSupplementaires =  $heureDeTravail[0]['heureSupplementaire'];
  1958.             if( $lesHeurs0){
  1959.                     $rValeureuresSupplementaires $lesHeurs *  $rTauxHoraire * (1.25);
  1960.             
  1961.                     $rubrique = array(
  1962.                                 'code' => '00',
  1963.                                 'designation' => 'HEURES SUPPLEMENTAIRES',
  1964.                                 'nombre' => $lesHeurs,
  1965.                                 'base' => $rTauxHoraire,
  1966.                                 'tauxSalarial' => '',
  1967.                                 'gainSalarial' => $rValeureuresSupplementaires,
  1968.                                 'retenueSalarial' => '',
  1969.                                 'tauxPatronal' => '',
  1970.                                 'gainPatronal' => '',
  1971.                                 'retenuePatronal' => ''
  1972.                             
  1973.                             );
  1974.                 
  1975.                 array_push($rubriques$rubrique);
  1976.             }
  1977.         }
  1978.         $supprimerPaiementSalaireDUnMoisDunEmploye $em->getRepository(RubriqueSalairePaiement::class)
  1979.                                                     ->findBy(
  1980.                                                         array(
  1981.                                                             'boutique' => $boutique->getId(),
  1982.                                                             'user' => $employe->getUser()->getId(),
  1983.                                                             'moisPaiementSalaire' =>$mois,
  1984.                                                             'anneePaiementSalaire' => $annee
  1985.                                                         )
  1986.                                                     );
  1987.         foreach($supprimerPaiementSalaireDUnMoisDunEmploye as $rb){
  1988.             $em->remove($rb);
  1989.         }
  1990.         $em->flush();
  1991.         foreach($rubriques as $rub){
  1992.             $rubriqueSalairePaiement = new RubriqueSalairePaiement;
  1993.             $rubriqueSalairePaiement->setBoutique($boutique);
  1994.             $rubriqueSalairePaiement->setUser($employe->getUser());
  1995.             $rubriqueSalairePaiement->setCode($rub['code']);
  1996.             $rubriqueSalairePaiement->setDesignation($rub['designation']);
  1997.             $rubriqueSalairePaiement->setNombre((float)$rub['nombre']);
  1998.             $rubriqueSalairePaiement->setLaBase((float)$rub['base']);
  1999.             $rubriqueSalairePaiement->setTauxSalarial((float)$rub['tauxSalarial']);
  2000.             $rubriqueSalairePaiement->setGainSalarial((float)$rub['gainSalarial']);
  2001.             $rubriqueSalairePaiement->setRetenueSalarial((float)$rub['retenueSalarial']);
  2002.             $rubriqueSalairePaiement->setTauxPatronal((float)$rub['tauxPatronal']);
  2003.             $rubriqueSalairePaiement->setGainPatronal((float)$rub['gainPatronal']);
  2004.             $rubriqueSalairePaiement->setRetenuePatronal((float)$rub['retenuePatronal']);
  2005.             $rubriqueSalairePaiement->setMoisPaiementSalaire($mois);
  2006.             $rubriqueSalairePaiement->setAnneePaiementSalaire($annee);
  2007.             $rubriqueSalairePaiement->setDatePaiementSalaire(new \DateTime());
  2008.             $em->persist($rubriqueSalairePaiement);
  2009.         }
  2010.         $em->flush();
  2011.         $paiementSalaireASupprimer $em->getRepository(PaiementSalaire::class)
  2012.                                         ->findOneBy(
  2013.                                             array(
  2014.                                                 'boutique' => $boutique->getId(),
  2015.                                                 'user' =>$employe->getUser()->getId(),
  2016.                                                 'moisSalaire' =>$mois,
  2017.                                                 'anneeSalaire' => $annee
  2018.                                             )
  2019.                                         );
  2020.         if($paiementSalaireASupprimer != null){
  2021.             $em->remove($paiementSalaireASupprimer);
  2022.             $em->flush();
  2023.         }
  2024.         $salaireNetAPayer $rTotalBrut $rChargeSalariales $primeDeTransport->getLaBase();
  2025.         $paiementSalaire = new PaiementSalaire;
  2026.         $paiementSalaire->setBoutique($boutique);
  2027.         $paiementSalaire->setUser($employe->getUser());
  2028.         $paiementSalaire->setSalaireBrut($rTotalBrut);
  2029.         $paiementSalaire->setChargesSalariales($rChargeSalariales);
  2030.         $paiementSalaire->setChargesPatronales($rChargeEmployeur);
  2031.         $paiementSalaire->setHeuresTravaillees($heuresTravaillees);
  2032.         $paiementSalaire->setHeuresSupplementaires($heuresSupplementaires);
  2033.         $paiementSalaire->setSalaireNetAPayer($salaireNetAPayer);
  2034.         $paiementSalaire->setDatePaiementFinDuMois($datePaiementSalaire);
  2035.         $paiementSalaire->setMoisSalaire($mois);
  2036.         $paiementSalaire->setAnneeSalaire($annee);
  2037.         $cumulElementPaiementSalaire $em->getRepository(PaiementSalaire::class)
  2038.                                         ->cumulElementPaiementSalaire($boutique->getId(), $employe->getUser()->getId(), new \DateTime());
  2039.         
  2040.         $cumulSalaireBrut $rTotalBrut + (float)$cumulElementPaiementSalaire['0']['cumulSalaireBrut'];
  2041.         $paiementSalaire->setCumulSalaireBrut($cumulSalaireBrut);
  2042.         
  2043.         $cumulChargesSalariales $rChargeSalariales + (float)$cumulElementPaiementSalaire['0']['cumulChargesSalariales'];
  2044.         $paiementSalaire->setCumulChargesSalariales($cumulChargesSalariales);
  2045.         $cumulChargesPatronales $rChargeEmployeur + (float)$cumulElementPaiementSalaire['0']['cumulChargesPatronales'];
  2046.         $paiementSalaire->setCumulChargesPatronales($cumulChargesPatronales);
  2047.         $cumulHeuresTravaillees =  $heuresTravaillees + (float)$cumulElementPaiementSalaire['0']['cumulHeuresTravaillees'];
  2048.         $paiementSalaire->setCumulHeuresTravaillees($cumulHeuresTravaillees);
  2049.         $cumulHeuresSupplementaires $heuresSupplementaires + (float)$cumulElementPaiementSalaire['0']['cumulHeuresSupplementaires'];
  2050.         $paiementSalaire->setCumulHeuresSupplementaires($cumulHeuresSupplementaires);
  2051.         $cumulSalaireNetAPayer $salaireNetAPayer + (float)$cumulElementPaiementSalaire['0']['cumulSalaireNetAPayer'];
  2052.         $paiementSalaire->setCumulSalaireNetAPayer($cumulSalaireNetAPayer);
  2053.         $em->persist($paiementSalaire);
  2054.         $em->flush();
  2055. }
  2056.         return $this->render('admin/calculer_salaire.html.twig', [
  2057.            'boutique' => $boutique,
  2058.            'userBoutique' => $userBoutique
  2059.         ]);
  2060.     }
  2061.     /**
  2062.      * @Route("/{slug}/rh/imprimer-bulletin-salaire/{employe}/{dateDebut}/{dateFin}/{moyenDePaiement}", name="admin_imprimer_bulletin_salaire")
  2063.      * @return \Symfony\Component\HttpFoundation\Response
  2064.      */
  2065.     public function imprimerBulletinSalaireActionRequest $requestBoutique $boutique$employe 0$dateDebut ''$dateFin ''$moyenDePaiement '')
  2066.     {
  2067.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2068.            return $this->redirectToRoute('security_login');
  2069.         }  
  2070.         $em $this->getDoctrine()
  2071.                     ->getManager();
  2072.         
  2073.         $user $this->getUser();
  2074.         $employe $em->getRepository(UserBoutique::class)
  2075.                     ->findOneBy(
  2076.                         array(
  2077.                             'boutique' => $boutique,
  2078.                             'user' => $employe
  2079.                         )
  2080.                     );
  2081.         $dateDebut = new \DateTime($dateDebut);
  2082.         $dateFin = new \DateTime($dateFin);
  2083.         $userBoutique $em->getRepository(UserBoutique::class)
  2084.                         ->findOneBy(
  2085.                             array(
  2086.                             'user' => $user->getId(),
  2087.                             'boutique' => $boutique->getId()
  2088.                             )
  2089.                         );
  2090.         
  2091.         $rubriques $em->getRepository(RubriqueSalairePaiement::class)
  2092.                                         ->findBy(
  2093.                                             array(
  2094.                                                 'boutique' => $boutique->getId(),
  2095.                                                 'user' => $employe->getUser()->getId(),
  2096.                                                 'moisPaiementSalaire' => $dateDebut->format('m'),
  2097.                                                 'anneePaiementSalaire' => $dateDebut->format('Y')
  2098.                                             )
  2099.                                         );
  2100.         $paiementSalaire $em->getRepository(PaiementSalaire::class)
  2101.                                         ->findOneBy(
  2102.                                             array(
  2103.                                                 'boutique' => $boutique->getId(),
  2104.                                                 'user' =>$employe->getUser()->getId(),
  2105.                                                 'moisSalaire' =>$dateDebut->format('m'),
  2106.                                                 'anneeSalaire' => $dateDebut->format('Y')
  2107.                                             )
  2108.                                         );
  2109.         
  2110.         $pdf = new Html2Pdf('P''A4''fr');
  2111.         $content $this->renderView('pdf/bulletin_de_salaire.html.twig', [
  2112.                         'boutique' => $boutique,
  2113.                         'dateDebut' => $dateDebut,
  2114.                         'dateFin' => $dateFin,
  2115.                         'moyenDePaiement' => $moyenDePaiement,
  2116.                         'rubriques' => $rubriques,
  2117.                         'employe' => $employe,
  2118.                         'paiementSalaire' => $paiementSalaire
  2119.                     ]);
  2120.         $pdf->writeHTML($content);
  2121.         $name $employe->getUser()->getId().time().$boutique->getId().rand(110000).'.pdf';
  2122.         $photo = new Photo;
  2123.         $lienPhysique $photo->getUploadRootDir().$name;
  2124.                 
  2125.         $pdf->output($lienPhysique'I');
  2126.         
  2127.         return $this->render('pdf/bulletin_de_salaire.html.twig', [
  2128.            'boutique' => $boutique,
  2129.             'rubriques' => $rubriques,
  2130.            'userBoutique' => $userBoutique
  2131.         ]);
  2132.     }
  2133.     /**
  2134.      * @Route("/{slug}/rh/rubriques-salaires", name="admin_rubriques_slaires")
  2135.      * @return \Symfony\Component\HttpFoundation\Response
  2136.      */
  2137.     public function rubriquesSalairesActionRequest $requestBoutique $boutique)
  2138.     {
  2139.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2140.            return $this->redirectToRoute('security_login');
  2141.         }  
  2142.         $em $this->getDoctrine()
  2143.                     ->getManager();
  2144.         
  2145.         $user $this->getUser();
  2146.         
  2147.         
  2148.         $rubriquesSalaires $em->getRepository(RubriqueSalaire::class)
  2149.                     ->findBy(
  2150.                         array(
  2151.                             'boutique' => $boutique->getId(),
  2152.                             
  2153.                         )
  2154.                     );
  2155.         
  2156.         
  2157.         $userBoutique $em->getRepository(UserBoutique::class)
  2158.                         ->findOneBy(
  2159.                             array(
  2160.                             'user' => $user->getId(),
  2161.                             'boutique' => $boutique->getId()
  2162.                             )
  2163.                         );
  2164.         
  2165.         
  2166.         return $this->render('admin/rubriques_slaires.html.twig', [
  2167.            'boutique' => $boutique,
  2168.             'rubriquesSalaires' => $rubriquesSalaires,
  2169.            'userBoutique' => $userBoutique
  2170.         ]);
  2171.     }
  2172.     
  2173.     
  2174.     /**
  2175.      * @Route("/{slug}/rh/editer-rubriques-salaires-employer/{id}", name="admin_editer_rubriques_slaires_employe")
  2176.      * @return \Symfony\Component\HttpFoundation\Response
  2177.      */
  2178.     public function editerRubriquesSalairesEmployeActionRequest $request,  $slug$id)
  2179.     {
  2180.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2181.            return $this->redirectToRoute('security_login');
  2182.         }      
  2183.         $em $this->getDoctrine()
  2184.                     ->getManager();
  2185.         
  2186.         $user $this->getUser();
  2187.         $boutique $em->getRepository(Boutique::class)
  2188.                     ->findOneBySlug($slug);
  2189.         
  2190.         
  2191.         $rubriquesSalaires $em->getRepository(RubriqueSalaire::class)
  2192.                     ->findBy(
  2193.                         array(
  2194.                             'boutique' => $boutique->getId(),    
  2195.                         )
  2196.                     );
  2197.         
  2198.         $employe $em->getRepository(AppUser::class)
  2199.                     ->findOneById($id);
  2200.         $rubriqueSalaireEmployes $em->getRepository(RubriqueSalaireEmploye::class)
  2201.                                 ->findBy(
  2202.                                     array(
  2203.                                         'boutique' => $boutique,
  2204.                                         'user' => $employe
  2205.                                     )
  2206.                                 );
  2207.         $lesRubriques = array();
  2208.         
  2209.         foreach($rubriquesSalaires as $rubriquesSalaire){
  2210.             $estDeDans false;
  2211.             if(empty($rubriqueSalaireEmployes))
  2212.             {
  2213.                 $r = array(
  2214.                             'code' => $rubriquesSalaire->getCode(),
  2215.                             'designation' =>  $rubriquesSalaire->getDesignation(),
  2216.                             'laBase' => '',
  2217.                             'taux' =>  '',
  2218.                             'part' => $rubriquesSalaire->getPart(),
  2219.                             'gainOuRetenu' => $rubriquesSalaire->getGainOuRetenu(),
  2220.                             'existeDeja' => false
  2221.                         );
  2222.                     array_push($lesRubriques$r);
  2223.             }else{
  2224.                 $taux 0;
  2225.             $laBase 0;
  2226.             $existeDeja false;
  2227.             foreach($rubriqueSalaireEmployes as $rubriqueSalaireEmploye){
  2228.                     
  2229.                 if($rubriqueSalaireEmploye->getCode() == $rubriquesSalaire->getCode()){
  2230.                     //existe_deja permet de savoir si le
  2231.                     $taux $rubriqueSalaireEmploye->getTaux();
  2232.                     $laBase $rubriqueSalaireEmploye->getLaBase();
  2233.                     $existeDeja true;
  2234.                 }else{
  2235.                     $existeDeja false;
  2236.                 }
  2237.             }
  2238.             $r = array(
  2239.                     'code' => $rubriquesSalaire->getCode(),
  2240.                     'designation' => $rubriquesSalaire->getDesignation(),
  2241.                     'laBase' => $laBase,
  2242.                     'taux'  => $taux,
  2243.                     'part' =>$rubriquesSalaire->getPart(),
  2244.                     'gainOuRetenu' => $rubriquesSalaire->getGainOuRetenu(),
  2245.                     'existeDeja' => $existeDeja
  2246.                 );
  2247.             array_push($lesRubriques$r);
  2248.             }
  2249.             
  2250.         }
  2251.         if($request->getMethod() == 'POST'){
  2252.             $i 0;
  2253.             foreach($rubriquesSalaires as $rubriquesSalaire){
  2254.                 $i++;
  2255.                 $laBase = (float)$request->request->get('la_base'.$i);
  2256.                 $taux =  (float)$request->request->get('taux'.$i);
  2257.                 $existeDeja = (bool)$request->request->get('existe_deja'.$i);
  2258.                 $rubrique $em->getRepository(RubriqueSalaireEmploye::class)
  2259.                                 ->findOneBy(
  2260.                                     array(
  2261.                                         'boutique' => $boutique,
  2262.                                         'user' => $employe,
  2263.                                         'code' =>$rubriquesSalaire->getCode()
  2264.                                     )
  2265.                                 );
  2266.                 if($rubrique == null){
  2267.                     $rubrique = new RubriqueSalaireEmploye;
  2268.                     $rubrique->setUser($employe);
  2269.                     $rubrique->setBoutique($boutique);
  2270.                     $rubrique->setCode($rubriquesSalaire->getCode());
  2271.                     $rubrique->setDesignation($rubriquesSalaire->getDesignation());
  2272.                     $rubrique->setPart($rubriquesSalaire->getPart());
  2273.                     $rubrique->setGainOuRetenu($rubriquesSalaire->getGainOuRetenu());
  2274.                 }
  2275.                 
  2276.                 $rubrique->setLaBase($laBase);
  2277.                 $rubrique->setTaux($taux);
  2278.                 $em->persist($rubrique);
  2279.                 $em->flush();
  2280.                 
  2281.                 
  2282.                 
  2283.             }
  2284.             return $this->redirectToRoute('admin_rh_salaires', array('slug' => $boutique->getSlug()));
  2285.         }
  2286.         $userBoutique $em->getRepository(UserBoutique::class)
  2287.                         ->findOneBy(
  2288.                             array(
  2289.                             'user' => $user->getId(),
  2290.                             'boutique' => $boutique->getId()
  2291.                             )
  2292.                         );
  2293.         
  2294.         
  2295.         return $this->render('admin/editer_rubriques_slaires_employe.html.twig', [
  2296.            'boutique' => $boutique,
  2297.             'rubriquesSalaires' => $rubriquesSalaires,
  2298.            'userBoutique' => $userBoutique,
  2299.            'employe' => $employe,
  2300.            'rubriqueSalaireEmployes' => $rubriqueSalaireEmployes,
  2301.            'lesRubriques' => $lesRubriques
  2302.         ]);
  2303.     }
  2304.     /**
  2305.      * @Route("/{slug}/rh/rubriques-salaires/nouveau", name="admin_nouvelle_rubrique_slaire")
  2306.      * @return \Symfony\Component\HttpFoundation\Response
  2307.      */
  2308.     public function nouvelleRubriqueSalaireActionRequest $requestBoutique $boutique)
  2309.     {
  2310.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2311.            return $this->redirectToRoute('security_login');
  2312.         }      
  2313.         $em $this->getDoctrine()
  2314.                     ->getManager();
  2315.         
  2316.         $user $this->getUser();
  2317.         
  2318.         $rubriquesSalaire = new RubriqueSalaire;
  2319.         $form $this->createForm(RubriqueSalaireType::class, $rubriquesSalaire);
  2320.         
  2321.         if($request->getMethod() == 'POST'){
  2322.             $form->handleRequest($request);
  2323.             if($form->isValid()){
  2324.                    
  2325.                 $rubriquesSalaire->setBoutique($boutique);
  2326.                    
  2327.                 $em->persist($rubriquesSalaire);
  2328.                 $em->flush();
  2329.                 
  2330.                 $ok_soumission =" Votre message a été pris en compte";
  2331.                     
  2332.                 
  2333.                 $rubriquesSalaire = new RubriqueSalaire;
  2334.                 $form $this->createForm(RubriqueSalaireType::class, $rubriquesSalaire);
  2335.                     
  2336.                 } else {
  2337.                     $error =" Veillez corrigez vos erreurs";
  2338.                 }
  2339.                 
  2340.         
  2341.         }
  2342.         $userBoutique $em->getRepository(UserBoutique::class)
  2343.                         ->findOneBy(
  2344.                             array(
  2345.                             'user' => $user->getId(),
  2346.                             'boutique' => $boutique->getId()
  2347.                             )
  2348.                         );
  2349.         
  2350.         
  2351.         return $this->render('admin/nouvelle_rubrique_salaire.html.twig', [
  2352.            'boutique' => $boutique,
  2353.             
  2354.            'userBoutique' => $userBoutique,
  2355.            'form' =>$form->createView()
  2356.         ]);
  2357.     }
  2358.     
  2359.     /**
  2360.      * @Route("/{slug}/rh/rubriques-salaires/modifier/{id}", name="admin_modifier_rubrique_salaire")
  2361.      * @return \Symfony\Component\HttpFoundation\Response
  2362.      */
  2363.     public function modifierRubriqueSalaireActionRequest $request$slug$id)
  2364.     {
  2365.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2366.            return $this->redirectToRoute('security_login');
  2367.         }      
  2368.         $em $this->getDoctrine()
  2369.                     ->getManager();
  2370.         
  2371.         $user $this->getUser();
  2372.         $boutique $em->getRepository(Boutique::class)
  2373.                                 ->findOneBySlug($slug);
  2374.         
  2375.         $rubriqueSalaire $em->getRepository(RubriqueSalaire::class)
  2376.                                 ->findOneById($id);
  2377.         $form $this->createForm(RubriqueSalaireEditType::class, $rubriqueSalaire);
  2378.         
  2379.         if($request->getMethod() == 'POST'){
  2380.             $form->handleRequest($request);
  2381.             if($form->isValid()){
  2382.     
  2383.                 $em->flush();
  2384.                 
  2385.                 $ok_soumission =" Votre message a été pris en compte";
  2386.                     
  2387.                 } else {
  2388.                     $error =" Veillez corrigez vos erreurs";
  2389.                 }
  2390.                 
  2391.         
  2392.         }
  2393.         $userBoutique $em->getRepository(UserBoutique::class)
  2394.                         ->findOneBy(
  2395.                             array(
  2396.                             'user' => $user->getId(),
  2397.                             'boutique' => $boutique->getId()
  2398.                             )
  2399.                         );
  2400.         
  2401.         
  2402.         return $this->render('admin/modifier_rubrique_salaire.html.twig', [
  2403.            'boutique' => $boutique,
  2404.            'userBoutique' => $userBoutique,
  2405.            'form' =>$form->createView()
  2406.         ]);
  2407.     }
  2408.     /**
  2409.      * @Route("/{slug}/rh/rubriques-salaires/supprimer/{id}", name="admin_supprimer_rubrique_salaire")
  2410.      * @return \Symfony\Component\HttpFoundation\Response
  2411.      */
  2412.     public function supprimerRubriqueSalaireActionRequest $request,  $slug$id)
  2413.     {
  2414.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2415.            return $this->redirectToRoute('security_login');
  2416.         }      
  2417.         $em $this->getDoctrine()
  2418.                     ->getManager();
  2419.         
  2420.         $user $this->getUser();
  2421.         $boutique $em->getRepository(Boutique::class)
  2422.                                 ->findOneBySlug($slug);
  2423.         
  2424.         $rubriquesSalaire $em->getRepository(RubriqueSalaire::class)
  2425.                                 ->findOneById($id);
  2426.     
  2427.         if(null !== $rubriquesSalaire){
  2428.             $em->remove($rubriquesSalaire);
  2429.             $em->flush();
  2430.         }
  2431.         
  2432.         return $this->redirectToRoute('admin_rubriques_slaires', array('slug'=>$boutique->getSlug()));
  2433.     }
  2434.     /**
  2435.      * @Route("/{slug}/rh/conges", name="admin_conges")
  2436.      * @return \Symfony\Component\HttpFoundation\Response
  2437.      */
  2438.     public function congesActionRequest $requestBoutique $boutique)
  2439.     {
  2440.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2441.            return $this->redirectToRoute('security_login');
  2442.         }  
  2443.         $em $this->getDoctrine()
  2444.                     ->getManager();
  2445.         
  2446.         $user $this->getUser();
  2447.     
  2448.         $userBoutiques $em->getRepository(UserBoutique::class)
  2449.                             ->findBy(
  2450.                                 array(
  2451.                                     'boutique' => $boutique->getId(),
  2452.                                     'estParti' => false
  2453.                                 )
  2454.                             );
  2455.         
  2456.         $userBoutique $em->getRepository(UserBoutique::class)
  2457.                         ->findOneBy(
  2458.                             array(
  2459.                             'user' => $user->getId(),
  2460.                             'boutique' => $boutique->getId()
  2461.                             )
  2462.                         );
  2463.         
  2464.         $employes = array();
  2465.         foreach($userBoutiques as $ub){
  2466.             $e = array(
  2467.                 'id' =>$ub->getUser()->getId(),
  2468.                 'name' =>$ub->getUser()->getNom().' '.$ub->getUser()->getPrenom(),
  2469.                 'department' => $ub->getDepartementEmploi()
  2470.             );
  2471.             array_push($employes$e);
  2472.         }
  2473.         $employes json_encode($employes);
  2474.         $conges $em->getRepository(Conge::class)
  2475.                     ->findBy(
  2476.                         array(
  2477.                         'boutique' => $boutique->getId()
  2478.                         )
  2479.                     );
  2480.         $cgs = array();
  2481.         foreach($conges as $conge){
  2482.             $cg = array(
  2483.                 'id' => $conge->getId(),
  2484.                 'employeeId' =>$conge->getUser()->getId(),
  2485.                 'employeeName' => $conge->getUser()->getNom(). ' '.$conge->getUser()->getPrenom(),
  2486.                 'type' => $conge->getTypeConge(),
  2487.                 'startDate' => $conge->getDateDebut()->format('Y-m-d'),
  2488.                 'endDate' => $conge->getDateFin()->format('Y-m-d'),
  2489.                 'notes' => $conge->getNotes()
  2490.             );
  2491.             array_push($cgs$cg);
  2492.         }
  2493.         return $this->render('admin/conges.html.twig', [
  2494.            'boutique' => $boutique,
  2495.            'userBoutiques' => $userBoutiques,
  2496.            'userBoutique' => $userBoutique,
  2497.            'employes' => $employes,
  2498.            'conges' => json_encode($cgs)
  2499.         ]);
  2500.         
  2501.     }    
  2502.     /**
  2503.      * @Route("/{slug}/rh/nouveau-conge", name="admin_rh_nouveau_conge")
  2504.      * @return \Symfony\Component\HttpFoundation\Response
  2505.      */
  2506.     public function nouveauCongeActionRequest $request,  $slug)
  2507.     {
  2508.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2509.            return $this->redirectToRoute('security_login');
  2510.         }
  2511.         $em $this->getDoctrine()
  2512.                     ->getManager();
  2513.         $boutique $em->getRepository(Boutique::class)
  2514.                         ->findOneBySlug($slug);
  2515.         $user $this->getUser();
  2516.         
  2517.         if($request->getMethod() == 'POST'){
  2518.             $employe $request->request->get('employe');
  2519.             $employe $em->getRepository(UserBoutique::class)
  2520.                     ->findOneBy(
  2521.                         array(
  2522.                             'boutique' => $boutique->getId(),
  2523.                             'user'=>$employe
  2524.                         )
  2525.                     );
  2526.             $typeConge $request->request->get('typeConge');
  2527.             $notes $request->request->get('notes');
  2528.             $dateDebut $request->request->get('dateDebut');
  2529.             $dateDebut = new \DateTime($dateDebut);
  2530.         
  2531.             $dateFin $request->request->get('dateFin');
  2532.                 
  2533.             $dateFin = new \DateTime($dateFin);
  2534.             $conge = new Conge;
  2535.             $conge->setDateDebut($dateDebut);
  2536.             $conge->setDateFin($dateFin);
  2537.             $conge->setTypeConge($typeConge);
  2538.             $conge->setNotes($notes);
  2539.             $conge->setUser($employe->getUser());
  2540.             $conge->setBoutique($boutique);
  2541.             
  2542.             $conge->setAnnee($dateDebut->format('Y'));
  2543.             $conge->setMois($dateDebut->format('m'));
  2544.             $nombreDeJour $dateFin->diff($dateDebut)->format("%a");
  2545.             $conge->setNombreDeJour($nombreDeJour);
  2546.             $em->persist($conge);
  2547.             $em->flush();
  2548.             return $this->redirectToRoute('admin_conges', array('slug'=>$boutique->getSlug()));
  2549.         }
  2550.         $userBoutique $em->getRepository(UserBoutique::class)
  2551.                         ->findOneBy(
  2552.                             array(
  2553.                             'user' => $user->getId(),
  2554.                             'boutique' => $boutique->getId()
  2555.                             )
  2556.                         );
  2557.         
  2558.         
  2559.         return $this->render('admin/nouveau_conge.html.twig', [
  2560.            'boutique' => $boutique,
  2561.            'userBoutique' => $userBoutique,
  2562.         ]);
  2563.     }
  2564.     /**
  2565.      * @Route("/{slug}/rh/nouvel-employe", name="admin.nouvel_employe")
  2566.      * @return \Symfony\Component\HttpFoundation\Response
  2567.     */
  2568.     public function nouvelEmployeAction(Request $requestUserPasswordHasherInterface $passwordHasherBoutique $boutique)
  2569.     {
  2570.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2571.            return $this->redirectToRoute('security_login');
  2572.         }
  2573.         $em $this->getDoctrine()
  2574.                     ->getManager();
  2575.         $employe = new AppUser;
  2576.         $form $this->createForm(EmployeType::class, $employe);
  2577.         $error '';
  2578.         $droits DroitUtilisateur::getDroits();
  2579.         $ok_submission '';
  2580.         if('POST' == $request->getMethod()){
  2581.             $form->handleRequest($request);
  2582.             if($form->isValid()){
  2583.                 $employe->setUsername($form->getData()->getNom().$form->getData()->getPrenom().time());
  2584.                 $roles $employe->getRoles();
  2585.                 $roles[] = 'ROLE_EMPLOYE';
  2586.                 $employe->setRoles($roles);
  2587.                 $employe->setEnabled(true);
  2588.                 $employe->setBoutique($boutique);
  2589.                 $email $form->getData()->getEmail();
  2590.                 if($email == ''){
  2591.                     $employe->setEmail($form->getData()->getNom().$form->getData()->getPrenom().time());
  2592.                 }
  2593.                 $motDePasse $request->request->get('mot_de_passe');
  2594.                 $motDePasse $request->request->get('mot_de_passe');
  2595.                 
  2596.                 $sexe $request->request->get('sexe');
  2597.                 
  2598.                 $hashedPassword $passwordHasher->hashPassword($employe$motDePasse);
  2599.                 $employe->setPassword($hashedPassword);
  2600.                 $employe->setSexe($sexe);
  2601.                 $em->persist($employe);
  2602.                 $em->flush();
  2603.                 
  2604.                 $matricule $request->request->get('matricule');
  2605.                 $salaire = (float)$request->request->get('salaire');
  2606.                 $laFonction $request->request->get('la_fonction');
  2607.                 $laQualification $request->request->get('la_qualification');
  2608.                 $categorie $request->request->get('categorie');
  2609.                 $departement $request->request->get('departement');
  2610.                 $dateDePriseDeFonction $request->request->get('date_de_prise_de_fonction');
  2611.                 $dateDePriseDeFonction = new \DateTime($dateDePriseDeFonction);
  2612.                 $nombreDEnfant =  (float)$request->request->get('nombre_d_enfant');
  2613.                 $igr =  (float)$request->request->get('igr');
  2614.                 
  2615.                 $employeBoutique = new UserBoutique;
  2616.                 $employeBoutique->setUser($employe);
  2617.                 $employeBoutique->setBoutique($boutique);
  2618.                 $employeBoutique->setMatricule($matricule);
  2619.                 $employeBoutique->setSalaire($salaire);
  2620.                 $employeBoutique->setLaFonction($laFonction);
  2621.                 $employeBoutique->setLaQualification($laQualification);
  2622.                 
  2623.                 $employeBoutique->setCategorieEmploi($categorie);
  2624.                 $employeBoutique->setDepartementEmploi($departement);
  2625.                 $employeBoutique->setDateDePriseDeFonction($dateDePriseDeFonction);
  2626.                 $employeBoutique->setNombreDEnfant($nombreDEnfant);
  2627.                 $employeBoutique->setIgr($igr);
  2628.                 $employeBoutique->setRole('ROLE_EMPLOYE');
  2629.                 $estEmploye =  $request->request->get('est_employe');
  2630.                 $employeBoutique->setEstEmploye($estEmploye);
  2631.                 //Droits 
  2632.                 
  2633.                 $lesDroits = array();
  2634.                 foreach($droits as $droit){
  2635.                     
  2636.                     $voir =  (boolean)$request->request->get($droit['nomVariable'].'voir');
  2637.                     $ajouter =  (boolean)$request->request->get($droit['nomVariable'].'ajouter');
  2638.                     $modifier = (boolean)$request->request->get($droit['nomVariable'].'modifier');
  2639.                     $supprimer = (boolean)$request->request->get($droit['nomVariable'].'supprimer');
  2640.                     $leDroit =  array(
  2641.                                             'nom' => $droit['nom'],
  2642.                                             'nomVariable' => $droit['nomVariable'],
  2643.                                             'valeurDroit' => array(
  2644.                                                     'lecture' => $voir,
  2645.                                                     'ajout' => $ajouter,
  2646.                                                     'modification' => $modifier,
  2647.                                                     'suppression' => $supprimer
  2648.                                                 )
  2649.                                             
  2650.                                 );
  2651.                     
  2652.                     array_push($lesDroits$leDroit);
  2653.                 }
  2654.                 $employeBoutique->setDroits($lesDroits);
  2655.                 $em->persist($employeBoutique);
  2656.                 $em->flush();
  2657.                 $employe = new AppUser;
  2658.                 $form $this->createForm(EmployeType::class, $employe);
  2659.                 $ok_submission 'Enregistrement effectué';
  2660.             } else{
  2661.                 $error 'error';
  2662.             }
  2663.         }
  2664.         
  2665.         $userBoutique $em->getRepository(UserBoutique::class)
  2666.                             ->findOneBy(
  2667.                                 array(
  2668.                                     'user' => $this->getUser(),
  2669.                                     'boutique' => $boutique
  2670.                                 )
  2671.                             );
  2672.         
  2673.         
  2674.         return $this->render('admin/nouvel_employe.html.twig', [ 
  2675.             'boutique' => $boutique,
  2676.             'form' => $form->createView(),
  2677.             'ok_submission' => $ok_submission,
  2678.             'error' => $error,
  2679.             'userBoutique' => $userBoutique,
  2680.             'droits' => $droits
  2681.         ]);    
  2682.     } 
  2683.     
  2684.     /**
  2685.      * @Route("/{slug}/rh/modifier-employe/{id}", name="admin_modifier_employe")
  2686.      * @return \Symfony\Component\HttpFoundation\Response
  2687.     */
  2688.     public function modifierEmployeAction(Request $request,  $slug$id)
  2689.     {
  2690.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2691.            return $this->redirectToRoute('security_login');
  2692.         }
  2693.         $em $this->getDoctrine()
  2694.                     ->getManager();
  2695.         
  2696.         $boutique $em->getRepository(Boutique::class)
  2697.                         ->findOneBySlug($slug);
  2698.         $employe $em->getRepository(AppUser::class)
  2699.                     ->findOneById($id);
  2700.         
  2701.         $employeBoutique $em->getRepository(UserBoutique::class)
  2702.                         ->findOneBy(
  2703.                                 array(
  2704.                                 'boutique' => $boutique->getId(),
  2705.                                 'user' => $employe->getId()
  2706.                                 )
  2707.                         );
  2708.         $droits $employeBoutique->getDroits();
  2709.         $form $this->createForm(EmployeEditType::class, $employe);
  2710.         $error '';
  2711.         
  2712.         $ok_submission '';
  2713.         if('POST' == $request->getMethod()){
  2714.             $form->handleRequest($request);
  2715.             if($form->isValid()){
  2716.                 $sexe $request->request->get('sexe');
  2717.                 $employe->setSexe($sexe);
  2718.                 $em->flush();
  2719.                 $ok_submission 'Enregistrement effectué';
  2720.                 $matricule $request->request->get('matricule');
  2721.                 $salaire = (float)$request->request->get('salaire');
  2722.                 $laFonction $request->request->get('la_fonction');
  2723.                 $laQualification $request->request->get('la_qualification');
  2724.                 $categorie $request->request->get('categorie');
  2725.                 $departement $request->request->get('departement');
  2726.                 $dateDePriseDeFonction $request->request->get('date_de_prise_de_fonction');
  2727.                 $dateDePriseDeFonction = new \DateTime($dateDePriseDeFonction);
  2728.                 $nombreDEnfant =  (float)$request->request->get('nombre_d_enfant');
  2729.                 $igr =  (float)$request->request->get('igr');
  2730.             
  2731.                 $employeBoutique->setMatricule($matricule);
  2732.                 $employeBoutique->setSalaire($salaire);
  2733.                 $employeBoutique->setLaFonction($laFonction);
  2734.                 $employeBoutique->setLaQualification($laQualification);
  2735.                 $employeBoutique->setCategorieEmploi($categorie);
  2736.                 $employeBoutique->setDepartementEmploi($departement);
  2737.                 $employeBoutique->setDateDePriseDeFonction($dateDePriseDeFonction);
  2738.                 $employeBoutique->setNombreDEnfant($nombreDEnfant);
  2739.                 $employeBoutique->setIgr($igr);
  2740.                 $estEmploye =  $request->request->get('est_employe');
  2741.                 $employeBoutique->setEstEmploye($estEmploye);
  2742.                 //Droits 
  2743.                 
  2744.                 $lesDroits = array();
  2745.                 foreach($droits as $droit){
  2746.                     
  2747.                     $voir =  (boolean)$request->request->get($droit['nomVariable'].'voir');
  2748.                     $ajouter =  (boolean)$request->request->get($droit['nomVariable'].'ajouter');
  2749.                     $modifier = (boolean)$request->request->get($droit['nomVariable'].'modifier');
  2750.                     $supprimer = (boolean)$request->request->get($droit['nomVariable'].'supprimer');
  2751.                     $leDroit =  array(
  2752.                                             'nom' => $droit['nom'],
  2753.                                             'nomVariable' => $droit['nomVariable'],
  2754.                                             'valeurDroit' => array(
  2755.                                                     'lecture' => $voir,
  2756.                                                     'ajout' => $ajouter,
  2757.                                                     'modification' => $modifier,
  2758.                                                     'suppression' => $supprimer
  2759.                                                 )
  2760.                                             
  2761.                                 );
  2762.                     
  2763.                     array_push($lesDroits$leDroit);
  2764.                 }
  2765.                 $employeBoutique->setDroits($lesDroits);
  2766.                 $em->flush();
  2767.             } else{
  2768.                 $error 'error';
  2769.             }
  2770.         }
  2771.         
  2772.         $userBoutique $em->getRepository(UserBoutique::class)
  2773.                             ->findOneBy(
  2774.                                 array(
  2775.                                     'user' => $this->getUser(),
  2776.                                     'boutique' => $boutique
  2777.                                 )
  2778.                             );
  2779.         
  2780.         
  2781.         return $this->render('admin/modifier_employe.html.twig', [ 
  2782.             'boutique' => $boutique,
  2783.             'form' => $form->createView(),
  2784.             'ok_submission' => $ok_submission,
  2785.             'error' => $error,
  2786.             'userBoutique' => $userBoutique,
  2787.             'employe' => $employe,
  2788.             'droits' => $droits,
  2789.             'employeBoutique' => $employeBoutique
  2790.         ]);    
  2791.     } 
  2792.     
  2793.     
  2794.     /**
  2795.      * @Route("/{slug}/comptes", name="admin_comptabilite_comptes")
  2796.      * @return \Symfony\Component\HttpFoundation\Response
  2797.      */
  2798.     public function comptesAction(Request $request,  $slug)
  2799.     {
  2800.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2801.            return $this->redirectToRoute('security_login');
  2802.         }      
  2803.         $em $this->getDoctrine()
  2804.                     ->getManager();
  2805.         $user $this->getUser();
  2806.         $boutique $em->getRepository(Boutique::class)
  2807.                     ->findOneBySlug($slug);
  2808.         $userBoutique $em->getRepository(UserBoutique::class)
  2809.                             ->findOneBy(
  2810.                                 array(
  2811.                                     'user' => $this->getUser(),
  2812.                                     'boutique' => $boutique
  2813.                                 )
  2814.                             );
  2815.         $comptes $em->getRepository(Compte::class)
  2816.                     ->findBy(
  2817.                         array(
  2818.                         'boutique' => $boutique->getId()
  2819.                         )
  2820.                         
  2821.                     );
  2822.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  2823.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  2824.         $dateDebut->setTime(00);
  2825.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  2826.         $dateFin->setTime(2359);
  2827.         
  2828.         
  2829.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  2830.         $startMonth $intervalleMois['debut'];
  2831.         $endMonth $intervalleMois['fin'];
  2832.         
  2833.         $invoices  $em->getRepository(Commande::class)
  2834.                         ->commandeParDateEtType($boutique->getId(), 'invoice'$dateDebut$dateFin);
  2835.         
  2836.         $startYear date('Y-01-01');
  2837.         $endYear date('Y-12-31');
  2838.         $user $this->getUser();
  2839.         return $this->render('admin/comptes.html.twig', [ 
  2840.             'boutique' => $boutique,
  2841.             'userBoutique' => $userBoutique,
  2842.             'comptes' => $comptes,
  2843.            'dateDebut' => $dateDebut,
  2844.            'dateFin' => $dateFin,
  2845.            'startMonth' => $startMonth,
  2846.            'endMonth' => $endMonth,
  2847.            'startYear' => $startYear,
  2848.            'endYear' => $endYear,
  2849.         ]);    
  2850.     }
  2851.     /**
  2852.      * @Route("/{slug}/ecritures-comptable-d-un-compte", name="admin_ecritures_comptale_d_un_compte")
  2853.      * @return \Symfony\Component\HttpFoundation\Response
  2854.      */
  2855.     public function ecrituresComptableDUnCompteAction(Request $request,  $slug)
  2856.     {
  2857.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2858.            return $this->redirectToRoute('security_login');
  2859.         }      
  2860.         $em $this->getDoctrine()
  2861.                     ->getManager();
  2862.         $user $this->getUser();
  2863.         $boutique $em->getRepository(Boutique::class)
  2864.                     ->findOneBySlug($slug);
  2865.         $userBoutique $em->getRepository(UserBoutique::class)
  2866.                             ->findOneBy(
  2867.                                 array(
  2868.                                     'user' => $this->getUser(),
  2869.                                     'boutique' => $boutique
  2870.                                 )
  2871.                             );
  2872.         if($request->getMethod() == 'POST'){
  2873.             $compte $request->request->get('compte');
  2874.             $dateDebut $request->request->get('dateDebut');
  2875.             $dateDebut = new \DateTime($dateDebut);
  2876.             $dateFin $request->request->get('dateFin');
  2877.             $dateFin = new \DateTime($dateFin);
  2878.             $ecrituresComptables $em->getRepository(EcritureComptable::class)
  2879.                     ->ecrituresComptableParDate($boutique$dateDebut$dateFin$compte);
  2880.         }
  2881.         return $this->render('admin/ecritures_comptale_d_un_compte.html.twig', [ 
  2882.             'boutique' => $boutique,
  2883.             'userBoutique' => $userBoutique,
  2884.             'ecrituresComptables' => $ecrituresComptables
  2885.         ]);    
  2886.     }
  2887.     /**
  2888.      * @Route("/{slug}/nouveau-compte", name="admin_nouveau_compte")
  2889.      * @return \Symfony\Component\HttpFoundation\Response
  2890.      */
  2891.     public function nouveauCompteAction(Request $requestBoutique $boutique)
  2892.     {
  2893.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2894.            return $this->redirectToRoute('security_login');
  2895.         }
  2896.         $em $this->getDoctrine()
  2897.                     ->getManager();
  2898.         
  2899.         $compte = new Compte;
  2900.         
  2901.         $user $this->getUser();
  2902.         $userBoutique $em->getRepository(UserBoutique::class)
  2903.                         ->findOneBy(
  2904.                             array(
  2905.                             'user' => $user->getId(),
  2906.                             'boutique' => $boutique->getId()
  2907.                             )
  2908.                         );
  2909.         $form $this->createForm(CompteType::class, $compte, array('boutique' => $boutique->getId()));
  2910.         
  2911.         $ok_soumission '';
  2912.         $error '';
  2913.         
  2914.         if($request->getMethod() == 'POST'){
  2915.             
  2916.                $form->handleRequest($request);
  2917.                if($form->isValid()){
  2918.                    $compte->setBoutique($boutique);
  2919.                   $em->persist($compte);
  2920.                   $em->flush();
  2921.         
  2922.                 $ok_soumission =" Votre message a été pris en compte";
  2923.                     
  2924.                 unset($compte);
  2925.                 unset($form);
  2926.                 $compte = new Compte;
  2927.                 
  2928.                 $form $this->createForm(CompteType::class, $compte, array('boutique' => $boutique->getId()));
  2929.                     
  2930.                 } else {
  2931.                     $error =" Veillez corrigez vos erreurs";
  2932.                 }
  2933.         }
  2934.     
  2935.         return $this->render('admin/nouveau_compte.html.twig', [
  2936.            'boutique' => $boutique,
  2937.            'form' => $form->createView(),
  2938.            'userBoutique' => $userBoutique
  2939.         ]);
  2940.     }
  2941.     /**
  2942.      * @Route("/{slug}/journaux", name="admin_comptabilite_journaux")
  2943.      * @return \Symfony\Component\HttpFoundation\Response
  2944.      */
  2945.     public function journauxAction(Request $requestBoutique $boutique)
  2946.     {
  2947.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2948.            return $this->redirectToRoute('security_login');
  2949.         }
  2950.         $em $this->getDoctrine()
  2951.                     ->getManager();
  2952.         
  2953.         $compte = new Compte;
  2954.         
  2955.         $user $this->getUser();
  2956.         $userBoutique $em->getRepository(UserBoutique::class)
  2957.                         ->findOneBy(
  2958.                             array(
  2959.                             'user' => $user->getId(),
  2960.                             'boutique' => $boutique->getId()
  2961.                             )
  2962.                         );
  2963.         
  2964.         $journaux $em->getRepository(JournalComptabilite::class)
  2965.                         ->findBy(
  2966.                             array(
  2967.                                 'boutique' => $boutique->getId(),
  2968.                                 'estSupprime' => false
  2969.                             ),
  2970.                             array(
  2971.                                 'nom' => 'ASC'
  2972.                             )
  2973.                         );
  2974.     
  2975.         return $this->render('admin/journaux.html.twig', [
  2976.            'boutique' => $boutique,
  2977.            'journaux' => $journaux,
  2978.            'userBoutique' => $userBoutique
  2979.         ]);
  2980.     }
  2981.     /**
  2982.      * @Route("/{slug}/nouveau-journal", name="admin_comptabilite_nouveau_journal")
  2983.      * @return \Symfony\Component\HttpFoundation\Response
  2984.      */
  2985.     public function nouveauJournalAction(Request $requestBoutique $boutique)
  2986.     {
  2987.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  2988.            return $this->redirectToRoute('security_login');
  2989.         }
  2990.         $em $this->getDoctrine()
  2991.                     ->getManager();
  2992.         
  2993.         $journal = new JournalComptabilite;
  2994.         
  2995.         $user $this->getUser();
  2996.         $userBoutique $em->getRepository(UserBoutique::class)
  2997.                         ->findOneBy(
  2998.                             array(
  2999.                             'user' => $user->getId(),
  3000.                             'boutique' => $boutique->getId()
  3001.                             )
  3002.                         );
  3003.         $form $this->createForm(JournalComptabiliteType::class, $journal);
  3004.         
  3005.         $ok_soumission '';
  3006.         $error '';
  3007.         
  3008.         if($request->getMethod() == 'POST'){
  3009.             
  3010.                $form->handleRequest($request);
  3011.                if($form->isValid()){
  3012.                    $journal->setBoutique($boutique);
  3013.                   $em->persist($journal);
  3014.                   $em->flush();
  3015.         
  3016.                 $ok_soumission =" Votre message a été pris en compte";
  3017.                     
  3018.                 unset($journal);
  3019.                 unset($form);
  3020.                 $journal = new JournalComptabilite;
  3021.                 
  3022.                 $form $this->createForm(JournalComptabiliteType::class, $journal);
  3023.                     
  3024.                 } else {
  3025.                     $error =" Veillez corrigez vos erreurs";
  3026.                 }
  3027.         }
  3028.     
  3029.         return $this->render('admin/nouveau_journal.html.twig', [
  3030.            'boutique' => $boutique,
  3031.            'form' => $form->createView(),
  3032.            'userBoutique' => $userBoutique
  3033.         ]);
  3034.     }
  3035.     /**
  3036.      * @Route("/{slug}/modifier-journal/{id}", name="admin_comptabilite_modifier_journal")
  3037.      * @return \Symfony\Component\HttpFoundation\Response
  3038.      */
  3039.     public function modifierJournalAction(Request $request,  $slug$id)
  3040.     {
  3041.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3042.            return $this->redirectToRoute('security_login');
  3043.         }
  3044.         $em $this->getDoctrine()
  3045.                     ->getManager();
  3046.         
  3047.         $journal $em->getRepository(JournalComptabilite::class)
  3048.                     ->findOneById($id);
  3049.         $boutique $em->getRepository(Boutique::class)
  3050.                     ->findOneBySlug($slug);
  3051.         
  3052.         $user $this->getUser();
  3053.         $userBoutique $em->getRepository(UserBoutique::class)
  3054.                         ->findOneBy(
  3055.                             array(
  3056.                             'user' => $user->getId(),
  3057.                             'boutique' => $boutique->getId()
  3058.                             )
  3059.                         );
  3060.         $form $this->createForm(JournalComptabiliteEditType::class, $journal);
  3061.         
  3062.         $ok_soumission '';
  3063.         $error '';
  3064.         
  3065.         if($request->getMethod() == 'POST'){
  3066.             
  3067.                $form->handleRequest($request);
  3068.                if($form->isValid()){
  3069.                   $em->flush();
  3070.         
  3071.                 $ok_soumission =" Votre message a été pris en compte";
  3072.                     
  3073.                     
  3074.                 } else {
  3075.                     $error =" Veillez corrigez vos erreurs";
  3076.                 }
  3077.         }
  3078.     
  3079.         return $this->render('admin/modifier_journal.html.twig', [
  3080.            'boutique' => $boutique,
  3081.            'form' => $form->createView(),
  3082.            'userBoutique' => $userBoutique,
  3083.            'journal' => $journal
  3084.         ]);
  3085.     }
  3086.     /**
  3087.      * @Route("/{slug}/supprimer-journal/{id}", name="admin_comptabilite_supprimer_journal")
  3088.      * @return \Symfony\Component\HttpFoundation\Response
  3089.      */
  3090.     public function supprimerJournalAction(Request $request,  $slug$id)
  3091.     {
  3092.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3093.            return $this->redirectToRoute('security_login');
  3094.         }
  3095.         $em $this->getDoctrine()
  3096.                     ->getManager();
  3097.         
  3098.         $journal $em->getRepository(JournalComptabilite::class)
  3099.                     ->findOneById($id);
  3100.         $boutique $em->getRepository(Boutique::class)
  3101.                     ->findOneBySlug($slug);
  3102.         
  3103.         $user $this->getUser();
  3104.         $userBoutique $em->getRepository(UserBoutique::class)
  3105.                         ->findOneBy(
  3106.                             array(
  3107.                             'user' => $user->getId(),
  3108.                             'boutique' => $boutique->getId()
  3109.                             )
  3110.                         );
  3111.     
  3112.         
  3113.         if(null !== $journal){
  3114.             $journal->setEstSupprime(true);
  3115.             $em->flush();
  3116.         }
  3117.         return $this->redirectToRoute('admin_comptabilite_journaux', array('slug' => $boutique->getSlug()));
  3118.     
  3119.        
  3120.     }
  3121.     /**
  3122.      * @Route("/{slug}/etats-financiers", name="admin_comptabilite_etats_financiers")
  3123.      * @return \Symfony\Component\HttpFoundation\Response
  3124.      */
  3125.     public function etatsFinanciersAction(Request $requestBoutique $boutique)
  3126.     {
  3127.         
  3128.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3129.            return $this->redirectToRoute('security_login');
  3130.         }
  3131.         
  3132.         $em $this->getDoctrine()
  3133.                     ->getManager();
  3134.     
  3135.         
  3136.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  3137.         $dateDebut date('Y-01-01');
  3138.         $dateDebut = new \DateTime($dateDebut);
  3139.         $dateDebut->setTime(00);
  3140.         $dateFin date('Y-12-31');
  3141.         $dateFin = new \DateTime($dateFin);
  3142.         $dateFin->setTime(2359);
  3143.         
  3144.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  3145.         $startMonth $intervalleMois['debut'];
  3146.         $endMonth $intervalleMois['fin'];
  3147.         $chargeDExploitations  $em->getRepository(Expensive::class)
  3148.                         ->chargeCompteDeResultatParDate($boutique->getId(), $dateDebut$dateFin'Charges d\'exploitation');
  3149.         
  3150.         $chargeFinancieres  $em->getRepository(Expensive::class)
  3151.                         ->chargeCompteDeResultatParDate($boutique->getId(), $dateDebut$dateFin'Charges financières');
  3152.         
  3153.         $chargeExceptionnelles  $em->getRepository(Expensive::class)
  3154.                         ->chargeCompteDeResultatParDate($boutique->getId(), $dateDebut$dateFin'Charges exceptionnelles');
  3155.         
  3156.         $impotSurLeBenefice  $em->getRepository(Expensive::class)
  3157.                         ->chargeCompteDeResultatParDate($boutique->getId(), $dateDebut$dateFin'Impôts sur les bénéficices');
  3158.         
  3159.         
  3160.         $venteDeMarchandise $em->getRepository(Commande::class)
  3161.                                         ->chiffreDAffaireDUnePeriode('invoice'$boutique->getId(), $dateDebut$dateFin);
  3162.         if(!empty($venteDeMarchandise)){
  3163.             $venteDeMarchandise $venteDeMarchandise['0'];
  3164.         }else{
  3165.             $venteDeMarchandise = array(
  3166.                                         'totalVente' => 0
  3167.                                     );
  3168.         }
  3169.         
  3170.         
  3171.         $startYear date('Y-01-01');
  3172.         $endYear date('Y-12-31');
  3173.         $user $this->getUser();
  3174.     
  3175.         $actifs = array();
  3176.         
  3177.         $immobilisationsIncorporelles $em->getRepository(EcritureComptable::class)
  3178.                                 ->bilanComptable($boutique'Immobilisations incorporelles'$dateDebut$dateFin);
  3179.         $immobilisationsCorporelles $em->getRepository(EcritureComptable::class)
  3180.                                 ->bilanComptable($boutique'Immobilisations corporelles'$dateDebut$dateFin);
  3181.         $immobilisationsFinancieres $em->getRepository(EcritureComptable::class)
  3182.                                 ->bilanComptable($boutique'Immobilisations financières'$dateDebut$dateFin);
  3183.         $stocks $em->getRepository(EcritureComptable::class)
  3184.                                 ->bilanComptable($boutique'Stocks'$dateDebut$dateFin);
  3185.         $creances $em->getRepository(EcritureComptable::class)
  3186.                                 ->bilanComptable($boutique'Créance'$dateDebut$dateFin);
  3187.         $disponibilites $em->getRepository(EcritureComptable::class)
  3188.                                 ->bilanComptable($boutique'Disponibilité'$dateDebut$dateFin);
  3189.         $capitauxPropres $em->getRepository(EcritureComptable::class)
  3190.                                 ->bilanComptable($boutique'Capitaux propres'$dateDebut$dateFin);
  3191.         $dettesFinancieres $em->getRepository(EcritureComptable::class)
  3192.                                 ->bilanComptable($boutique'Dettes financières'$dateDebut$dateFin);
  3193.         $dettesDExploitations $em->getRepository(EcritureComptable::class)
  3194.                                 ->bilanComptable($boutique'Dettes d\'exploitation'$dateDebut$dateFin);
  3195.         $dettesSurImmobilisations $em->getRepository(EcritureComptable::class)
  3196.                                 ->bilanComptable($boutique'Dettes sur immobilisations'$dateDebut$dateFin);
  3197.         if($request->getMethod() == 'POST'){
  3198.             
  3199.             
  3200.         }
  3201.             $userBoutique $em->getRepository(UserBoutique::class)
  3202.                         ->findOneBy(
  3203.                             array(
  3204.                             'user' => $user->getId(),
  3205.                             'boutique' => $boutique->getId()
  3206.                             )
  3207.                         );
  3208.                         
  3209.         return $this->render('admin/etats_financiers.html.twig', [
  3210.            'boutique' => $boutique,
  3211.            'userBoutique' => $userBoutique,
  3212.            'intervalleDeDate' => $intervalleDeDate,
  3213.            'dateDebut' => $dateDebut,
  3214.            'dateFin' => $dateFin,
  3215.            'startMonth' => $startMonth,
  3216.            'intervalleMois' => $intervalleMois,
  3217.            'endMonth' => $endMonth,
  3218.            'startYear' => $startYear,
  3219.            'endYear' => $endYear,
  3220.            'chargeDExploitations' => $chargeDExploitations,
  3221.            'chargeFinancieres' => $chargeFinancieres,
  3222.            'chargeExceptionnelles' => $chargeExceptionnelles,
  3223.            'impotSurLeBenefice' => $impotSurLeBenefice,
  3224.            'venteDeMarchandise' => $venteDeMarchandise,
  3225.            'immobilisationsIncorporelles' => $immobilisationsIncorporelles,
  3226.            'immobilisationsCorporelles' => $immobilisationsCorporelles,
  3227.            'immobilisationsFinancieres' => $immobilisationsFinancieres,
  3228.            'stocks' => $stocks,
  3229.            'creances' => $creances,
  3230.            'disponibilites' => $disponibilites,
  3231.            'capitauxPropres' => $capitauxPropres,
  3232.            'dettesFinancieres' => $dettesFinancieres,
  3233.            'dettesDExploitations' => $dettesDExploitations,
  3234.            'dettesSurImmobilisations' => $dettesSurImmobilisations
  3235.         ]);
  3236.     }
  3237.     
  3238.     
  3239.     /**
  3240.      * @Route("/{slug}/ecritures-comptable", name="admin_comptabilite_ecritures_comptable")
  3241.      * @return \Symfony\Component\HttpFoundation\Response
  3242.      */
  3243.     public function ecrituresEomptableAction(Request $requestBoutique $boutique)
  3244.     {
  3245.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3246.            return $this->redirectToRoute('security_login');
  3247.         }
  3248.         $em $this->getDoctrine()
  3249.                     ->getManager();
  3250.         
  3251.         $compte = new Compte;
  3252.         
  3253.         $user $this->getUser();
  3254.         $userBoutique $em->getRepository(UserBoutique::class)
  3255.                         ->findOneBy(
  3256.                             array(
  3257.                             'user' => $user->getId(),
  3258.                             'boutique' => $boutique->getId()
  3259.                             )
  3260.                         );
  3261.         $ecritureComptables $em->getRepository(EcritureComptable::class)
  3262.                                 ->findBy(
  3263.                                     array(
  3264.                                         'boutique' => $boutique->getId()
  3265.                                     ),
  3266.                                     array(
  3267.                                         'laDate' => 'ASC'
  3268.                                     )
  3269.                                 );
  3270.         
  3271.         if($request->getMethod() == 'POST'){
  3272.             $ecritureComptables = array();
  3273.             
  3274.         }
  3275.     
  3276.         return $this->render('admin/ecriture_comptables.html.twig', [
  3277.            'boutique' => $boutique,
  3278.            'ecritureComptables' => $ecritureComptables,
  3279.            'userBoutique' => $userBoutique
  3280.         ]);
  3281.     }
  3282.     /**
  3283.      * @Route("/{slug}/grand-livre", name="admin_comptabilite_grand_livre")
  3284.      * @return \Symfony\Component\HttpFoundation\Response
  3285.      */
  3286.     public function grandLivreAction(Request $requestBoutique $boutique)
  3287.     {
  3288.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3289.            return $this->redirectToRoute('security_login');
  3290.         }
  3291.         $em $this->getDoctrine()
  3292.                     ->getManager();
  3293.         
  3294.         $compte = new Compte;
  3295.         
  3296.         $user $this->getUser();
  3297.         $userBoutique $em->getRepository(UserBoutique::class)
  3298.                         ->findOneBy(
  3299.                             array(
  3300.                             'user' => $user->getId(),
  3301.                             'boutique' => $boutique->getId()
  3302.                             )
  3303.                         );
  3304.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  3305.         $dateDebut date('Y-01-01');
  3306.         $dateDebut = new \DateTime($dateDebut);
  3307.         $dateDebut->setTime(00);
  3308.         $dateFin date('Y-12-31');
  3309.         $dateFin = new \DateTime($dateFin);
  3310.         $dateFin->setTime(2359);
  3311.         
  3312.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  3313.         $startMonth $intervalleMois['debut'];
  3314.         $endMonth $intervalleMois['fin'];
  3315.         $ecritureComptables $em->getRepository(EcritureComptable::class)
  3316.                                 ->grandLivre($boutique->getId(), $dateDebut$dateFin);
  3317.         
  3318.         if($request->getMethod() == 'POST'){
  3319.             $ecritureComptables = array();
  3320.             
  3321.         }
  3322.     
  3323.         return $this->render('admin/grand_livre.html.twig', [
  3324.            'boutique' => $boutique,
  3325.            'ecritureComptables' => $ecritureComptables,
  3326.            'userBoutique' => $userBoutique
  3327.         ]);
  3328.     }
  3329.     
  3330.     /**
  3331.      * @Route("/{slug}/nouvelle-ecriture-comptable", name="admin_comptabilite_nouvelle_ecriture_comptable")
  3332.      * @return \Symfony\Component\HttpFoundation\Response
  3333.      */
  3334.     public function nouvelleEcritureEomptableAction(Request $requestBoutique $boutique)
  3335.     {
  3336.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3337.            return $this->redirectToRoute('security_login');
  3338.         }
  3339.         $em $this->getDoctrine()
  3340.                     ->getManager();
  3341.         
  3342.         $ecritureComptable = new EcritureComptable;
  3343.         
  3344.         $user $this->getUser();
  3345.         $userBoutique $em->getRepository(UserBoutique::class)
  3346.                         ->findOneBy(
  3347.                             array(
  3348.                             'user' => $user->getId(),
  3349.                             'boutique' => $boutique->getId()
  3350.                             )
  3351.                         );
  3352.         $form $this->createForm(EcritureComptableType::class, $ecritureComptable, array('boutique' => $boutique->getId()));
  3353.         
  3354.         $ok_soumission '';
  3355.         $error '';
  3356.         
  3357.         if($request->getMethod() == 'POST'){
  3358.             
  3359.                $form->handleRequest($request);
  3360.                if($form->isValid()){
  3361.                    $ecritureComptable->setBoutique($boutique);
  3362.                   $em->persist($ecritureComptable);
  3363.                   $em->flush();
  3364.         
  3365.                 $ok_soumission =" Votre message a été pris en compte";
  3366.                     
  3367.                 unset($ecritureComptable);
  3368.                 unset($form);
  3369.                 $ecritureComptable = new EcritureComptable;
  3370.                 
  3371.                 $form $this->createForm(EcritureComptableType::class, $ecritureComptable, array('boutique' => $boutique->getId()));
  3372.                     
  3373.                 } else {
  3374.                     $error =" Veillez corrigez vos erreurs";
  3375.                 }
  3376.         }
  3377.     
  3378.         return $this->render('admin/nouvelle_ecriture_comptable.html.twig', [
  3379.            'boutique' => $boutique,
  3380.            'form' => $form->createView(),
  3381.            'userBoutique' => $userBoutique
  3382.         ]);
  3383.     }
  3384.     /**
  3385.      * @Route("/{slug}/visites", name="admin_visites")
  3386.      * @return \Symfony\Component\HttpFoundation\Response
  3387.      */
  3388.     public function visitesAction(Request $requestBoutique $boutique)
  3389.     {
  3390.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3391.            return $this->redirectToRoute('security_login');
  3392.         }
  3393.         $em $this->getDoctrine()
  3394.                     ->getManager();
  3395.         $user $this->getUser();
  3396.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  3397.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  3398.         $dateDebut->setTime(00);
  3399.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  3400.         $dateFin->setTime(2359);
  3401.         
  3402.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  3403.         $startMonth $intervalleMois['debut'];
  3404.         $endMonth $intervalleMois['fin'];
  3405.         
  3406.         $visites  $em->getRepository(Visite::class)
  3407.                         ->visiteParDate($boutique->getId(), $dateDebut$dateFin);
  3408.         
  3409.         $startYear date('Y-01-01');
  3410.         $endYear date('Y-12-31');
  3411.         $userBoutique $em->getRepository(UserBoutique::class)
  3412.                         ->findOneBy(
  3413.                             array(
  3414.                             'user' => $user->getId(),
  3415.                             'boutique' => $boutique->getId()
  3416.                             )
  3417.                         );
  3418.          return $this->render('admin/visites.html.twig', [
  3419.             'boutique' => $boutique,
  3420.             'userBoutique' => $userBoutique,
  3421.             'dateDebut' => $dateDebut,
  3422.            'dateFin' => $dateFin,
  3423.            'startMonth' => $startMonth,
  3424.            'endMonth' => $endMonth,
  3425.            'startYear' => $startYear,
  3426.            'endYear' => $endYear,
  3427.            'visites' => $visites
  3428.         ]);
  3429.     }
  3430.     /**
  3431.      * @Route("/{slug}/nouvelle-visite", name="admin_nouvelle_visite")
  3432.      * @return \Symfony\Component\HttpFoundation\Response
  3433.      */
  3434.     public function nouvelleVisiteAction(Request $requestBoutique $boutique)
  3435.     {
  3436.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3437.            return $this->redirectToRoute('security_login');
  3438.         }
  3439.         $em $this->getDoctrine()
  3440.                     ->getManager();
  3441.         
  3442.         $visite = new Visite;
  3443.         $form $this->createForm(VisiteType::class, $visite);
  3444.         
  3445.         $user $this->getUser();
  3446.         $userBoutique $em->getRepository(UserBoutique::class)
  3447.                         ->findOneBy(
  3448.                             array(
  3449.                             'user' => $user->getId(),
  3450.                             'boutique' => $boutique->getId()
  3451.                             )
  3452.                         );
  3453.         
  3454.         $ok_soumission '';
  3455.         $error '';
  3456.         
  3457.         if($request->getMethod() == 'POST'){
  3458.             
  3459.                $form->handleRequest($request);
  3460.                if($form->isSubmitted() && $form->isValid()){
  3461.                    $visite->setBoutique($boutique);
  3462.                    $visite->setCreePar($user);
  3463.                     $em->persist($visite);
  3464.                   $em->flush();
  3465.                 
  3466.                   if(isset($_FILES['photos']) && $_FILES['photos']['name'][0] != ''){
  3467.                         
  3468.                         $this->gererFichierMultiple($visite$_FILES['photos']);
  3469.                     }
  3470.         
  3471.                 $ok_soumission ="Enregistrement effectué";
  3472.                 $visite = new Visite;
  3473.                 
  3474.                 $form $this->createForm(VisiteType::class, $visite);
  3475.                     
  3476.                 } else {
  3477.                     $error =" Veillez corrigez vos erreurs";
  3478.                 }
  3479.         }
  3480.         return $this->render('admin/nouvelle_visite.html.twig', [
  3481.            'boutique' => $boutique,
  3482.            'form' => $form->createView(),
  3483.            'userBoutique' => $userBoutique,
  3484.            'ok_soumission' => $ok_soumission,
  3485.            'error' => $error
  3486.         ]);
  3487.     }
  3488.     /**
  3489.      * @Route("/{slug}/modifier-visite/{visite}", name="admin_modifier_visite")
  3490.      * @return \Symfony\Component\HttpFoundation\Response
  3491.      */
  3492.     public function modifierVisiteAction(Request $requestBoutique $boutique$visite)
  3493.     {
  3494.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3495.            return $this->redirectToRoute('security_login');
  3496.         }
  3497.         $em $this->getDoctrine()
  3498.                     ->getManager();
  3499.                     
  3500.         $user $this->getUser();
  3501.         $userBoutique $em->getRepository(UserBoutique::class)
  3502.                         ->findOneBy(
  3503.                             array(
  3504.                             'user' => $user->getId(),
  3505.                             'boutique' => $boutique->getId()
  3506.                             )
  3507.                         );
  3508.         $visite $em->getRepository(Visite::class)
  3509.                     ->findOneById($visite);
  3510.         $form $this->createForm(VisiteEditType::class, $visite);
  3511.         
  3512.         $ok_soumission '';
  3513.         $error '';
  3514.         
  3515.         if($request->getMethod() == 'POST'){
  3516.             
  3517.                $form->handleRequest($request);
  3518.                if($form->isValid()){
  3519.                     $visite->setModifiePar($user);
  3520.                     $em->flush();
  3521.         
  3522.                 $ok_soumission =" Votre message a été pris en compte";
  3523.                     
  3524.                 } else {
  3525.                     $error =" Veillez corrigez vos erreurs";
  3526.                 }
  3527.         }
  3528.         return $this->render('admin/modifier_visite.html.twig', [
  3529.            'boutique' => $boutique,
  3530.            'form' => $form->createView(),
  3531.            'userBoutique' => $userBoutique,
  3532.            'visite' => $visite
  3533.         ]);
  3534.     }
  3535.     /**
  3536.      * @Route("/{slug}/depart-visiteur/{visite}", name="admin_depart_visiteur")
  3537.      * @return \Symfony\Component\HttpFoundation\Response
  3538.      */
  3539.     public function departVisiteurAction(Request $requestBoutique $boutique$visite)
  3540.     {
  3541.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3542.            return $this->redirectToRoute('security_login');
  3543.         }
  3544.         $em $this->getDoctrine()
  3545.                     ->getManager();
  3546.         $user $this->getUser();
  3547.         $visite $em->getRepository(Visite::class)
  3548.                     ->findOneById($visite);
  3549.                     
  3550.         if(null != $visite){
  3551.             $visite->setDateDeDepart(new \DateTime());
  3552.             $em->flush();
  3553.         }
  3554.         
  3555.         return $this->redirectToRoute('admin_visites', array('slug' => $boutique->getSlug()));
  3556.     }
  3557.     /**
  3558.      * @Route("/{slug}/supprimer-visite/{visite}", name="admin_supprimer_visite")
  3559.      * @return \Symfony\Component\HttpFoundation\Response
  3560.      */
  3561.     public function supprimerVisiteAction(Request $requestBoutique $boutique$visite)
  3562.     {
  3563.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3564.            return $this->redirectToRoute('security_login');
  3565.         }
  3566.         $em $this->getDoctrine()
  3567.                     ->getManager();
  3568.         $user $this->getUser();
  3569.         $visite $em->getRepository(Visite::class)
  3570.                     ->findOneById($visite);
  3571.                     
  3572.         if(null != $visite){
  3573.             $visite->setEstSupprime(true);
  3574.             $visite->setSupprimePar($user);
  3575.             $em->flush();
  3576.         }
  3577.         
  3578.         return $this->redirectToRoute('admin_visites', array('slug' => $boutique->getSlug()));
  3579.     }
  3580.     
  3581.     
  3582.     
  3583.     /**
  3584.      * @Route("/{slug}/new-payment/{id}", name="admin.new_payment")
  3585.      * @return \Symfony\Component\HttpFoundation\Response
  3586.      */
  3587.     public function newPaymentAction(Request $request,  $slug$id)
  3588.     {
  3589.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3590.            return $this->redirectToRoute('security_login');
  3591.         }      
  3592.         $em $this->getDoctrine()
  3593.                     ->getManager();
  3594.         
  3595.         $boutique $em->getRepository(Boutique::class)
  3596.                     ->findOneBySlug($slug);
  3597.             
  3598.         $commande $em->getRepository(Commande::class)
  3599.                     ->findOneBy(
  3600.                         array(
  3601.                             'boutique' => $boutique->getId(),
  3602.                             'id' => $id
  3603.                         )
  3604.                     );
  3605.         $factures $em->getRepository(Commande::class)
  3606.                     ->facturesPourVersement($boutique->getId());
  3607.         
  3608.         $user $this->getUser();        
  3609.         $userBoutique $em->getRepository(UserBoutique::class)
  3610.                         ->findOneBy(
  3611.                             array(
  3612.                             'user' => $user->getId(),
  3613.                             'boutique' => $boutique->getId()
  3614.                             )
  3615.                         );
  3616.         $paymentMethods $em->getRepository(PaymentMethod::class)
  3617.                     ->findBy(
  3618.                         array(
  3619.                             'boutique' => $boutique->getId()
  3620.                         )
  3621.                     );
  3622.                     
  3623.         $ok_soumission '';
  3624.         $error '';
  3625.             
  3626.             
  3627.        return $this->render('admin/new_payment.html.twig', [
  3628.            'boutique' => $boutique,
  3629.            'commande' => $commande,
  3630.            'paymentMethods' => $paymentMethods,
  3631.            'factures' => $factures,
  3632.            'userBoutique' => $userBoutique
  3633.         ]);
  3634.     
  3635.    }
  3636.    /**
  3637.      * @Route("/{slug}/make-payment/{id}", name="admin_make_payment")
  3638.      * @return \Symfony\Component\HttpFoundation\Response
  3639.      */
  3640.     public function makePaymentAction(Request $request,  $slug$id 0)
  3641.     {
  3642.         /*
  3643.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3644.            return $this->redirectToRoute('security_login');
  3645.         }      
  3646.         */
  3647.         $em $this->getDoctrine()
  3648.                     ->getManager();
  3649.         
  3650.         $boutique $em->getRepository(Boutique::class)
  3651.                     ->findOneBySlug($slug);
  3652.         
  3653.         $commande $em->getRepository(Commande::class)
  3654.                     ->findOneBy(
  3655.                         array(
  3656.                             'boutique' => $boutique->getId(),
  3657.                             'id' => $id
  3658.                         )
  3659.                     );
  3660.         $factures $em->getRepository(Commande::class)
  3661.                     ->facturesPourVersement($boutique->getId());
  3662.         
  3663.         $user $this->getUser();
  3664.         
  3665.         
  3666.         $userBoutique $em->getRepository(UserBoutique::class)
  3667.                         ->findOneBy(
  3668.                             array(
  3669.                             'user' => $user->getId(),
  3670.                             'boutique' => $boutique->getId()
  3671.                             )
  3672.                         );
  3673.         $paymentMethods $em->getRepository(PaymentMethod::class)
  3674.                     ->findBy(
  3675.                         array(
  3676.                             'boutique' => $boutique->getId()
  3677.                         )
  3678.                     );
  3679.                     
  3680.         $ok_soumission '';
  3681.         $error '';
  3682.         
  3683.         
  3684.             $laDate $request->request->get('laDate'); 
  3685.             $frais = (float)$request->request->get('frais');
  3686.             $paymentMethod $request->request->get('paymentMethod');
  3687.             $montant = (float)$request->request->get('montant');
  3688.             $referencePaiement $request->request->get('referencePaiement');
  3689.             $commande $request->request->get('facture');
  3690.             
  3691.             $commande $em->getRepository(Commande::class)
  3692.                             ->findOneBy(
  3693.                                 array(
  3694.                                 'boutique' =>$boutique->getId(),
  3695.                                 'id' => $commande
  3696.                                 )
  3697.                             );
  3698.             
  3699.             if((float)$commande->getResteAPayer() < $montant || $montant == 0){
  3700.                 $this->addFlash(
  3701.                     'danger',
  3702.                     'Montant invalide '$montant
  3703.                 );
  3704.             } else{
  3705.                 $laDate = new \DateTime($laDate);
  3706.                 $payment = new Payment;
  3707.                 $payment->setLaDate($laDate);
  3708.                 $payment->setCommande($commande);
  3709.                 $payment->setBoutique($boutique);
  3710.                 $payment->setMontant($montant);
  3711.                 $payment->setReferencePaiement($referencePaiement);
  3712.                 $payment->setMoyenDePaiement($paymentMethod);
  3713.                 
  3714.                 $em->persist($payment);
  3715.                 
  3716.                 $commande->setMontantPaye($commande->getMontantPaye() + $montant);
  3717.                 $commande->setResteAPayer($commande->getResteAPayer() - $montant);
  3718.                 $em->flush();
  3719.                 
  3720.                 if($boutique->getSettings()->isGenererAutomatiquementEcrituresComptabilite()){
  3721.                     $groupeEcritureComptable = new GroupeEcritureComptable;
  3722.                     $groupeEcritureComptable->setBoutique($boutique);
  3723.                     
  3724.                     $groupeEcritureComptable->setLibelleEcriture('Règlement client');
  3725.                     $groupeEcritureComptable->setDebit($montant);
  3726.                     $groupeEcritureComptable->setCredit($montant);
  3727.                     $groupeEcritureComptable->setLaDate($payment->getLaDate());
  3728.                     $groupeEcritureComptable->setNumeroPiece($commande->getNumero());
  3729.                     $groupeEcritureComptable->setAnnee($payment->getLaDate()->format('Y'));
  3730.                     $groupeEcritureComptable->setMois($payment->getLaDate()->format('m'));
  3731.                     $em->persist($groupeEcritureComptable);
  3732.                     $em->flush();
  3733.                 if($paymentMethod == 'check' || $paymentMethod == 'transfer'){
  3734.                     //Debit
  3735.                     
  3736.                     $ecritureComptable = new EcritureComptable;
  3737.                     $groupeEcritureComptable->setLeJournal($boutique->getSettings()->getJournalDeBanque());
  3738.                     $ecritureComptable->setBoutique($boutique);
  3739.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  3740.                     
  3741.                     $ecritureComptable->setLeJournal($leJournal);
  3742.                     $compte $em->getRepository(Compte::class)
  3743.                                 ->findOneByNumero('521'); //Banque
  3744.                     $compte->setSolde($compte->getSolde() + $montant);
  3745.                     $ecritureComptable->setCompte($compte);
  3746.                     $ecritureComptable->setLibelleEcriture('Règlement client');
  3747.                     $ecritureComptable->setDebit($montant);
  3748.                     $ecritureComptable->setSolde($compte->getSolde());
  3749.                     $ecritureComptable->setLaDate($payment->getLaDate());
  3750.                     $ecritureComptable->setNumeroPiece($commande->getNumero());
  3751.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  3752.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  3753.                     $em->persist($ecritureComptable);
  3754.                     //Credit
  3755.                     $ecritureComptable = new EcritureComptable;
  3756.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  3757.                     $ecritureComptable->setBoutique($boutique);
  3758.                     
  3759.                     $ecritureComptable->setLeJournal($boutique->getSettings()->getJournalDeBanque());
  3760.                     $compte $em->getRepository(Compte::class)
  3761.                                 ->findOneByNumero('411'); //Client
  3762.                     $compte->setSolde($compte->getSolde() - $montant);
  3763.                     $ecritureComptable->setCompte($compte);
  3764.                     $ecritureComptable->setLibelleEcriture('Règlement client');
  3765.                     $ecritureComptable->setCredit($montant);
  3766.                     $ecritureComptable->setSolde($compte->getSolde());
  3767.                     $ecritureComptable->setLaDate($payment->getLaDate());
  3768.                     $ecritureComptable->setNumeroPiece($commande->getNumero());
  3769.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  3770.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  3771.                     $em->persist($ecritureComptable);
  3772.                 }
  3773.                 if($paymentMethod == 'cash'){
  3774.                     //Débit
  3775.                     $ecritureComptable = new EcritureComptable;
  3776.                     $ecritureComptable->setBoutique($boutique);
  3777.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  3778.                     $leJournal $em->getRepository(JournalComptabilite::class)
  3779.                                     ->findOneBy(
  3780.                                         array(
  3781.                                         'boutique' => $boutique->getId(),
  3782.                                         'reference' => 'CA',
  3783.                                         'nom' => 'Caisse'
  3784.                                         )
  3785.                                     );
  3786.                     $groupeEcritureComptable->setLeJournal($leJournal);
  3787.                     $ecritureComptable->setLeJournal($leJournal);
  3788.                     $compte $em->getRepository(Compte::class)
  3789.                                 ->findOneByNumero('5711'); //caisse
  3790.                     $compte->setSolde($compte->getSolde() + $montant);
  3791.                     $ecritureComptable->setCompte($compte);
  3792.                     $ecritureComptable->setLibelleEcriture('Règlement client');
  3793.                     $ecritureComptable->setDebit($montant);
  3794.                     $ecritureComptable->setSolde($compte->getSolde());
  3795.                     $ecritureComptable->setLaDate($payment->getLaDate());
  3796.                     $ecritureComptable->setNumeroPiece($commande->getNumero());
  3797.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  3798.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  3799.                     $em->persist($ecritureComptable);
  3800.                     //Credit
  3801.                     $ecritureComptable = new EcritureComptable;
  3802.                     $ecritureComptable->setBoutique($boutique);
  3803.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  3804.                     
  3805.                     $ecritureComptable->setLeJournal($leJournal);
  3806.                     $compte $em->getRepository(Compte::class)
  3807.                                 ->findOneByNumero('411'); //Client
  3808.                     $compte->setSolde($compte->getSolde() - $montant);
  3809.                     $ecritureComptable->setCompte($compte);
  3810.                     $ecritureComptable->setLibelleEcriture('Règlement client');
  3811.                     $ecritureComptable->setCredit($montant);
  3812.                     $ecritureComptable->setSolde($compte->getSolde());
  3813.                     $ecritureComptable->setLaDate($payment->getLaDate());
  3814.                     $ecritureComptable->setNumeroPiece($commande->getNumero());
  3815.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  3816.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  3817.                     $em->persist($ecritureComptable);
  3818.                 }
  3819.                 if($paymentMethod == 'card'){
  3820.                     $ecritureComptable = new EcritureComptable;
  3821.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  3822.                     $ecritureComptable->setBoutique($boutique);
  3823.                     $leJournal $em->getRepository(JournalComptabilite::class)
  3824.                                     ->findOneBy(
  3825.                                         array(
  3826.                                         'boutique' => $boutique->getId(),
  3827.                                         'reference' => 'BQ',
  3828.                                         'nom' => 'Banque'
  3829.                                         )
  3830.                                     );
  3831.                     $ecritureComptable->setLeJournal($leJournal);
  3832.                     $groupeEcritureComptable->setLeJournal($leJournal);
  3833.                     $compte $em->getRepository(Compte::class)
  3834.                                 ->findOneByNumero('521'); //Banque
  3835.                     $compte->setSolde($compte->getSolde() + $montant $frais);
  3836.                     $ecritureComptable->setCompte($compte);
  3837.                     $ecritureComptable->setLibelleEcriture('Règlement client');
  3838.                     $ecritureComptable->setDebit($montant $frais);
  3839.                     $ecritureComptable->setSolde($compte->getSolde());
  3840.                     $ecritureComptable->setLaDate($payment->getLaDate());
  3841.                     $ecritureComptable->setNumeroPiece($commande->getNumero());
  3842.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  3843.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  3844.                     $em->persist($ecritureComptable);
  3845.                     if($frais 0){
  3846.                         $ecritureComptable = new EcritureComptable;
  3847.                         $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  3848.                         $ecritureComptable->setBoutique($boutique);
  3849.                         
  3850.                         $ecritureComptable->setLeJournal($leJournal);
  3851.                         $compte $em->getRepository(Compte::class)
  3852.                                     ->findOneByNumero('6315'); //Commissions sur cartes de crédit
  3853.                         $compte->setSolde($compte->getSolde() + $frais);
  3854.                         $ecritureComptable->setCompte($compte);
  3855.                         $ecritureComptable->setLibelleEcriture('Règlement client');
  3856.                         $ecritureComptable->setDebit($frais);
  3857.                         $ecritureComptable->setSolde($compte->getSolde());
  3858.                         $ecritureComptable->setLaDate($payment->getLaDate());
  3859.                         $ecritureComptable->setNumeroPiece($commande->getNumero());
  3860.                         $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  3861.                         $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  3862.                         $em->persist($ecritureComptable);
  3863.                     }
  3864.                     //Credit
  3865.                     $ecritureComptable = new EcritureComptable;
  3866.                     $ecritureComptable->setBoutique($boutique);
  3867.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  3868.                     
  3869.                     $ecritureComptable->setLeJournal($leJournal);
  3870.                     $compte $em->getRepository(Compte::class)
  3871.                                 ->findOneByNumero('515'); //CARTES DE CREDIT A ENCAISSER
  3872.                     $compte->setSolde($compte->getSolde() - $montant );
  3873.                     $ecritureComptable->setCompte($compte);
  3874.                     $ecritureComptable->setLibelleEcriture('Règlement client');
  3875.                     $ecritureComptable->setCredit($montant);
  3876.                     $ecritureComptable->setSolde($compte->getSolde());
  3877.                     $ecritureComptable->setLaDate($payment->getLaDate());
  3878.                     $ecritureComptable->setNumeroPiece($commande->getNumero());
  3879.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  3880.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  3881.                     $em->persist($ecritureComptable);
  3882.                 }
  3883.                 if($paymentMethod == 'mobile-money'){
  3884.                     $ecritureComptable = new EcritureComptable;
  3885.                     $ecritureComptable->setBoutique($boutique);
  3886.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  3887.                     $leJournal $em->getRepository(JournalComptabilite::class)
  3888.                                     ->findOneBy(
  3889.                                         array(
  3890.                                             'boutique' => $boutique->getId(),
  3891.                                         'reference' => 'CA',
  3892.                                         'nom' => 'Caisse'
  3893.                                         )
  3894.                                     );
  3895.                     $ecritureComptable->setLeJournal($leJournal);
  3896.                     $groupeEcritureComptable->setLeJournal($leJournal);
  3897.                     $compte $em->getRepository(Compte::class)
  3898.                                 ->findOneByNumero('5711'); //Caisse en monnaie nationale
  3899.                     $compte->setSolde($compte->getSolde() + $montant $frais);
  3900.                     $ecritureComptable->setCompte($compte);
  3901.                     $ecritureComptable->setLibelleEcriture('Règlement client');
  3902.                     $ecritureComptable->setDebit($montant $frais);
  3903.                     $ecritureComptable->setSolde($compte->getSolde());
  3904.                     $ecritureComptable->setLaDate($payment->getLaDate());
  3905.                     $ecritureComptable->setNumeroPiece($commande->getNumero());
  3906.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  3907.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  3908.                     $em->persist($ecritureComptable);
  3909.                     if($frais 0){
  3910.                         $ecritureComptable = new EcritureComptable;
  3911.                         $ecritureComptable->setBoutique($boutique);
  3912.                         $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  3913.                         
  3914.                         $ecritureComptable->setLeJournal($leJournal);
  3915.                         $compte $em->getRepository(Compte::class)
  3916.                                     ->findOneByNumero('6317'); //Frais sur instruments monnaie électronique
  3917.                         $compte->setSolde($compte->getSolde() + $frais);
  3918.                         $ecritureComptable->setCompte($compte);
  3919.                         $ecritureComptable->setLibelleEcriture('Règlement client');
  3920.                         $ecritureComptable->setDebit($frais);
  3921.                         $ecritureComptable->setSolde($compte->getSolde());
  3922.                         $ecritureComptable->setLaDate($payment->getLaDate());
  3923.                         $ecritureComptable->setNumeroPiece($commande->getNumero());
  3924.                         $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  3925.                         $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  3926.                         $em->persist($ecritureComptable);
  3927.                     }
  3928.                     //Credit
  3929.                     $ecritureComptable = new EcritureComptable;
  3930.                     $ecritureComptable->setBoutique($boutique);
  3931.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  3932.                     
  3933.                     $ecritureComptable->setLeJournal($leJournal);
  3934.                     $compte $em->getRepository(Compte::class)
  3935.                                 ->findOneByNumero('554'); //PORTE-MONNAIE ELECTRONIQUE
  3936.                     $compte->setSolde($compte->getSolde() - $montant);
  3937.                     $ecritureComptable->setCompte($compte);
  3938.                     $ecritureComptable->setLibelleEcriture('Règlement client');
  3939.                     $ecritureComptable->setCredit($montant);
  3940.                     $ecritureComptable->setSolde($compte->getSolde());
  3941.                     $ecritureComptable->setLaDate($payment->getLaDate());
  3942.                     $ecritureComptable->setNumeroPiece($commande->getNumero());
  3943.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  3944.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  3945.                     $em->persist($ecritureComptable);
  3946.                 }
  3947.                 } //Fin condition ecriture comptable automatique
  3948.                 $em->flush();
  3949.                  $this->addFlash(
  3950.                         'success',
  3951.                         'Enregistrement effectué'
  3952.                     );
  3953.             }
  3954.         
  3955.         
  3956.        return $this->render('admin/new_payment.html.twig', [
  3957.            'boutique' => $boutique,
  3958.            'commande' => $commande,
  3959.            'paymentMethods' => $paymentMethods,
  3960.            'factures' => $factures,
  3961.            'userBoutique' => $userBoutique
  3962.         ]);
  3963.     
  3964.    }
  3965.     
  3966.     
  3967.     
  3968.     //bill_credit
  3969.     /**
  3970.      * @Route("/{slug}/bill-credits", name="admin.bill_credits")
  3971.      * @return \Symfony\Component\HttpFoundation\Response
  3972.      */
  3973.     public function billCreditsActionRequest $requestBoutique $boutique)
  3974.     {
  3975.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  3976.            return $this->redirectToRoute('security_login');
  3977.         }      
  3978.         $em $this->getDoctrine()
  3979.                     ->getManager();
  3980.     
  3981.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  3982.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  3983.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  3984.         
  3985.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  3986.         $startMonth $intervalleMois['debut'];
  3987.         $endMonth $intervalleMois['fin'];
  3988.         
  3989.         $billCredits  $em->getRepository(Commande::class)
  3990.                         ->commandeParDateEtType($boutique->getId(), 'bill_credit'$dateDebut$dateFin);
  3991.         
  3992.         $startYear date('Y-01-01');
  3993.         $endYear date('Y-12-31');
  3994.         $user $this->getUser();
  3995.         $userBoutique $em->getRepository(UserBoutique::class)
  3996.                         ->findOneBy(
  3997.                             array(
  3998.                             'user' => $user->getId(),
  3999.                             'boutique' => $boutique->getId()
  4000.                             )
  4001.                         );
  4002.         if('POST' == $request->getMethod()){
  4003.             $dateDebut $_POST['dateDebut'];
  4004.             $dateFin $_POST['dateFin'];
  4005.             
  4006.             $dateDebut = new \DateTime($dateDebut);
  4007.             $dateFin = new \DateTime($dateFin);
  4008.             
  4009.             $billCredits  $em->getRepository(Commande::class)
  4010.                         ->commandeParDateEtType($boutique->getId(), 'bill_credit'$dateDebut$dateFin);
  4011.             
  4012.             
  4013.             return $this->render('admin/bill_credits_table_content.html.twig', [
  4014.                'boutique' => $boutique,
  4015.                'billCredits' => $billCredits,
  4016.                'userBoutique' => $userBoutique
  4017.             ]);
  4018.             
  4019.         }
  4020.     
  4021.     
  4022.         return $this->render('admin/bill_credits.html.twig', [
  4023.            'boutique' => $boutique,
  4024.            'billCredits' => $billCredits,
  4025.            'dateDebut' => $dateDebut,
  4026.            'dateFin' => $dateFin,
  4027.            'startMonth' => $startMonth,
  4028.            'endMonth' => $endMonth,
  4029.            'startYear' => $startYear,
  4030.            'endYear' => $endYear,
  4031.            'userBoutique' => $userBoutique
  4032.         ]);
  4033.     }
  4034.     
  4035.     //Sales
  4036.     /**
  4037.      * @Route("/{slug}/proposals/new", name="admin.new_proposal")
  4038.      * @return \Symfony\Component\HttpFoundation\Response
  4039.      */
  4040.     public function newProposalsActionRequest $requestBoutique $boutique)
  4041.     {
  4042.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  4043.            return $this->redirectToRoute('security_login');
  4044.         }  
  4045.         $em $this->getDoctrine()
  4046.                     ->getManager();
  4047.         
  4048.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  4049.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  4050.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  4051.         
  4052.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  4053.         $startMonth $intervalleMois['debut'];
  4054.         $endMonth $intervalleMois['fin'];
  4055.         
  4056.         $proposals  $em->getRepository(Commande::class)
  4057.                         ->commandeParDateEtType($boutique->getId(), 'proposal'$dateDebut$dateFin);
  4058.         
  4059.         $startYear date('Y-01-01');
  4060.         $endYear date('Y-12-31');
  4061.         $user $this->getUser();
  4062.         $userBoutique $em->getRepository(UserBoutique::class)
  4063.                         ->findOneBy(
  4064.                             array(
  4065.                             'user' => $user->getId(),
  4066.                             'boutique' => $boutique->getId()
  4067.                             )
  4068.                         );
  4069.         if('POST' == $request->getMethod()){
  4070.             $dateDebut $_POST['dateDebut'];
  4071.             $dateFin $_POST['dateFin'];
  4072.             
  4073.             $dateDebut = new \DateTime($dateDebut);
  4074.             $dateFin = new \DateTime($dateFin);
  4075.             
  4076.             $proposals  $em->getRepository(Commande::class)
  4077.                         ->commandeParDateEtType($boutique->getId(), 'proposal'$dateDebut$dateFin);
  4078.             
  4079.             
  4080.             return $this->render('admin/proposals_table_content.html.twig', [
  4081.                'boutique' => $boutique,
  4082.                'proposals' => $proposals
  4083.             ]);
  4084.             
  4085.         }
  4086.     
  4087.         return $this->render('admin/nouvelle_commande.html.twig', [
  4088.            'boutique' => $boutique,
  4089.            'proposals' => $proposals,
  4090.            'dateDebut' => $dateDebut,
  4091.            'dateFin' => $dateFin,
  4092.            'startMonth' => $startMonth,
  4093.            'endMonth' => $endMonth,
  4094.            'startYear' => $startYear,
  4095.            'endYear' => $endYear,
  4096.            'userBoutique' => $userBoutique
  4097.         ]);
  4098.     }
  4099.     
  4100.     //Sales
  4101.     /**
  4102.      * @Route("/{slug}/sales", name="admin.sales")
  4103.      * @return \Symfony\Component\HttpFoundation\Response
  4104.      */
  4105.     public function salesActionRequest $requestChiffreEnLettre $chiffreEnLettreBoutique $boutique$type 'Invoice')
  4106.     {
  4107.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  4108.            return $this->redirectToRoute('security_login');
  4109.         }      
  4110.         $em $this->getDoctrine()
  4111.                     ->getManager();
  4112.         $produits  $em->getRepository(Produit::class)
  4113.                         ->findByBoutique($boutique);
  4114.         $modeleReglements $em->getRepository(ModeleReglement::class)
  4115.                                 ->findByBoutique($boutique);        
  4116.         $tiers $em->getRepository(Tiers::class)
  4117.                                 ->findByBoutique($boutique);        
  4118.         
  4119.         $user $this->getUser();
  4120.     
  4121.         $ok_soumission '';
  4122.         $error '';
  4123.         
  4124.         
  4125.         if($request->getMethod() == 'POST'){
  4126.             $typeFacture $_POST['typeFacture'];
  4127.             $modeleReglement $_POST['modeleReglement'];
  4128.             $client $_POST['client'];
  4129.             $dateCommande $_POST['dateCommande'];
  4130.             $montantHT $_POST['montantHT'];
  4131.             $montantTVA $_POST['montantTVA'];
  4132.             $montantTTC $_POST['montantTTC'];
  4133.             $listeProduits json_decode($_POST['listeProduits']);
  4134.             
  4135.             $commande = new Commande;
  4136.             $commande->setBoutique($boutique);
  4137.             $client $em->getRepository(Tiers::class)
  4138.                         ->findOneById($client);
  4139.             if(null !== $client){
  4140.                 
  4141.                 $commande->setTiers($client);
  4142.             }
  4143.             
  4144.             $laDate = new \DateTime($dateCommande);
  4145.             $commande->setLaDate($laDate);
  4146.             $commande->setTotalHT($montantHT);
  4147.             $commande->setTotalTVA($montantTVA);
  4148.             $commande->setTotalTTC($montantTTC);
  4149.             $montantlettre strtoupper($chiffreEnLettre->Conversion($montantTTC));
  4150.             $commande->setMontantEnLettre($montantlettre);
  4151.             $commande->setTypeFacture($typeFacture);
  4152.             $em->persist($commande);
  4153.             $em->flush();
  4154.             $produitCommandes = array();
  4155.             foreach($listeProduits as $listeProduit){
  4156.                 $listeProduit = (array)$listeProduit;
  4157.                 $leProduit $em->getRepository(Produit::class)->findOneById($listeProduit['idProduit']);
  4158.                 
  4159.                 $produitCommande = new ProduitCommande;
  4160.                 $produitCommande->setProduit($leProduit);
  4161.                 $produitCommande->setCommande($commande);
  4162.                 $produitCommande->setQuantite($listeProduit['quantite']);
  4163.                 $produitCommande->setPrix((float)$listeProduit['prixUnitaire']);
  4164.                 $produitCommande->setRemise($listeProduit['reduction']);
  4165.                 $produitCommande->setTotalHT($listeProduit['totalHT']);
  4166.                 $produitCommande->setTotalTVA($listeProduit['totalTVA']);
  4167.                 $produitCommande->setTotalTTC($listeProduit['totalTTC']);
  4168.                 $em->persist($produitCommande);
  4169.                 array_push($produitCommandes$produitCommande);
  4170.                 
  4171.             }
  4172.             $em->flush();
  4173.             return $this->render('admin/facture.html.twig', [
  4174.                    'boutique' => $boutique,
  4175.                    'commande' => $commande,
  4176.                    'typeFacture' => $typeFacture,
  4177.                    'client' => $client,
  4178.                    'produitCommandes' => $produitCommandes,
  4179.                    'listeProduit' => $listeProduit,
  4180.                    'montantHT' => $montantHT,
  4181.                    'montantTVA' => $montantTVA,
  4182.                    'montantTTC' => $montantTTC,
  4183.                    'userBoutique' => $userBoutique
  4184.                 ]);
  4185.             
  4186.             
  4187.         }
  4188.     
  4189.         return $this->render('admin/nouvelle_commande.html.twig', [
  4190.            'boutique' => $boutique,
  4191.            'produits' => $produits,
  4192.            'modeleReglements' => $modeleReglements,
  4193.            'tiers' => $tiers,
  4194.            'userBoutique' => $userBoutique
  4195.         ]);
  4196.     }
  4197.     
  4198.     //Vente
  4199.     /**
  4200.      * @Route("/{slug}/new-sale/{type}", name="admin.new_sale")
  4201.      * @return \Symfony\Component\HttpFoundation\Response
  4202.      */
  4203.     public function newSaleActionRequest $requestChiffreEnLettre $chiffreEnLettreBoutique $boutique$type 'invoice')
  4204.     {
  4205.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  4206.            return $this->redirectToRoute('security_login');
  4207.         }      
  4208.         
  4209.         $em $this->getDoctrine()
  4210.                     ->getManager();
  4211.         $produits  $em->getRepository(Produit::class)
  4212.                         ->findByBoutique($boutique);
  4213.         $modeleReglements $em->getRepository(ModeleReglement::class)
  4214.                                 ->findByBoutique($boutique);        
  4215.         $tiers $em->getRepository(Tiers::class)
  4216.                                 ->findByBoutique($boutique);        
  4217.         
  4218.         $user $this->getUser();
  4219.         $vehicules = array( 222328);
  4220.         
  4221.         $userBoutique $em->getRepository(UserBoutique::class)
  4222.                         ->findOneBy(
  4223.                             array(
  4224.                             'user' => $user->getId(),
  4225.                             'boutique' => $boutique->getId()
  4226.                             )
  4227.                         );
  4228.     
  4229.         $ok_soumission '';
  4230.         $error '';
  4231.         
  4232.         $editMode 'new';
  4233.         $responseFNE '';
  4234.         $natureFacture '';
  4235.         if($request->getMethod() == 'POST'){
  4236.             $typeFacture $_POST['typeFacture'];
  4237.             $modeleReglement $_POST['modeleReglement'];
  4238.             $client $_POST['client'];
  4239.             $moyenDePaiement $_POST['moyenDePaiement'];
  4240.             $clientFinalNom $_POST['clientFinalNom'];
  4241.             $clientFinalNumero $_POST['clientFinalNumero'];
  4242.             $dateCommande $_POST['dateCommande'];
  4243.             $montantHT = (float)$_POST['montantHT'];
  4244.             $remise =   (float)$_POST['remise'];
  4245.             $remisePourcentage =  (float)$_POST['remisePourcentage'];
  4246.             $totalHTApresRemise =  (float)$_POST['totalHTApresRemise'];
  4247.             $montantTVA = (float)$_POST['montantTVA'];
  4248.             $montantTTC = (float)$_POST['montantTTC'];
  4249.             $titreDocument $_POST['titreDocument'];
  4250.             $valableJusquAu $_POST['valableJusquAu'];
  4251.             $observation $_POST['observation'];
  4252.             $matriculeVehicule $_POST['matriculeVehicule'];
  4253.             $marqueVehicule $_POST['marqueVehicule'];
  4254.             $kilometrageVehicule = (float)$_POST['kilometrageVehicule'];
  4255.             $listeProduits json_decode($_POST['listeProduits']);
  4256.             $natureFacture $_POST['natureFacture'];
  4257.             
  4258.             $commande = new Commande;
  4259.             $commande->setNatureFacture($natureFacture);
  4260.             $commande->setClientFinalNom($clientFinalNom);
  4261.             $commande->setClientFinalNumero($clientFinalNumero);
  4262.             $commande->setCreePar($user);
  4263.             $commande->setBoutique($boutique);
  4264.             $client $em->getRepository(Tiers::class)
  4265.                         ->findOneById($client);
  4266.             if(null !== $client){
  4267.                 
  4268.                 $commande->setTiers($client);
  4269.             }
  4270.             
  4271.             $laDate = new \DateTime($dateCommande);
  4272.             $commande->setLaDate($laDate);
  4273.             $commande->setMoyenDePaiement($moyenDePaiement);
  4274.             $commande->setMatriculeVehicule($matriculeVehicule);
  4275.             $commande->setMarqueVehicule($marqueVehicule);
  4276.             $commande->setKilometrageVehicule($kilometrageVehicule);
  4277.             
  4278.             $commande->setTotalHT($montantHT);
  4279.             $commande->setRemise($remise);
  4280.             $commande->setRemisePourcentage($remisePourcentage);
  4281.             $commande->setTotalHTApresRemise($totalHTApresRemise);
  4282.             if($commande->getNatureFacture() == 'purchase'){
  4283.                 $commande->setTotalTVA(0);
  4284.                 $commande->setTotalTTC($totalHTApresRemise);
  4285.                 $commande->setResteAPayer($totalHTApresRemise);
  4286.             }else{
  4287.                 $commande->setTotalTVA($montantTVA);
  4288.                 $commande->setTotalTTC($montantTTC);
  4289.                 $commande->setResteAPayer($montantTTC);
  4290.             }
  4291.             $commande->setTitreDocument($titreDocument);
  4292.             $commande->setObservation($observation);
  4293.             if($valableJusquAu != ''){
  4294.                 $commande->setValableJusquAu(new \DateTime($valableJusquAu));
  4295.             }
  4296.             $montantlettre strtoupper($chiffreEnLettre->Conversion($commande->getTotalTTC()));
  4297.             $commande->setMontantEnLettre($montantlettre);
  4298.             $commande->setTypeFacture($type);
  4299.             
  4300.             if($commande->getNumero() == ''){
  4301.                 $commande->setNumero($this->getNumero($type$boutique));
  4302.             }
  4303.             
  4304.             $em->persist($commande);
  4305.             $em->flush();
  4306.             $produitCommandes = array();
  4307.             $coutDeRevientCommande 0;
  4308.             foreach($listeProduits as $listeProduit){
  4309.                 $listeProduit = (array)$listeProduit;
  4310.                 $idDuProduit $listeProduit['idProduit'];
  4311.                 
  4312.                 if($idDuProduit == ''){
  4313.                     //Produit inexistant, il faut le créer
  4314.                     $leProduit = new Produit;
  4315.                     $leProduit->setNom($listeProduit['nomProduit']);
  4316.                     $em->persist($leProduit);
  4317.                     $em->flush();
  4318.                     
  4319.                     //TVA
  4320.                     if($listeProduit['tva'] > 0){
  4321.                         $tva $em->getRepository(TVA::class)
  4322.                                     ->findOneBy(
  4323.                                         array(
  4324.                                             'boutique' => $boutique->getId(),
  4325.                                             'valeur'  => $listeProduit['tva']
  4326.                                         )
  4327.                                     );
  4328.                         if($tva == null){
  4329.                             $tva = new TVA;
  4330.                             $tva->setValeur($listeProduit['tva']);
  4331.                             $em->persist($tva);
  4332.                             $em->flush();
  4333.                         }
  4334.                         
  4335.                         $leProduit->setTva($tva);
  4336.                         
  4337.                     }else{
  4338.                         $tva $em->getRepository(TVA::class)
  4339.                                     ->findOneBy(
  4340.                                         array(
  4341.                                             'boutique' => $boutique->getId(),
  4342.                                             'estPrincipale'  => true
  4343.                                         )
  4344.                                     );
  4345.                         $leProduit->setTva($tva);
  4346.                     }
  4347.                     //Prix
  4348.                     $produitP = new PrixProduit;
  4349.                     $produitP->setValeur($listeProduit['prixUnitaire']);
  4350.                     $leProduit->addPrix($produitP);
  4351.                     $leProduit->setPrixActuel($produitP);
  4352.                     $leProduit->setBoutique($boutique);
  4353.                     $em->persist($produitP);
  4354.                     $em->persist($leProduit);
  4355.                     $em->flush();
  4356.                     
  4357.                 } else{
  4358.                     $leProduit $em->getRepository(Produit::class)
  4359.                         ->findOneById($idDuProduit);
  4360.                 }
  4361.                 
  4362.                 
  4363.                 $produitCommande = new ProduitCommande;
  4364.                 $produitCommande->setProduit($leProduit);
  4365.                 $produitCommande->setCommande($commande);
  4366.                 $quantite = (float)$listeProduit['quantite'];
  4367.                 $produitCommande->setQuantite($quantite);
  4368.                 $produitCommande->setPrix((float)$listeProduit['prixUnitaire']);
  4369.                 $prixDeRevient = (float)$listeProduit['prixDeRevient'];
  4370.                 $produitCommande->setCoutDeRevient($prixDeRevient);
  4371.                 $totalCoutDeRevient $prixDeRevient $quantite;
  4372.                 $produitCommande->setTotalCoutDeRevient($totalCoutDeRevient);
  4373.                 $coutDeRevientCommande += $totalCoutDeRevient;
  4374.                 $produitCommande->setRemise((float)$listeProduit['reduction']);
  4375.                 $produitCommande->setMontantRemise((float)$listeProduit['montantReduction']);
  4376.                 $produitCommande->setTotalHT((float)$listeProduit['totalHT']);
  4377.                 $produitCommande->setTotalHTApresRemise((float)$listeProduit['totalHTApresRemise']);
  4378.                 $produitCommande->setTotalTVA((float)$listeProduit['totalTVA']);
  4379.                 
  4380.                 $produitCommande->setTva((float)$listeProduit['tva']);
  4381.                 $produitCommande->setTotalTTC((float)$listeProduit['totalTTC']);
  4382.                 if($produitCommande->getProduit()->getTypeProduit() != null){
  4383.                     if($produitCommande->getProduit()->getTypeProduit()->getNomInterne() == 'produit'){
  4384.                         if($type == 'invoice'){
  4385.                             
  4386.                             
  4387.                             $leProduit->setStockDisponible($leProduit->getStockDisponible() - $produitCommande->getQuantite());
  4388.                         }
  4389.                     }
  4390.                 }
  4391.                 $em->persist($produitCommande);
  4392.                 array_push($produitCommandes$produitCommande);
  4393.                 
  4394.             } // Fin foreach($listeProduits as $listeProduit)
  4395.              
  4396.             $commande->setCoutDeRevient($coutDeRevientCommande);
  4397.             $em->flush();
  4398.             
  4399.             $pdf = new Html2Pdf('P'$boutique->getSettings()->getFormatPapierImpression(), 'en');
  4400.             $content '';
  4401.             switch($type){
  4402.                 case 'invoice':
  4403.                     //Facture FNE qui
  4404.                     
  4405.                     if($boutique->getApiKeyFNE() != ''){
  4406.                         if($boutique->getSettings()->isGenererAutomatiquementFNE()){
  4407.                             $responseFNE $this->genererFactureFNE($boutique->getSlug(), $commande->getId(), $natureFacture);
  4408.                         }
  4409.                     
  4410.                     }
  4411.                     $commande->setEtat(Commande::ETAT_FACTURE_PROVISOIRE);
  4412.                     
  4413.                     $content $this->renderView('pdf/facture.html.twig', [
  4414.                         'boutique' => $boutique,
  4415.                         'facture' => $commande,
  4416.                         'produits' => $produitCommandes,
  4417.                         'natureFacture' => $natureFacture,
  4418.                         'vehicules' => $vehicules
  4419.                     ]);
  4420.                     
  4421.                     if($boutique->getSettings()->isGenererAutomatiquementEcrituresComptabilite()){
  4422.                         $this->genererEcritureComptableDeVente($boutique$commande);
  4423.                         //Ecriture comptable
  4424.                     }
  4425.                     $em->flush();
  4426.                     
  4427.                 break;
  4428.                 
  4429.                 case 'proposal':
  4430.                     $commande->setEtat(Commande::ETAT_DEVIS_PROVISOIRE);
  4431.                     
  4432.                     $content $this->renderView('pdf/devis.html.twig', [
  4433.                         'boutique' => $boutique,
  4434.                         'facture' => $commande,
  4435.                         'produits' => $produitCommandes,
  4436.                         'vehicules' => $vehicules
  4437.                     ]);
  4438.                 break;
  4439.                 
  4440.                 
  4441.                 case 'bill_credit':
  4442.                     
  4443.                     $content $this->renderView('pdf/facture_avoir.html.twig', [
  4444.                         'boutique' => $boutique,
  4445.                         'facture' => $commande,
  4446.                         'produits' => $produitCommandes,
  4447.                         'vehicules' => $vehicules
  4448.                     ]);
  4449.                     
  4450.                 break;
  4451.             }
  4452.             
  4453.             
  4454.             $pdf->writeHTML($content);
  4455.             $name $commande->getTypeFacture().$commande->getId().time().$boutique->getId().rand(110000).'.pdf';
  4456.             $lienPhysique $commande->getUploadRootDir().$name;
  4457.                 
  4458.             $commande->setLienPDF($this->getDomain().'/pdf478njkp01/'.$name);
  4459.             $pdf->output($lienPhysique'F');
  4460.             
  4461.             $em->flush();
  4462.             
  4463.             return $this->render('admin/response_new_sale.html.twig', [
  4464.                    'boutique' => $boutique,
  4465.                    'commande' => $commande,
  4466.                    'responseFNE' => $responseFNE,
  4467.                    'vehicules' => $vehicules
  4468.                    
  4469.                 ]);
  4470.             
  4471.             
  4472.             /*
  4473.             return $this->render('admin/facture.html.twig', [
  4474.                    'boutique' => $boutique,
  4475.                    'commande' => $commande,
  4476.                    'typeFacture' => $typeFacture,
  4477.                    'client' => $client,
  4478.                    'produitCommandes' => $produitCommandes,
  4479.                    'listeProduit' => $listeProduit,
  4480.                    'montantHT' => $montantHT,
  4481.                    'montantTVA' => $montantTVA,
  4482.                    'montantTTC' => $montantTTC,
  4483.                    'userBoutique' => $userBoutique
  4484.                 ]);
  4485.             */
  4486.             
  4487.         }
  4488.     
  4489.         return $this->render('admin/nouvelle_commande.html.twig', [
  4490.            'boutique' => $boutique,
  4491.            'produits' => $produits,
  4492.            'modeleReglements' => $modeleReglements,
  4493.            'tiers' => $tiers,
  4494.            'editMode' => $editMode,
  4495.            'userBoutique' => $userBoutique,
  4496.            'responseFNE' => $responseFNE,
  4497.            'type' => $type,
  4498.            'vehicules' => $vehicules
  4499.           
  4500.         ]);
  4501.     }
  4502.     public function genererEcritureComptableDeVente($boutique$commande)
  4503.     {
  4504.         $em $this->getDoctrine()
  4505.                     ->getManager();
  4506.                     
  4507.         $groupeEcritureComptable = new GroupeEcritureComptable;
  4508.         $groupeEcritureComptable->setBoutique($boutique);
  4509.         $libelle 'Vente client';
  4510.         if($commande->getTiers() != null){
  4511.             $libelle 'Vente à ' $commande->getTiers()->getNom();
  4512.         }
  4513.         $groupeEcritureComptable->setLibelleEcriture($libelle);
  4514.         $groupeEcritureComptable->setDebit($commande->getTotalTTC());
  4515.         $groupeEcritureComptable->setCredit($commande->getTotalTTC());
  4516.         $groupeEcritureComptable->setLaDate($commande->getLaDate());
  4517.         $groupeEcritureComptable->setNumeroPiece($commande->getNumero());
  4518.         $groupeEcritureComptable->setAnnee($commande->getLaDate()->format('Y'));
  4519.         $groupeEcritureComptable->setMois($commande->getLaDate()->format('m'));
  4520.         $em->persist($groupeEcritureComptable);
  4521.         $em->flush();
  4522.         //Débit
  4523.         $ecritureComptable = new EcritureComptable;
  4524.         $ecritureComptable->setBoutique($boutique);
  4525.         $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  4526.         $ecritureComptable->setLeJournal($boutique->getSettings()->getJournalDeVente());
  4527.         $groupeEcritureComptable->setLeJournal($boutique->getSettings()->getJournalDeVente());
  4528.         $compteClient $em->getRepository(Compte::class)
  4529.                                     ->findOneBy(
  4530.                                         array(
  4531.                                             'numero' => '411',
  4532.                                             'boutique' =>$boutique->getId()
  4533.                                         )
  4534.                                     );
  4535.         $compteClient->setSolde($compteClient->getSolde() + $commande->getTotalTTC());
  4536.         $ecritureComptable->setCompte($compteClient);
  4537.         $ecritureComptable->setNumeroPiece($commande->getNumero());
  4538.         $nomClient '';
  4539.         if($commande->getTiers() != null){
  4540.             $nomClient =  ' à '.$commande->getTiers()->getNom();
  4541.         }
  4542.         $ecritureComptable->setLibelleEcriture('Vente'.$nomClient);
  4543.         $ecritureComptable->setDebit($commande->getTotalTTC());
  4544.         $ecritureComptable->setSolde($compteClient->getSolde());
  4545.         $ecritureComptable->setLaDate($commande->getLaDate());
  4546.         $ecritureComptable->setAnnee($commande->getLaDate()->format('Y'));
  4547.         $ecritureComptable->setMois($commande->getLaDate()->format('m'));
  4548.                     
  4549.         $em->persist($ecritureComptable);
  4550.         $ecritureComptable = new EcritureComptable;
  4551.         $ecritureComptable->setBoutique($boutique);
  4552.         $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  4553.         
  4554.         //Crédit
  4555.         $ecritureComptable->setLeJournal($boutique->getSettings()->getJournalDeVente());
  4556.         $compte $em->getRepository(Compte::class)
  4557.                     ->findOneBy(
  4558.                         array(
  4559.                                 'numero' => '701',
  4560.                                 'boutique' => $boutique->getId()
  4561.                             )
  4562.                         );
  4563.         
  4564.         $compte->setSolde($compte->getSolde() - $commande->getTotalHTApresRemise() );
  4565.         $ecritureComptable->setCompte($compte);
  4566.         $ecritureComptable->setNumeroPiece($commande->getNumero());
  4567.                     
  4568.         $ecritureComptable->setLibelleEcriture('Vente'.$nomClient);
  4569.         $ecritureComptable->setCredit($commande->getTotalHTApresRemise());
  4570.         $ecritureComptable->setSolde($compte->getSolde());
  4571.         $ecritureComptable->setLaDate($commande->getLaDate());
  4572.         $ecritureComptable->setAnnee($commande->getLaDate()->format('Y'));
  4573.         $ecritureComptable->setMois($commande->getLaDate()->format('m'));
  4574.                     
  4575.                     
  4576.         $em->persist($ecritureComptable);
  4577.         //TVA pour une entreprise qui facture la TVA
  4578.         if($commande->getTotalTVA() > 0){
  4579.             $ecritureComptable = new EcritureComptable;
  4580.             $ecritureComptable->setBoutique($boutique);
  4581.             $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  4582.                         
  4583.             $ecritureComptable->setLeJournal($boutique->getSettings()->getJournalDeVente());
  4584.             $compte $em->getRepository(Compte::class)
  4585.                             ->findOneBy(
  4586.                                 array(
  4587.                                     'numero' => '4431',
  4588.                                     'boutique' => $boutique->getId()
  4589.                                 )
  4590.                             );
  4591.             $compte->setSolde($compte->getSolde() - $commande->getTotalTVA() );
  4592.             $ecritureComptable->setCompte($compte);
  4593.             $ecritureComptable->setNumeroPiece($commande->getNumero());
  4594.                         
  4595.             $ecritureComptable->setLibelleEcriture('Vente'.$nomClient);
  4596.             $ecritureComptable->setCredit($commande->getTotalTVA());
  4597.             $ecritureComptable->setSolde($compte->getSolde());
  4598.             $ecritureComptable->setLaDate($commande->getLaDate());
  4599.             $ecritureComptable->setAnnee($commande->getLaDate()->format('Y'));
  4600.             $ecritureComptable->setMois($commande->getLaDate()->format('m'));
  4601.                     
  4602.                         
  4603.             $em->persist($ecritureComptable);
  4604.         }
  4605.         $em->flush();
  4606.     }
  4607.     
  4608.     /**
  4609.       * @Route("/{slug}/generer-facture-fne/{id}", name="admin_url_generer_facture_fne")
  4610.     */
  4611.     public function urlGenererFactureFNEAction(Request $request$slug$id)
  4612.     {
  4613.         
  4614.         $em $this->getDoctrine()
  4615.                     ->getManager();
  4616.         $boutique $em->getRepository(Boutique::class)
  4617.                         ->findOneBySlug($slug);
  4618.         $commande $em->getRepository(Commande::class)
  4619.                         ->findOneById($id);
  4620.         
  4621.         $produitCommandes $em->getRepository(ProduitCommande::class)
  4622.                             ->findByCommande($commande);
  4623.         $reponse '';
  4624.         $vehicules = array( 222328);
  4625.         if($boutique->getApiKeyFNE() != ''){
  4626.             $reponse $this->genererFactureFNE($slug$id$commande->getNatureFacture());
  4627.             //$reponse = json_decode($reponse);
  4628.             if(isset($reponse['invoice']['id'])){
  4629.                 $commande->setIdFactureFNE($reponse['invoice']['id']);
  4630.             }
  4631.             if(isset($reponse['token'])){
  4632.                 $commande->seTtokenFNE($reponse['token']);
  4633.             }
  4634.             if(isset($reponse['balance_sticker'])){
  4635.                 $boutique->setSoldeTimbreFNE($reponse['balance_sticker']);
  4636.             }
  4637.             if(isset($reponse['balance_sticker'])){
  4638.                 $boutique->setSoldeTimbreFNE($reponse['balance_sticker']);
  4639.             }
  4640.             if(isset($reponse['balance_funds'])){
  4641.                 $boutique->setSoldeTimbreFNE($reponse['balance_funds']);
  4642.             }
  4643.             
  4644.             
  4645.             $em->flush();
  4646.         
  4647.         }
  4648.         
  4649.         $pdf = new Html2Pdf('P'$boutique->getSettings()->getFormatPapierImpression(), 'fr');
  4650.     
  4651.         $content $this->renderView('pdf/facture.html.twig', [
  4652.                     'boutique' => $boutique,
  4653.                     'facture' => $commande,
  4654.                     'produits' => $produitCommandes,
  4655.                     'natureFacture' => $commande->getNatureFacture(),
  4656.                     'vehicules' => $vehicules
  4657.                 ]);
  4658.         $pdf->writeHTML($content);
  4659.         $name $commande->getTypeFacture().$commande->getId().time().$boutique->getId().rand(110000).'.pdf';
  4660.         $lienPhysique $commande->getUploadRootDir().$name;
  4661.                 
  4662.         $commande->setLienPDF($this->getDomain().'/pdf478njkp01/'.$name);
  4663.         $pdf->output($lienPhysique'F');
  4664.         $em->flush();
  4665.         return $this->redirectToRoute('admin.invoices', array('slug' => $boutique->getSlug()));
  4666.         return $this->render('admin/admin_generer_facture_fne.html.twig', [
  4667.            'boutique' => $boutique,
  4668.            'content' => $content,
  4669.            'userBoutique' => $userBoutique
  4670.         ]);
  4671.         
  4672.     }
  4673.     public function genererFactureFNE($slug$idCommande$invoiceType 'sale')
  4674.     {
  4675.         
  4676.         $em $this->getDoctrine()
  4677.                     ->getManager();
  4678.         $boutique $em->getRepository(Boutique::class)
  4679.                         ->findOneBySlug($slug);
  4680.         $commande $em->getRepository(Commande::class)
  4681.                         ->findOneById($idCommande);
  4682.         $user $this->getUser();
  4683.         $userBoutique $em->getRepository(UserBoutique::class)
  4684.                         ->findOneBy(
  4685.                             array(
  4686.                                 'user' => $user,
  4687.                                 'boutique' => $boutique
  4688.                             )
  4689.                         );
  4690.         $url $boutique->getUrlFNEDeBase().'/external/invoices/sign';
  4691.         $produitCommandes $em->getRepository(ProduitCommande::class)
  4692.                                 ->findByCommande($commande);
  4693.                                 
  4694.         $globalCustomTaxes = array();
  4695.         
  4696.         $items = array();
  4697.         foreach($produitCommandes as $produitCommande){
  4698.             $tvas = array();
  4699.             $customTaxes = array();
  4700.             if($invoiceType == 'sale'){
  4701.                 if($produitCommande->getProduit()->getTVA() != null){
  4702.                     array_push($tvas$produitCommande->getProduit()->getTVA()->getLibelleInterne());
  4703.                     $nested = array(
  4704.                         'name' => $produitCommande->getProduit()->getTVA()->getLibelleInterne(),
  4705.                         'amount' =>$produitCommande->getProduit()->getTVA()->getValeur()
  4706.                     );
  4707.                     $nested  json_encode($nested);
  4708.                     array_push($customTaxes$nested);
  4709.                 }
  4710.             }else{
  4711.                 array_push($tvas'TVAD');
  4712.                     $nested = array(
  4713.                         'name' => $produitCommande->getProduit()->getTVA()->getLibelleInterne(),
  4714.                         'amount' =>0
  4715.                     );
  4716.                     $nested  json_encode($nested);
  4717.                     array_push($customTaxes$nested);
  4718.             }
  4719.             
  4720.             
  4721.             
  4722.             $item = array(
  4723.                     //'taxes' => $tvas,
  4724.                     //'customTaxes' => $customTaxes,
  4725.                     'reference' => $produitCommande->getProduit()->getReference(),
  4726.                     'description' =>  $produitCommande->getProduit()->getNom(),
  4727.                     'quantity' => $produitCommande->getQuantite(),
  4728.                     'amount' => $produitCommande->getPrix(),
  4729.                     'discount' => $produitCommande->getRemisePourcentage(),
  4730.                     'measurementUnit' => $produitCommande->getProduit()->getUniteDeMesure()
  4731.             );
  4732.             if($invoiceType == 'sale'){
  4733.                 $item['taxes'] = $tvas;
  4734.             }
  4735.             array_push($items$item);
  4736.         }
  4737.         
  4738.         $clientNcc =  '';
  4739.         if($invoiceType == 'sale'){
  4740.             if($commande->getTiers() != null){
  4741.                 $clientNcc str_replace(' '''$commande->getTiers()->getCodeTVA());
  4742.             }
  4743.             
  4744.         }
  4745.         $template 'B2C';
  4746.         $clientCompanyName $commande->getClientFinalNom();
  4747.         $clientPhone str_replace(' '''$commande->getClientFinalNumero());
  4748.         $clientEmail '';
  4749.         if($commande->getTiers() != null){
  4750.             $template $commande->getTiers()->getTypeClient();
  4751.             $clientCompanyName $commande->getTiers()->getNom();
  4752.             $clientPhone str_replace(' '''$commande->getTiers()->getTelephone());
  4753.             $clientEmail $commande->getTiers()->getEmail();
  4754.         }
  4755.         $content = array(
  4756.             
  4757.             'invoiceType' => $invoiceType ,
  4758.             'paymentMethod'=> $commande->getMoyenDePaiement(),
  4759.             'template' => $template,
  4760.             'isRne' => false,
  4761.             'clientNcc' => $clientNcc,
  4762.             'clientCompanyName' => $clientCompanyName,
  4763.             'clientPhone' => $clientPhone,
  4764.             'clientEmail' => $clientEmail,
  4765.             'clientSellerName' => $user->getNomComplet(),
  4766.             'pointOfSale' => $userBoutique->getNomPointDeVenteFNE(),
  4767.             'establishment' =>  $userBoutique->getNomEtablissementFNE(),
  4768.             'commercialMessage' => $commande->getTitreDocument(),
  4769.             'footer' => 'Arrêtée la presente facture à la somme de '.$commande->getMontantEnLettre().' '.$boutique->getSettings()->getDevise(),
  4770.             //'foreignCurrency' => '',
  4771.             //'foreignCurrencyRate' => 0,
  4772.             'items' => $items,
  4773.             
  4774.             'discount' => $commande->getRemisePourcentage()
  4775.         );
  4776.         
  4777.         if($invoiceType == 'sale'){
  4778.             $content['customTaxes'] = $globalCustomTaxes;
  4779.         }
  4780.         
  4781.         $content json_encode($content);
  4782.         $ch curl_init($url);
  4783.         curl_setopt($chCURLOPT_RETURNTRANSFERtrue);
  4784.         curl_setopt($chCURLOPT_HTTPHEADER, ['Content-Type: application/json''Authorization: Bearer '.$boutique->getApiKeyFNE()]);
  4785.         curl_setopt($chCURLOPT_POSTFIELDS$content);
  4786.         $serverOutput curl_exec($ch);
  4787.         curl_close($ch);
  4788.         
  4789.         $response = new JsonResponse;
  4790.         
  4791.         
  4792.         //$response->setContent(json_encode($serverOutput));
  4793.         //return $response;
  4794.         $serverOutput json_decode($serverOutputtrue);
  4795.         if(isset($serverOutput['invoice'])){
  4796.             $commande->setIdFactureFNE($serverOutput['invoice']['id']);
  4797.             $commande->seTtokenFNE($serverOutput['token']);
  4798.             //$boutique->setSoldeTimbreFNE($serverOutput['balance_sticker']);
  4799.             if(isset($serverOutput['balance_funds'])){
  4800.                 $boutique->setSoldeTimbreFNE($serverOutput['balance_funds']);
  4801.             }
  4802.             if(isset($serverOutput['balance_sticker'])){
  4803.                 $boutique->setSoldeTimbreFNE($serverOutput['balance_sticker']);
  4804.             }
  4805.             
  4806.             
  4807.             //Mettre aussi les produitCommande Ajour pour d'eventuel facture d'avoir
  4808.             
  4809.             $itemsRetournes $serverOutput['invoice']['items'];
  4810.             foreach($itemsRetournes as $itemsRetourne){
  4811.                 $pro $em->getRepository(Produit::class)
  4812.                             ->findOneBy(
  4813.                                 array(
  4814.                                     'boutique' => $boutique,
  4815.                                     'nom' => $itemsRetourne['description'],
  4816.                                     'reference' => $itemsRetourne['reference']
  4817.                                 )
  4818.                             );
  4819.                 if($pro != null){
  4820.                     $proCom $em->getRepository(ProduitCommande::class)
  4821.                             ->findOneBy(
  4822.                                 array(
  4823.                                     'commande' => $commande->getId(),
  4824.                                     'produit' => $pro->getId()
  4825.                                 )
  4826.                             );
  4827.                     if($proCom != null){
  4828.                         $proCom->setIdProduitPourFactureDAvoirFNE($itemsRetourne['id']);
  4829.                         $em->persist($proCom);
  4830.                     }
  4831.                 
  4832.                 }
  4833.             }
  4834.             
  4835.             $em->flush();
  4836.         }
  4837.         return $serverOutput;
  4838.         
  4839.     }
  4840.     
  4841.     
  4842.     /**
  4843.       * @Route("/{slug}/url-generer-facture-d-avoir-fne/{id}", name="admin_url_generer_facture_d_avoir_fne")
  4844.     */
  4845.     public function urlGenererFactureDAvoirFNEAction(Request $requestChiffreEnLettre $chiffreEnLettre$slug$id)
  4846.     {
  4847.         
  4848.         $em $this->getDoctrine()
  4849.                     ->getManager();
  4850.         $boutique $em->getRepository(Boutique::class)
  4851.                         ->findOneBySlug($slug);
  4852.         $commande $em->getRepository(Commande::class)
  4853.                         ->findOneById($id);
  4854.         $user $this->getUser();
  4855.         $userBoutique $em->getRepository(UserBoutique::class)
  4856.                         ->findOneBy(
  4857.                             array(
  4858.                                 'user' => $user,
  4859.                                 'boutique' => $boutique
  4860.                             )
  4861.                         );
  4862.         $produitCommandes $em->getRepository(ProduitCommande::class)
  4863.                                 ->findByCommande($commande);
  4864.         $reponse '';
  4865.         
  4866.         if($request->getMethod() == 'POST'){
  4867.                 
  4868.             $chiffreEnLettre = new ChiffreEnLettre;
  4869.             if($boutique->getApiKeyFNE() != ''){
  4870.                 $reponse $this->genererFactureDAvoirFNE($chiffreEnLettre$boutique->getSlug(), $commande->getId());
  4871.             }
  4872.         }
  4873.         
  4874.         
  4875.          return $this->render('admin/url_generer_facture_d_avoir_fne.html.twig', [
  4876.            'boutique' => $boutique,
  4877.            'reponse' => $reponse,
  4878.            'userBoutique' => $userBoutique,
  4879.            'produitCommandes' => $produitCommandes
  4880.         ]);
  4881.     }
  4882.     
  4883.     public function genererFactureDAvoirFNE(ChiffreEnLettre $chiffreEnLettre$slug$id)
  4884.     {
  4885.         
  4886.         $em $this->getDoctrine()
  4887.                     ->getManager();
  4888.         $boutique $em->getRepository(Boutique::class)
  4889.                         ->findOneBySlug($slug);
  4890.         $commande $em->getRepository(Commande::class)
  4891.                         ->findOneById($id);
  4892.         $user $this->getUser();
  4893.         $userBoutique $em->getRepository(UserBoutique::class)
  4894.                         ->findOneBy(
  4895.                             array(
  4896.                                 'user' => $user,
  4897.                                 'boutique' => $boutique
  4898.                             )
  4899.                         );
  4900.         $url $boutique->getUrlFNEDeBase().'/external/invoices/'.$commande->getIdFactureFNE().'/refund';
  4901.         
  4902.         $produitCommandes $em->getRepository(ProduitCommande::class)
  4903.                                 ->findByCommande($commande);
  4904.                                 
  4905.         
  4906.             
  4907.             $items = array();
  4908.             $avoir = new Commande;
  4909.             $avoir->setBoutique($boutique);
  4910.             $avoir->setTypeFacture('bill_credit');
  4911.             $avoir->setNumero($this->getNumero('bill_credit'$boutique));
  4912.             $avoir->setTiers($commande->getTiers());
  4913.             $avoir->setIdFactureDeBase($commande->getId());
  4914.             $em->persist($avoir);
  4915.             
  4916.             $em->flush();
  4917.             $avoirProduits = array();
  4918.             foreach($produitCommandes as $produitCommande){
  4919.                     $idProduitPourFactureDAvoirFNE $_POST['idProduit'.$produitCommande->getProduit()->getId()];
  4920.                     $quantiteRetournee = (float)$_POST['quantite'.$produitCommande->getProduit()->getId()];
  4921.                 if($quantiteRetournee && $quantiteRetournee <= $produitCommande->getQuantite()){
  4922.                     $item = array(
  4923.                             'id' => $idProduitPourFactureDAvoirFNE,
  4924.                             'quantity' => $quantiteRetournee,
  4925.                     );
  4926.                     
  4927.                     array_push($items$item);
  4928.                     $avoirProduit = new ProduitCommande;
  4929.                     $avoirProduit->setCommande($avoir);
  4930.                     $avoirProduit->setProduit($produitCommande->getProduit());
  4931.                     $avoirProduit->setQuantite($quantiteRetournee);
  4932.                     $avoirProduit->setPrix($produitCommande->getPrix());
  4933.                     $totalHt $quantiteRetournee $produitCommande->getPrix();
  4934.                     
  4935.                     $totalTVA =  $produitCommande->getTotalTva() * $quantiteRetournee/$produitCommande->getQuantite();
  4936.                     $totalTTC $totalHt $totalTVA;
  4937.                     $avoirProduit->setTotalHT($totalHt);
  4938.                     $avoirProduit->setTva($totalTVA);
  4939.                     $avoirProduit->setTotalTTC($totalTTC);
  4940.                     $em->persist($avoirProduit);
  4941.                     array_push($avoirProduits$avoirProduit);
  4942.                     $avoir->setTotalHT($avoir->getTotalHT()+ $totalHt);
  4943.                     $avoir->setTotalHTApresRemise($avoir->getTotalHTApresRemise() + $totalHt);
  4944.                     $avoir->setTotalTTC($avoir->getTotalTTC()+ $totalTTC);
  4945.                     $avoir->setTotalTVA($avoir->getTotalTVA()+ $totalTVA);
  4946.                 }
  4947.             }
  4948.             $avoir->setmontantEnLettre($chiffreEnLettre->Conversion($avoir->getTotalTTC()));
  4949.             $em->flush();
  4950.             $pdf = new Html2Pdf('P'$boutique->getSettings()->getFormatPapierImpression(), 'en');
  4951.                 
  4952.                     
  4953.             $pdfContent $this->renderView('pdf/facture_avoir.html.twig', [
  4954.                         'boutique' => $boutique,
  4955.                         'facture' => $avoir,
  4956.                         'produits' => $avoirProduits,
  4957.                         'commandeDeBasse' => $commande
  4958.                 ]);
  4959.             $pdf->writeHTML($pdfContent);
  4960.             $name $avoir->getTypeFacture().$avoir->getId().time().$boutique->getId().rand(110000).'.pdf';
  4961.             $lienPhysique $avoir->getUploadRootDir().$name;
  4962.                 
  4963.             $avoir->setLienPDF($this->getDomain().'/pdf478njkp01/'.$name);
  4964.             $pdf->output($lienPhysique'F');
  4965.             // Fin facture PDF
  4966.             
  4967.             $em->flush();
  4968.             $content = array(
  4969.                 'id' => $commande->getIdFactureFNE(),
  4970.                 'items' => $items
  4971.             );
  4972.             
  4973.             
  4974.             $content json_encode($content);
  4975.             
  4976.             $ch curl_init($url);
  4977.             curl_setopt($chCURLOPT_RETURNTRANSFERtrue);
  4978.             curl_setopt($chCURLOPT_HTTPHEADER, ['Content-Type: application/json''Authorization: Bearer '.$boutique->getApiKeyFNE()]);
  4979.             curl_setopt($chCURLOPT_POSTFIELDS$content);
  4980.             $serverOutput curl_exec($ch);
  4981.             curl_close($ch);
  4982.             
  4983.             $response = new JsonResponse;
  4984.             
  4985.             
  4986.             //$response->setContent(json_encode($serverOutput));
  4987.             //return $response;
  4988.             $serverOutput json_decode($serverOutputtrue);
  4989.             //$commande->setIdFactureFNE($serverOutput['invoice']['id']);
  4990.             if(isset($serverOutput['token'])){
  4991.                 $avoir->seTtokenFNE($serverOutput['token']);
  4992.             }
  4993.             //$boutique->setSoldeTimbreFNE($serverOutput['balance_sticker']);
  4994.             if(isset($serverOutput['balance_funds'])){
  4995.                 $boutique->setSoldeTimbreFNE($serverOutput['balance_funds']);
  4996.             }
  4997.             if(isset($serverOutput['balance_sticker'])){
  4998.                 $boutique->setSoldeTimbreFNE($serverOutput['balance_sticker']);
  4999.             }
  5000.             
  5001.             
  5002.             $em->flush();
  5003.             return $serverOutput;
  5004.         
  5005.         
  5006.     }
  5007.     
  5008.     //Vente
  5009.     /**
  5010.      * @Route("/{slug}/change-sale-state/{type}/{id}/{state}", name="admin.change_sale_state")
  5011.      * @return \Symfony\Component\HttpFoundation\Response
  5012.      */
  5013.     public function changeSaleStateAction(Request $request$slug$type$id$state)
  5014.     {
  5015.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5016.            return $this->redirectToRoute('security_login');
  5017.         }
  5018.         
  5019.         $em $this->getDoctrine()
  5020.                     ->getManager();
  5021.                     
  5022.         $boutique  $em->getRepository(Boutique::class)
  5023.                         ->findOneBySlug($slug);
  5024.     
  5025.         $user $this->getUser();
  5026.         $userBoutique $em->getRepository(UserBoutique::class)
  5027.                         ->findOneBy(
  5028.                             array(
  5029.                             'user' => $user->getId(),
  5030.                             'boutique' => $boutique->getId()
  5031.                             )
  5032.                         );
  5033.         $commande  $em->getRepository(Commande::class)
  5034.                         ->findOneBy(
  5035.                             array(
  5036.                                 'boutique' => $boutique->getId(),
  5037.                                 'id' => $id
  5038.                         ));
  5039.         if($commande->getNumero() == ''){
  5040.             $commande->setNumero($this->getNumero($type$boutique));
  5041.         }
  5042.         $commande->setEtat($state);
  5043.         $em->flush();
  5044.         
  5045.         //Produit commande du devis
  5046.                     
  5047.         $produitCommandesDevis $em->getRepository(ProduitCommande::class)
  5048.                                 ->findByCommande($commande);
  5049.         //
  5050.         $produitCommandes = array();
  5051.         
  5052.         
  5053.         switch($type){
  5054.             case 'proposal':
  5055.                 
  5056.                     $facture = new  Commande;
  5057.                     $facture->setTypeFacture('invoice');
  5058.                     $facture->setNatureFacture('sale');
  5059.                     $facture->setEtat(Commande::ETAT_FACTURE_FINALISE);
  5060.                     $facture->setLaDate(new \DateTime());
  5061.                     $facture->setTotalHT($commande->getTotalHT());
  5062.                     $facture->setTotalHTApresRemise($commande->getTotalHTApresRemise());
  5063.                     $facture->setTotalTVA($commande->getTotalTVA());
  5064.                     $facture->setTotalTTC($commande->getTotalTTC());
  5065.                     $facture->setResteAPayer($commande->getTotalTTC());
  5066.                     $facture->setCoutDeRevient($commande->getCoutDeRevient());
  5067.                     
  5068.                     $facture->setRemise($commande->getRemise());
  5069.                     $facture->setRemisePourcentage($commande->getRemisePourcentage());
  5070.                     $facture->setMontantEnLettre($commande->getMontantEnLettre());
  5071.                     $facture->setBoutique($commande->getBoutique());
  5072.                     $facture->setTiers($commande->getTiers());
  5073.                     $facture->setClientFinalNom($commande->getClientFinalNom());
  5074.                     $facture->setClientFinalNumero($commande->getClientFinalNumero());
  5075.                     
  5076.                     $facture->setNumero($this->getNumero('invoice'$boutique));
  5077.                     $em->persist($facture);
  5078.                     $em->flush();
  5079.                     $this->genererEcritureComptableDeVente($boutique$facture);
  5080.                     
  5081.                     if($boutique->getApiKeyFNE() != ''){
  5082.                         if($boutique->getSettings()->isGenererAutomatiquementFNE()){
  5083.                             $responseFNE $this->genererFactureFNE($boutique->getSlug(), $facture->getId(), $facture->getNatureFacture());
  5084.                         }
  5085.                     
  5086.                     }
  5087.                     foreach($produitCommandesDevis as $produitCommandeDevis){
  5088.                         $prodCom = new ProduitCommande;
  5089.                         $prodCom->setProduit($produitCommandeDevis->getProduit());
  5090.                         $prodCom->setCommande($facture);
  5091.                         $prodCom->setQuantite($produitCommandeDevis->getQuantite());
  5092.                         $prodCom->setPrix($produitCommandeDevis->getPrix());
  5093.                         $prodCom->setRemise($produitCommandeDevis->getRemise());
  5094.                         $prodCom->setTotalHT($produitCommandeDevis->getTotalHT());
  5095.                         $prodCom->setTotalHTApresRemise($produitCommandeDevis->getTotalHTApresRemise());
  5096.                         $prodCom->setCoutDeRevient($produitCommandeDevis->getCoutDeRevient());
  5097.                         $prodCom->setTotalCoutDeRevient($produitCommandeDevis->getTotalCoutDeRevient());
  5098.                         
  5099.                         
  5100.                         $prodCom->setTotalTVA($produitCommandeDevis->getTotalTVA());
  5101.                         $prodCom->setTotalTTC($produitCommandeDevis->getTotalTTC());
  5102.                         $prodCom->setTva($produitCommandeDevis->getTva());
  5103.                         if($produitCommandeDevis->getProduit()->getTypeProduit() == 'produit'){
  5104.                             $produitCommandeDevis->getProduit()->setStockDisponible($produitCommandeDevis->getProduit()->getStockDisponible() - $produitCommandeDevis->getQuantite());
  5105.                         }
  5106.                         if($produitCommandeDevis->getProduit()->getTypeProduit() == 'produit'){
  5107.                             if($type == 'invoice'){
  5108.                                 
  5109.                                 $produitVendu $em->getRepository(Produit::class)
  5110.                                                 ->findOneById($idDuProduit);
  5111.                                 $produitVendu->setStockDisponible($produitVendu->getStockDisponible() - $produitCommandeDevis->getQuantite());
  5112.                             }
  5113.                         }
  5114.                         $em->persist($prodCom);
  5115.                         array_push($produitCommandes$prodCom);
  5116.                     }
  5117.                     
  5118.                     $pdf = new Html2Pdf('P'$boutique->getSettings()->getFormatPapierImpression(), 'en');
  5119.                     
  5120.                     $content $this->renderView('pdf/facture.html.twig', [
  5121.                         'boutique' => $boutique,
  5122.                         'facture' => $facture,
  5123.                         'produits' => $produitCommandes
  5124.                     ]);
  5125.                     
  5126.                     $pdf->writeHTML($content);
  5127.                     $lienPhysique $facture->getUploadRootDir().$facture->getTypeFacture().$facture->getId().'.pdf';
  5128.                 
  5129.                     $facture->setLienPDF($this->getDomain().'/pdf478njkp01/'.$facture->getTypeFacture().$facture->getId().'.pdf');
  5130.                     $pdf->output($lienPhysique'F');
  5131.                     
  5132.                     $commande->setEtat(Commande::ETAT_DEVIS_FINALISE);
  5133.                     $em->flush();
  5134.                 return $this->redirectToRoute('admin.proposals', array('slug' => $boutique->getSlug()));
  5135.             
  5136.             break;
  5137.             
  5138.             case 'invoice':
  5139.                     $pdf = new Html2Pdf('P'$boutique->getSettings()->getFormatPapierImpression(), 'en');
  5140.                     
  5141.                     $content $this->renderView('pdf/facture.html.twig', [
  5142.                         'boutique' => $boutique,
  5143.                         'facture' => $commande,
  5144.                         'produits' => $produitCommandes
  5145.                     ]);
  5146.                     
  5147.                     $pdf->writeHTML($content);
  5148.                     $lienPhysique $commande->getUploadRootDir().$commande->getTypeFacture().$commande->getId().'.pdf';
  5149.                 
  5150.                     $commande->setLienPDF($this->getDomain().'/pdf478njkp01/'.$commande->getTypeFacture().$commande->getId().'.pdf');
  5151.                     $commande->setEtat(Commande::ETAT_FACTURE_FINALISE);
  5152.                     $pdf->output($lienPhysique'F');
  5153.                     
  5154.                     $em->flush();
  5155.                 return $this->redirectToRoute('admin.invoices', array('slug' => $boutique->getSlug()));
  5156.             break;
  5157.         }
  5158.         
  5159.         
  5160.         return $this->redirectToRoute('admin.invoices', array('slug' => $boutique->getSlug()));
  5161.         
  5162.     }
  5163.     
  5164.     
  5165.     /**
  5166.      * @Route("/{slug}/check-customer-vat-status", name="admin.check_customer_vat_status")
  5167.      * @return \Symfony\Component\HttpFoundation\Response
  5168.      */
  5169.     public function checkCustomerVATStatusAction(Request $request$slug)
  5170.     {
  5171.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5172.            return $this->redirectToRoute('security_login');
  5173.         }
  5174.         $em $this->getDoctrine()
  5175.                     ->getManager();
  5176.         $response = new JsonResponse;
  5177.         $response->headers->set('Access-Control-Allow-Origin''*');
  5178.         $response->headers->set('Content-Type''application/json');
  5179.         
  5180.         $boutique $em->getRepository(Boutique::class)
  5181.                                     ->findOneBySlug($slug);
  5182.                         
  5183.         $data = array();
  5184.         
  5185.         if($request->getMethod() == 'POST'){
  5186.             $id $_POST['id'];
  5187.             $customer  $em->getRepository(Tiers::class)
  5188.                         ->findOneBy(
  5189.                             array(
  5190.                                 'boutique' => $boutique->getId(),
  5191.                                 'id' => $id
  5192.                         ));
  5193.             
  5194.             $data = array(
  5195.                 "assujettiALaTVA" => $customer->getAssujettiALaTVA()
  5196.             );
  5197.         }
  5198.         
  5199.         $response->setContent(json_encode($data));
  5200.         return $response;
  5201.     }
  5202.     
  5203.     
  5204.     //Vente
  5205.     /**
  5206.      * @Route("/{slug}/edit-sale/{type}/{id}", name="admin.edit_sale")
  5207.      * @return \Symfony\Component\HttpFoundation\Response
  5208.      */
  5209.     public function editSaleAction(Request $requestChiffreEnLettre $chiffreEnLettre$slug$type$id)
  5210.     {
  5211.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5212.            return $this->redirectToRoute('security_login');
  5213.         }  
  5214.         $em $this->getDoctrine()
  5215.                     ->getManager();
  5216.         $boutique  $em->getRepository(Boutique::class)
  5217.                         ->findOneBySlug($slug);
  5218.     
  5219.         $produits  $em->getRepository(Produit::class)
  5220.                         ->findByBoutique($boutique->getId());
  5221.     
  5222.         $commande  $em->getRepository(Commande::class)
  5223.                         ->findOneBy(
  5224.                             array(
  5225.                                 'boutique' => $boutique->getId(),
  5226.                                 'id' => $id
  5227.                         ));
  5228.         
  5229.         $ancienProduitCommandes  $em->getRepository(ProduitCommande::class)
  5230.                         ->findBy(
  5231.                             array(
  5232.                                 'commande' => $commande->getId()
  5233.                         ));
  5234.                         
  5235.         $modeleReglements $em->getRepository(ModeleReglement::class)
  5236.                                 ->findByBoutique($boutique);        
  5237.         $tiers $em->getRepository(Tiers::class)
  5238.                                 ->findByBoutique($boutique);        
  5239.         
  5240.         $user $this->getUser();
  5241.         $userBoutique $em->getRepository(UserBoutique::class)
  5242.                         ->findOneBy(
  5243.                             array(
  5244.                             'user' => $user->getId(),
  5245.                             'boutique' => $boutique->getId()
  5246.                             )
  5247.                         );
  5248.         $vehicules = array(1222328);
  5249.     
  5250.         $ok_soumission '';
  5251.         $error '';
  5252.         $editMode 'edit';
  5253.         if($request->getMethod() == 'POST'){
  5254.             $typeFacture $_POST['typeFacture'];
  5255.             $observation $_POST['observation'];
  5256.             $titreDocument $_POST['titreDocument'];
  5257.             $modeleReglement $_POST['modeleReglement'];
  5258.             $moyenDePaiement $_POST['moyenDePaiement'];
  5259.             $client $_POST['client'];
  5260.             $clientFinalNom $_POST['clientFinalNom'];
  5261.             $clientFinalNumero $_POST['clientFinalNumero'];
  5262.             $dateCommande $_POST['dateCommande'];
  5263.             
  5264.             $montantHT = (float)$_POST['montantHT'];
  5265.             $remise =   (float)$_POST['remise'];
  5266.             $remisePourcentage =  (float)$_POST['remisePourcentage'];
  5267.             $totalHTApresRemise =  (float)$_POST['totalHTApresRemise'];
  5268.             $montantTVA = (float)$_POST['montantTVA'];
  5269.             $montantTTC = (float)$_POST['montantTTC'];
  5270.             $matriculeVehicule $_POST['matriculeVehicule'];
  5271.             $marqueVehicule $_POST['marqueVehicule'];
  5272.             $kilometrageVehicule = (float)$_POST['kilometrageVehicule'];
  5273.             $listeProduits json_decode($_POST['listeProduits']);
  5274.             $client $em->getRepository(Tiers::class)
  5275.                         ->findOneById($client);
  5276.             if(null !== $client){
  5277.                 $commande->setTiers($client);
  5278.             }
  5279.             
  5280.             $laDate = new \DateTime($dateCommande);
  5281.             $commande->setLaDate($laDate);
  5282.             $commande->setTitreDocument($titreDocument);
  5283.             $commande->setObservation($observation);
  5284.             $commande->setModifiePar($user);
  5285.             $commande->setMoyenDePaiement($moyenDePaiement);
  5286.             $commande->setClientFinalNom($clientFinalNom);
  5287.             $commande->setClientFinalNumero($clientFinalNumero);
  5288.             
  5289.             $commande->setMatriculeVehicule($matriculeVehicule);
  5290.             $commande->setMarqueVehicule($marqueVehicule);
  5291.             $commande->setKilometrageVehicule($kilometrageVehicule);
  5292.             $commande->setTotalHT($montantHT);
  5293.             $commande->setRemise($remise);
  5294.             $commande->setRemisePourcentage($remisePourcentage);
  5295.             $commande->setTotalHTApresRemise($totalHTApresRemise);
  5296.             
  5297.             $commande->setTotalTVA($montantTVA);
  5298.             $commande->setTotalTTC($montantTTC);
  5299.             $commande->setResteAPayer($montantTTC);
  5300.             $montantlettre strtoupper($chiffreEnLettre->Conversion($montantTTC));
  5301.             $commande->setMontantEnLettre($montantlettre);
  5302.             $commande->setTypeFacture($type);
  5303.             if($commande->getNumero() == ''){
  5304.                 $commande->setNumero($this->getNumero($type$boutique));
  5305.             }
  5306.             $em->flush();
  5307.             
  5308.             //Supprimer les ancien ProduitCommande lié 
  5309.             foreach($ancienProduitCommandes as $ancienProduitCommande){
  5310.                 $em->remove($ancienProduitCommande);
  5311.             }
  5312.             $em->flush();
  5313.             $produitCommandes = array();
  5314.             $coutDeRevientCommande 0;
  5315.             foreach($listeProduits as $listeProduit){
  5316.                 $listeProduit = (array)$listeProduit;
  5317.                 $idDuProduit $listeProduit['idProduit'];
  5318.             
  5319.                 if($idDuProduit == ''){
  5320.                     //Produit inexistant, il faut le créer
  5321.                     $leProduit = new Produit;
  5322.                     $leProduit->setNom($listeProduit['nomProduit']);
  5323.                     $em->persist($leProduit);
  5324.                     
  5325.                     //TVA
  5326.                     if($listeProduit['tva'] > 0){
  5327.                         $tva $em->getRepository(TVA::class)
  5328.                                     ->findOneBy(
  5329.                                         array(
  5330.                                             'boutique' => $boutique->getId(),
  5331.                                             'valeur'  => $listeProduit['tva']
  5332.                                         )
  5333.                                     );
  5334.                         if($tva == null){
  5335.                             $tva = new TVA;
  5336.                             $tva->setValeur($listeProduit['tva']);
  5337.                             $em->persist($tva);
  5338.                             $em->flush();
  5339.                         }
  5340.                         
  5341.                         $leProduit->setTva($tva);
  5342.                         
  5343.                     }
  5344.                     //Prix
  5345.                     $produitP = new PrixProduit;
  5346.                     $produitP->setValeur($listeProduit['prixUnitaire']);
  5347.                     $produitP->setBoutique($boutique);
  5348.                     $leProduit->addPrix($produitP);
  5349.                     $leProduit->setPrixActuel($produitP);
  5350.                     $leProduit->setBoutique($boutique);
  5351.                     $em->persist($produitP);
  5352.                     $em->persist($leProduit);
  5353.                     $em->flush();
  5354.                     
  5355.                 } else{
  5356.                     $leProduit $em->getRepository(Produit::class)
  5357.                         ->findOneById($idDuProduit);
  5358.                 }
  5359.                 $produitCommande = new ProduitCommande;
  5360.                 $produitCommande->setProduit($leProduit);
  5361.                 $produitCommande->setCommande($commande);
  5362.                 $quantite = (float)$listeProduit['quantite'];
  5363.                 $produitCommande->setQuantite($quantite);
  5364.                 $produitCommande->setPrix((float)$listeProduit['prixUnitaire']);
  5365.                 $prixDeRevient = (float)$listeProduit['prixDeRevient'];
  5366.                 $produitCommande->setCoutDeRevient($prixDeRevient);
  5367.                 $totalCoutDeRevient $prixDeRevient $quantite;
  5368.                 $produitCommande->setTotalCoutDeRevient($totalCoutDeRevient);
  5369.                 $coutDeRevientCommande += $totalCoutDeRevient;
  5370.                 $produitCommande->setRemise((float)$listeProduit['reduction']);
  5371.                 $produitCommande->setMontantRemise((float)$listeProduit['montantReduction']);
  5372.                 $produitCommande->setTotalHT((float)$listeProduit['totalHT']);
  5373.                 $produitCommande->setTotalHTApresRemise((float)$listeProduit['totalHTApresRemise']);
  5374.                 
  5375.                 $produitCommande->setTotalTVA((float)$listeProduit['totalTVA']);
  5376.                 $produitCommande->setTva((float)$listeProduit['tva']);
  5377.                 $produitCommande->setTotalTTC((float)$listeProduit['totalTTC']);
  5378.                 $em->persist($produitCommande);
  5379.                 array_push($produitCommandes$produitCommande);
  5380.                 
  5381.             } //Fin boucle sur les produit
  5382.             $em->flush();
  5383.             $commande->setCoutDeRevient($coutDeRevientCommande);
  5384.             
  5385.             $pdf = new Html2Pdf('P'$boutique->getSettings()->getFormatPapierImpression(), 'en');
  5386.             $content '';
  5387.             switch($type){
  5388.                 case 'invoice':    
  5389.                     $content $this->renderView('pdf/facture.html.twig', [
  5390.                         'boutique' => $boutique,
  5391.                         'facture' => $commande,
  5392.                         'produits' => $produitCommandes
  5393.                     ]);
  5394.                 break;
  5395.                 
  5396.                 case 'proposal':
  5397.                     $content $this->renderView('pdf/devis.html.twig', [
  5398.                         'boutique' => $boutique,
  5399.                         'facture' => $commande,
  5400.                         'produits' => $produitCommandes
  5401.                     ]);
  5402.                 break;
  5403.             }
  5404.             
  5405.             $pdf->writeHTML($content);
  5406.             $lienPhysique $commande->getUploadRootDir().$commande->getTypeFacture().$commande->getId().'.pdf';
  5407.                 
  5408.             $commande->setLienPDF($this->getDomain().'/pdf478njkp01/'.$commande->getTypeFacture().$commande->getId().'.pdf');
  5409.             $pdf->output($lienPhysique'F');
  5410.             
  5411.             $em->flush();
  5412.             
  5413.             return $this->render('admin/response_new_sale.html.twig', [
  5414.                    'boutique' => $boutique,
  5415.                    'commande' => $commande,
  5416.                    'responseFNE' => '',
  5417.                    'vehicules' => $vehicules,
  5418.                    'typeFacture' => $typeFacture,
  5419.                    'client' => $client,
  5420.                    'produitCommandes' => $produitCommandes,
  5421.                    'listeProduit' => $listeProduit,
  5422.                    'montantHT' => $montantHT,
  5423.                    'montantTVA' => $montantTVA,
  5424.                    'montantTTC' => $montantTTC,
  5425.                    'userBoutique' => $userBoutique
  5426.                 ]);
  5427.             
  5428.         }
  5429.     
  5430.         return $this->render('admin/edit_sale.html.twig', [
  5431.            'boutique' => $boutique,
  5432.            'produits' => $produits,
  5433.            'modeleReglements' => $modeleReglements,
  5434.            'tiers' => $tiers,
  5435.            'editMode' => $editMode,
  5436.            'commande' => $commande,
  5437.            'ancienProduitCommandes' => $ancienProduitCommandes,
  5438.            'type' => $type,
  5439.            'userBoutique' => $userBoutique,
  5440.            'vehicules' => $vehicules
  5441.         ]);
  5442.     }
  5443.     /**
  5444.      * @Route("/{slug}/bon-de-livraison/{id}", name="admin.bon_de_livraison")
  5445.      * @return \Symfony\Component\HttpFoundation\Response
  5446.      */
  5447.     public function bonDeLivraisonAction(Request $request$slug$id)
  5448.     {
  5449.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5450.            return $this->redirectToRoute('security_login');
  5451.         }      
  5452.         $em $this->getDoctrine()
  5453.                     ->getManager();
  5454.         $boutique  $em->getRepository(Boutique::class)
  5455.                         ->findOneBySlug($slug);
  5456.     
  5457.         $user $this->getUser();
  5458.         $userBoutique $em->getRepository(UserBoutique::class)
  5459.                         ->findOneBy(
  5460.                             array(
  5461.                             'user' => $user->getId(),
  5462.                             'boutique' => $boutique->getId()
  5463.                             )
  5464.                         );
  5465.         $commande  $em->getRepository(Commande::class)
  5466.                         ->findOneBy(
  5467.                             array(
  5468.                                 'boutique' => $boutique->getId(),
  5469.                                 'id' => $id
  5470.                         ));
  5471.         
  5472.         
  5473.             
  5474.             return $this->render('admin/bon_de_livraison.html.twig', [
  5475.                 'boutique' => $boutique,
  5476.                 'facture' => $commande,
  5477.                 'userBoutique' => $userBoutique,
  5478.                 'commande' => $commande
  5479.             ]);
  5480.     }        
  5481.     /**
  5482.      * @Route("/{slug}/bon-de-livraison-avec-date/{id}", name="admin_bon_de_livraison_avec_date")
  5483.      * @return \Symfony\Component\HttpFoundation\Response
  5484.      */
  5485.     public function bonDeLivraisonAvecDateAction(Request $request$slug$id)
  5486.     {
  5487.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5488.            return $this->redirectToRoute('security_login');
  5489.         }      
  5490.         $em $this->getDoctrine()
  5491.                     ->getManager();
  5492.         $boutique  $em->getRepository(Boutique::class)
  5493.                         ->findOneBySlug($slug);
  5494.     
  5495.         $user $this->getUser();
  5496.         $userBoutique $em->getRepository(UserBoutique::class)
  5497.                         ->findOneBy(
  5498.                             array(
  5499.                             'user' => $user->getId(),
  5500.                             'boutique' => $boutique->getId()
  5501.                             )
  5502.                         );
  5503.         if($request->getMethod() == 'POST'){
  5504.         $dateDImpression $request->request->get('dateDImpression');
  5505.         $dateDImpression = new \DateTime($dateDImpression);
  5506.         $commande  $em->getRepository(Commande::class)
  5507.                         ->findOneBy(
  5508.                             array(
  5509.                                 'boutique' => $boutique->getId(),
  5510.                                 'id' => $id
  5511.                         ));
  5512.         
  5513.         $listeProduits  $em->getRepository(ProduitCommande::class)
  5514.                         ->findBy(
  5515.                             array(
  5516.                                 'commande' => $commande->getId()
  5517.                         ));
  5518.                 
  5519.             
  5520.             $produitCommandes = array();
  5521.             foreach($listeProduits as $listeProduit){
  5522.                 
  5523.                 array_push($produitCommandes$listeProduit);
  5524.                 
  5525.             }
  5526.             
  5527.             $pdf = new Html2Pdf('P'$boutique->getSettings()->getFormatPapierImpression(), 'en');
  5528.             
  5529.             
  5530.             $content $this->renderView('pdf/bon_de_livraison.html.twig', [
  5531.                 'boutique' => $boutique,
  5532.                 'facture' => $commande,
  5533.                 'produits' => $produitCommandes,
  5534.                 'dateDImpression' => $dateDImpression
  5535.             ]);
  5536.             
  5537.             
  5538.             $pdf->writeHTML($content);
  5539.             $lienPhysique $commande->getUploadRootDir().'_bon_de_livraison_'.$commande->getId().'.pdf';
  5540.                 
  5541.             $pdf->output($lienPhysique'I');
  5542.             
  5543.             return $this->renderView('pdf/bon_de_livraison.html.twig', [
  5544.                 'boutique' => $boutique,
  5545.                 'facture' => $commande,
  5546.                 'produits' => $produitCommandes,
  5547.                 'dateDImpression' => $dateDImpression
  5548.             ]);
  5549.         }
  5550.     }        
  5551.     
  5552.     
  5553.     /**
  5554.      * @Route("/{slug}/duplicate-sale/{id}", name="admin.duplicate_sale")
  5555.      * @return \Symfony\Component\HttpFoundation\Response
  5556.      */
  5557.     public function duplicateSaleAction(Request $request$slug$id)
  5558.     {
  5559.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5560.            return $this->redirectToRoute('security_login');
  5561.         }      
  5562.         $em $this->getDoctrine()
  5563.                     ->getManager();
  5564.         $boutique  $em->getRepository(Boutique::class)
  5565.                         ->findOneBySlug($slug);
  5566.     
  5567.         $user $this->getUser();
  5568.         $userBoutique $em->getRepository(UserBoutique::class)
  5569.                         ->findOneBy(
  5570.                             array(
  5571.                             'user' => $user->getId(),
  5572.                             'boutique' => $boutique->getId()
  5573.                             )
  5574.                         );
  5575.         $commande  $em->getRepository(Commande::class)
  5576.                         ->findOneBy(
  5577.                             array(
  5578.                                 'boutique' => $boutique->getId(),
  5579.                                 'id' => $id
  5580.                         ));
  5581.         
  5582.         $listeProduits  $em->getRepository(ProduitCommande::class)
  5583.                         ->findBy(
  5584.                             array(
  5585.                                 'commande' => $commande->getId()
  5586.                         ));
  5587.                 
  5588.             $nouvelleCommande = new Commande;
  5589.             $nouvelleCommande->setBoutique($boutique);
  5590.             $nouvelleCommande->setTiers($commande->getTiers());
  5591.             
  5592.             $nouvelleCommande->setLaDate(new \DateTime());
  5593.             $nouvelleCommande->setTotalHT($commande->getTotalHT());
  5594.             $nouvelleCommande->setTotalHTApresRemise($commande->getTotalHTApresRemise());
  5595.             $nouvelleCommande->setRemise($commande->getRemise());
  5596.             $nouvelleCommande->setRemisePourcentage($commande->getRemisePourcentage());
  5597.             $nouvelleCommande->setTotalTVA($commande->getTotalTVA());
  5598.             $nouvelleCommande->setTotalAutreTaxe($commande->getTotalAutreTaxe());
  5599.             $nouvelleCommande->setTotalTTC($commande->getTotalTTC());
  5600.             $nouvelleCommande->setResteAPayer($commande->getTotalTTC());
  5601.             $nouvelleCommande->setTitreDocument($commande->getTitreDocument());
  5602.             $nouvelleCommande->setObservation($commande->getObservation());
  5603.             $nouvelleCommande->setValableJusquAu($commande->getValableJusquAu());
  5604.             $nouvelleCommande->setMontantEnLettre($commande->getMontantEnLettre());
  5605.             $nouvelleCommande->setTypeFacture($commande->getTypeFacture());
  5606.             $nouvelleCommande->setNatureFacture($commande->getNatureFacture());
  5607.             
  5608.             $nouvelleCommande->setNumero($this->getNumero($nouvelleCommande->getTypeFacture(), $boutique));
  5609.             $em->persist($nouvelleCommande);
  5610.             $em->flush();
  5611.             $produitCommandes = array();
  5612.             foreach($listeProduits as $listeProduit){
  5613.                 $produitCommande = new ProduitCommande;
  5614.                 $produitCommande->setProduit($listeProduit->getProduit());
  5615.                 $produitCommande->setCommande($nouvelleCommande);
  5616.                 $produitCommande->setQuantite($listeProduit->getQuantite());
  5617.                 $produitCommande->setPrix($listeProduit->getPrix());
  5618.                 $produitCommande->setRemise($listeProduit->getRemise());
  5619.                 $produitCommande->setRemisePourcentage($listeProduit->getRemisePourcentage());
  5620.                 $produitCommande->setTotalHT($listeProduit->getTotalHT());
  5621.                 $produitCommande->setTotalHTApresRemise($listeProduit->getTotalHTApresRemise());
  5622.                 $produitCommande->setTotalTVA($listeProduit->getTotalTVA());
  5623.                 $produitCommande->setAutreTaxe($listeProduit->getAutreTaxe());
  5624.                 $produitCommande->setTotalTTC($listeProduit->getTotalTTC());
  5625.                 $em->persist($produitCommande);
  5626.                 
  5627.                 array_push($produitCommandes$produitCommande);
  5628.                 
  5629.             }
  5630.             $em->flush();
  5631.             
  5632.             if($nouvelleCommande->getTypeFacture() == 'invoice'){
  5633.                     
  5634.                 if($boutique->getApiKeyFNE() != ''){
  5635.                     if($boutique->getSettings()->isGenererAutomatiquementFNE()){
  5636.                         $responseFNE $this->genererFactureFNE($boutique->getSlug(), $nouvelleCommande->getId(), $nouvelleCommande->getNatureFacture());
  5637.                     }
  5638.                     
  5639.                 }
  5640.                 $this->genererEcritureComptableDeVente($boutique$nouvelleCommande);
  5641.                     //Ecriture comptable
  5642.             }
  5643.             $pdf = new Html2Pdf('P'$boutique->getSettings()->getFormatPapierImpression(), 'en');
  5644.             $content '';
  5645.             switch($commande->getTypeFacture()){
  5646.                 case 'invoice':    
  5647.                     $content $this->renderView('pdf/facture.html.twig', [
  5648.                         'boutique' => $boutique,
  5649.                         'facture' => $nouvelleCommande,
  5650.                         'produits' => $produitCommandes
  5651.                     ]);
  5652.                 break;
  5653.                 
  5654.                 case 'proposal':
  5655.                     $content $this->renderView('pdf/devis.html.twig', [
  5656.                         'boutique' => $boutique,
  5657.                         'facture' => $nouvelleCommande,
  5658.                         'produits' => $produitCommandes
  5659.                     ]);
  5660.                 break;
  5661.             }
  5662.             
  5663.             $pdf->writeHTML($content);
  5664.             $lienPhysique $nouvelleCommande->getUploadRootDir().$nouvelleCommande->getTypeFacture().$nouvelleCommande->getId().'.pdf';
  5665.                 
  5666.             $nouvelleCommande->setLienPDF($this->getDomain().'/pdf478njkp01/'.$nouvelleCommande->getTypeFacture().$nouvelleCommande->getId().'.pdf');
  5667.             $pdf->output($lienPhysique'F');
  5668.             
  5669.             $em->flush();
  5670.             
  5671.             switch($commande->getTypeFacture()){
  5672.                 case 'invoice':    
  5673.                     return $this->redirectToRoute('admin.invoices',  array('slug' => $boutique->getSlug()));
  5674.                 break;
  5675.                 
  5676.                 case 'proposal':
  5677.                     return $this->redirectToRoute('admin.proposals',  array('slug' => $boutique->getSlug()));
  5678.                 break;
  5679.                 
  5680.                 case 'bill_credit':
  5681.                     return $this->redirectToRoute('admin.bill_credits',  array('slug' => $boutique->getSlug()));
  5682.                 break;
  5683.                 
  5684.                 case 'deposit':
  5685.                     return $this->redirectToRoute('admin.deposits',  array('slug' => $boutique->getSlug()));
  5686.                 break;
  5687.             }
  5688.     }
  5689.     
  5690.     /**
  5691.      * @Route("/{slug}/delete-sale/{type}/{id}", name="admin.delete_sale")
  5692.      * @return \Symfony\Component\HttpFoundation\Response
  5693.   
  5694.     */
  5695.     public function deleteSaleAction(Request $request$slug$type$id)
  5696.     {
  5697.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5698.            return $this->redirectToRoute('security_login');
  5699.         }
  5700.         $em $this->getDoctrine()
  5701.                     ->getManager();
  5702.         
  5703.         $boutique $em->getRepository(Boutique::class)
  5704.                         ->findOneBySlug($slug);
  5705.         $user $this->getUser();
  5706.         $userBoutique $em->getRepository(UserBoutique::class)
  5707.                         ->findOneBy(
  5708.                             array(
  5709.                             'user' => $user->getId(),
  5710.                             'boutique' => $boutique->getId()
  5711.                             )
  5712.                         );
  5713.         $commande $em->getRepository(Commande::class)
  5714.                         ->findOneBy(
  5715.                             array(
  5716.                                 'boutique' => $boutique->getId(),
  5717.                                 'id' => $id
  5718.                             ));
  5719.         /*
  5720.         
  5721.         $produitCommandes = $em->getRepository(ProduitCommande::class)
  5722.                         ->findByCommande($commande->getId());
  5723.                         
  5724.         foreach($produitCommandes as $produitCommande){
  5725.             $em->remove($produitCommande);
  5726.         }
  5727.         $em->flush();
  5728.         
  5729.         $em->remove($commande);
  5730.         */
  5731.         
  5732.         
  5733.         $commande->setEstSupprime(true);
  5734.         $commande->setSupprimePar($user);
  5735.         $em->flush();
  5736.         
  5737.         switch($type){
  5738.             case 'invoice':
  5739.                 return $this->redirectToRoute('admin.invoices', array('slug' => $boutique->getSlug()));
  5740.             break;
  5741.             
  5742.             case 'bill_credit':
  5743.                 return $this->redirectToRoute('admin.bill_credits', array('slug' => $boutique->getSlug()));
  5744.             break;
  5745.             
  5746.             case 'proposal':
  5747.                 return $this->redirectToRoute('admin.proposals', array('slug' => $boutique->getSlug()));
  5748.             break;
  5749.         }
  5750.         
  5751.     }
  5752.     
  5753.     /**
  5754.      * @Route("/{slug}/product/list", name="admin.list_product")
  5755.      * @return \Symfony\Component\HttpFoundation\Response
  5756.     */
  5757.     public function listProductAction(Request $requestBoutique $boutique)
  5758.     {
  5759.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5760.            return $this->redirectToRoute('security_login');
  5761.         }
  5762.         $em $this->getDoctrine()
  5763.                     ->getManager();
  5764.         
  5765.         $produits $em->getRepository(Produit::class)
  5766.                         ->findBy(
  5767.                             array(
  5768.                                 'boutique' => $boutique->getId(),
  5769.                                 'estSupprime' => false
  5770.                             ),    
  5771.                             array(
  5772.                                 'nom' => 'ASC'
  5773.                             )
  5774.                         );
  5775.         $user $this->getUser();
  5776.         $userBoutique $em->getRepository(UserBoutique::class)
  5777.                         ->findOneBy(
  5778.                             array(
  5779.                             'user' => $user->getId(),
  5780.                             'boutique' => $boutique->getId()
  5781.                             )
  5782.                         );
  5783.         return $this->render('admin/liste_produit.html.twig', [
  5784.            'boutique' => $boutique,
  5785.            'produits' => $produits,
  5786.            'userBoutique' => $userBoutique
  5787.         ]);
  5788.     }
  5789.     
  5790.     /**
  5791.      * @Route("/{slug}/new-product", name="admin.new_product")
  5792.      * @return \Symfony\Component\HttpFoundation\Response
  5793.      */
  5794.     public function newProductAction(Request $requestBoutique $boutique)
  5795.     {
  5796.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5797.            return $this->redirectToRoute('security_login');
  5798.         }
  5799.         $em $this->getDoctrine()
  5800.                     ->getManager();
  5801.         
  5802.         $produit = new Produit;
  5803.         
  5804.         $user $this->getUser();
  5805.         $userBoutique $em->getRepository(UserBoutique::class)
  5806.                         ->findOneBy(
  5807.                             array(
  5808.                             'user' => $user->getId(),
  5809.                             'boutique' => $boutique->getId()
  5810.                             )
  5811.                         );
  5812.         $form $this->createForm(ProduitType::class, $produit, array('boutique' => $boutique->getId()));
  5813.         
  5814.         $ok_soumission '';
  5815.         $error '';
  5816.         
  5817.         if($request->getMethod() == 'POST'){
  5818.             
  5819.                $form->handleRequest($request);
  5820.                if($form->isValid()){
  5821.                  $em->persist($produit);
  5822.                    $em->flush();
  5823.                  
  5824.                    //Prix
  5825.                    $prix = (float)$_POST['prix'];
  5826.                    $produitP = new PrixProduit;
  5827.                    $produitP->setValeur($prix);
  5828.                    $produitP->setBoutique($boutique);
  5829.                    $produit->addPrix($produitP);
  5830.                    $produit->setPrixActuel($produitP);
  5831.                    $produit->setBoutique($boutique);
  5832.                   $em->persist($produitP);
  5833.                   
  5834.                   $em->flush();
  5835.                 
  5836.                 $ok_soumission =" Votre message a été pris en compte";
  5837.                     
  5838.                 unset($produit);
  5839.                 unset($form);
  5840.                 $produit = new Produit;
  5841.                 $form $this->createForm(ProduitType::class, $produit, array('boutique' => $boutique->getId()));
  5842.                     
  5843.                 } else {
  5844.                     $error =" Veillez corrigez vos erreurs";
  5845.                 }
  5846.         }
  5847.     
  5848.         return $this->render('admin/nouveau_produit.html.twig', [
  5849.            'boutique' => $boutique,
  5850.            'form' => $form->createView(),
  5851.            'userBoutique' => $userBoutique
  5852.         ]);
  5853.     }
  5854.     
  5855.     /**
  5856.      * @Route("/{slug}/product/edit/{id}", name="admin.edit_product")
  5857.      * @return \Symfony\Component\HttpFoundation\Response
  5858.     */
  5859.     public function edtProductAction(Request $request$slug$id)
  5860.     {
  5861.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5862.            return $this->redirectToRoute('security_login');
  5863.         }
  5864.         $em $this->getDoctrine()
  5865.                     ->getManager();
  5866.         
  5867.         $boutique $em->getRepository(Boutique::class)
  5868.                         ->findOneBySlug($slug);
  5869.         
  5870.         $produit $em->getRepository(Produit::class)
  5871.                         ->findOneBy(
  5872.                             array(
  5873.                             'boutique' => $boutique->getId(),
  5874.                             'id' => $id
  5875.                             )
  5876.                         );
  5877.         
  5878.         $user $this->getUser();
  5879.         $userBoutique $em->getRepository(UserBoutique::class)
  5880.                         ->findOneBy(
  5881.                             array(
  5882.                             'user' => $user->getId(),
  5883.                             'boutique' => $boutique->getId()
  5884.                             )
  5885.                         );
  5886.         $form $this->createForm(ProduitEditType::class, $produit, array('boutique' => $boutique->getId()));
  5887.         
  5888.         $ok_soumission '';
  5889.         $error '';
  5890.         
  5891.         if($request->getMethod() == 'POST'){
  5892.             
  5893.                $form->handleRequest($request);
  5894.                if($form->isValid()){
  5895.                    //Prix
  5896.                     $prix = (float)$_POST['prix'];
  5897.                     if($prix && $produit->getPrixActuel()->getValeur() != $prix){
  5898.                         $produit->getPrixActuel()->setValeur($prix);
  5899.                         $produitP = new PrixProduit;
  5900.                        $produitP->setValeur($prix);
  5901.                        $produit->addPrix($produitP);
  5902.                        $produit->setPrixActuel($produitP);
  5903.                        $produit->setBoutique($boutique);
  5904.                       $em->persist($produitP);
  5905.                         
  5906.                     }
  5907.                     $em->flush();
  5908.                     $ok_soumission =" Votre message a été pris en compte";
  5909.                 } else {
  5910.                     $error =" Veillez corrigez vos erreurs";
  5911.                 }
  5912.         }
  5913.     
  5914.         return $this->render('admin/edit_product.html.twig', [
  5915.            'boutique' => $boutique,
  5916.            'form' => $form->createView(),
  5917.            'produit' => $produit,
  5918.            'userBoutique' => $userBoutique
  5919.         ]);
  5920.     }
  5921.     
  5922.     //Produit/Service
  5923.     /**
  5924.      * @Route("/{slug}/delete-product/{id}", name="admin.delete_product")
  5925.      * @return \Symfony\Component\HttpFoundation\Response
  5926.      */
  5927.     public function deleteProductAction(Request $request,  $slug$id)
  5928.     { 
  5929.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5930.            return $this->redirectToRoute('security_login');
  5931.         }
  5932.         $em $this->getDoctrine()
  5933.                     ->getManager();
  5934.         $boutique $em->getRepository(Boutique::class)
  5935.                         ->findOneBySlug($slug);
  5936.         
  5937.         $product $em->getRepository(Produit::class)
  5938.                         ->findOneBy(
  5939.                         array(
  5940.                             'boutique' => $boutique->getId(),
  5941.                             'id' => $id
  5942.                         )
  5943.                         );
  5944.         if(null !== $product){
  5945.             
  5946.             $product->setEstSupprime(true);
  5947.             $em->flush();
  5948.         }
  5949.         return $this->redirectToRoute('admin.list_product', array('slug' => $boutique->getSlug()));
  5950.     
  5951.     }
  5952.     
  5953.     /**
  5954.      * @Route("/{slug}/product-category/list", name="admin.category_product")
  5955.      * @return \Symfony\Component\HttpFoundation\Response
  5956.     */
  5957.     public function listeCategoryProductAction(Request $requestBoutique $boutique)
  5958.     {
  5959.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5960.            return $this->redirectToRoute('security_login');
  5961.         }
  5962.         $em $this->getDoctrine()
  5963.                     ->getManager();
  5964.         
  5965.         $categories $em->getRepository(CategorieProduit::class)
  5966.                         ->findByBoutique($boutique);
  5967.         $user $this->getUser();
  5968.         $userBoutique $em->getRepository(UserBoutique::class)
  5969.                         ->findOneBy(
  5970.                             array(
  5971.                             'user' => $user->getId(),
  5972.                             'boutique' => $boutique->getId()
  5973.                             )
  5974.                         );
  5975.         return $this->render('admin/category_product.html.twig', [
  5976.            'categories' => $categories,
  5977.            'boutique' => $boutique,
  5978.            'userBoutique' => $userBoutique
  5979.         ]);
  5980.     }
  5981.     
  5982.     //Produit/Service
  5983.     /**
  5984.      * @Route("/{slug}/new-product-category", name="admin.new_product_category")
  5985.      * @return \Symfony\Component\HttpFoundation\Response
  5986.      */
  5987.     public function newProductCategoryAction(Request $requestBoutique $boutique)
  5988.     {
  5989.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  5990.            return $this->redirectToRoute('security_login');
  5991.         }      
  5992.         $em $this->getDoctrine()
  5993.                     ->getManager();
  5994.         
  5995.         $categorie = new CategorieProduit;
  5996.         $form $this->createForm(CategorieProduitType::class, $categorie);
  5997.         
  5998.         $ok_soumission '';
  5999.         $error '';
  6000.         $user $this->getUser();
  6001.         $userBoutique $em->getRepository(UserBoutique::class)
  6002.                         ->findOneBy(
  6003.                             array(
  6004.                             'user' => $user->getId(),
  6005.                             'boutique' => $boutique->getId()
  6006.                             )
  6007.                         );
  6008.         if($request->getMethod() == 'POST'){
  6009.             
  6010.                $form->handleRequest($request);
  6011.                if($form->isValid()){
  6012.                    $categorie->setBoutique($boutique);
  6013.                   $em->persist($categorie);
  6014.                   $em->flush();
  6015.         
  6016.                 $ok_soumission =" Votre message a été pris en compte";
  6017.                     
  6018.                 unset($categorie);
  6019.                 unset($form);
  6020.                 $categorie = new CategorieProduit;
  6021.                 
  6022.                 $form $this->createForm(CategorieProduitType::class, $categorie);
  6023.                     
  6024.                 } else {
  6025.                     $error =" Veillez corrigez vos erreurs";
  6026.                 }
  6027.         }
  6028.     
  6029.         return $this->render('admin/new_product_category.html.twig', [
  6030.            'boutique' => $boutique,
  6031.            'form' => $form->createView(),
  6032.            'userBoutique' => $userBoutique
  6033.         ]);
  6034.     }
  6035.     
  6036.     
  6037.     //Produit/Service
  6038.     /**
  6039.      * @Route("/{slug}/edit-product-category/{id}", name="admin.edit_product_category")
  6040.      * @return \Symfony\Component\HttpFoundation\Response
  6041.      */
  6042.     public function editProductCategoryAction(Request $request$slug$id)
  6043.     { 
  6044.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6045.            return $this->redirectToRoute('security_login');
  6046.         }
  6047.         $em $this->getDoctrine()
  6048.                     ->getManager();
  6049.         
  6050.         $user $this->getUser();
  6051.         
  6052.         $categorie $em->getRepository(CategorieProduit::class)
  6053.                         ->findOneById($id);
  6054.         $boutique $em->getRepository(Boutique::class)
  6055.                         ->findOneBySlug($slug);
  6056.         $userBoutique $em->getRepository(UserBoutique::class)
  6057.                         ->findOneBy(
  6058.                             array(
  6059.                             'user' => $user->getId(),
  6060.                             'boutique' => $boutique->getId()
  6061.                             )
  6062.                         );
  6063.         $form $this->createForm(CategorieProduitEditType::class, $categorie);
  6064.         
  6065.         $ok_soumission '';
  6066.         $error '';
  6067.         
  6068.         if($request->getMethod() == 'POST'){
  6069.             
  6070.                $form->handleRequest($request);
  6071.                if($form->isValid()){
  6072.                   $em->flush();
  6073.         
  6074.                 $ok_soumission =" Votre message a été pris en compte";    
  6075.                 } else {
  6076.                     $error =" Veillez corrigez vos erreurs";
  6077.                 }
  6078.         }
  6079.     
  6080.         return $this->render('admin/edit_product_category.html.twig', [
  6081.            'boutique' => $boutique,
  6082.            'categorie' => $categorie,
  6083.            'form' => $form->createView(),
  6084.            'userBoutique' => $userBoutique
  6085.         ]);
  6086.     }
  6087.     
  6088.     //Produit/Service
  6089.     /**
  6090.      * @Route("/{slug}/delete-product-category/{id}", name="admin.delete_product_category")
  6091.      * @return \Symfony\Component\HttpFoundation\Response
  6092.      */
  6093.     public function deleteProductCategoryAction(Request $request,  $slug$id)
  6094.     { 
  6095.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6096.            return $this->redirectToRoute('security_login');
  6097.         }
  6098.         $em $this->getDoctrine()
  6099.                     ->getManager();
  6100.         $boutique $em->getRepository(Boutique::class)
  6101.                         ->findOneBySlug($slug);
  6102.                         
  6103.         $categorie $em->getRepository(CategorieProduit::class)
  6104.                         ->findOneBy(
  6105.                         array(
  6106.                             'boutique' => $boutique->getId(),
  6107.                             'id' => $id
  6108.                         )
  6109.                         );
  6110.         if(null !== $categorie){
  6111.             $em->remove($categorie);
  6112.             $em->flush();
  6113.         }
  6114.         return $this->redirectToRoute('admin.category_product', array('slug' => $boutique->getSlug()));
  6115.         
  6116.         
  6117.     }
  6118.     /**
  6119.      * @Route("/{slug}/tax/list", name="admin.list_tax")
  6120.      * @return \Symfony\Component\HttpFoundation\Response
  6121.      */
  6122.     public function listTaxAction(Request $requestBoutique $boutique)
  6123.     {    
  6124.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6125.            return $this->redirectToRoute('security_login');
  6126.         }
  6127.         $em $this->getDoctrine()
  6128.                     ->getManager();
  6129.         
  6130.         $taxes $em->getRepository(TVA::class)
  6131.                         ->findByBoutique($boutique);
  6132.         $user $this->getUser();
  6133.         $userBoutique $em->getRepository(UserBoutique::class)
  6134.                         ->findOneBy(
  6135.                             array(
  6136.                             'user' => $user->getId(),
  6137.                             'boutique' => $boutique->getId()
  6138.                             )
  6139.                         );
  6140.         return $this->render('admin/liste_tva.html.twig', [
  6141.            'boutique' => $boutique,
  6142.            'taxes' => $taxes,
  6143.            'userBoutique' => $userBoutique
  6144.         ]);
  6145.     }
  6146.     
  6147.     /**
  6148.      * @Route("/{slug}/new-tax", name="admin.new_tax")
  6149.      * @return \Symfony\Component\HttpFoundation\Response
  6150.      */
  6151.     public function newTaxAction(Request $requestBoutique $boutique)
  6152.     {
  6153.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6154.            return $this->redirectToRoute('security_login');
  6155.         }
  6156.         $em $this->getDoctrine()
  6157.                     ->getManager();
  6158.         
  6159.         $tva = new TVA;
  6160.         
  6161.         $user $this->getUser();
  6162.         $userBoutique $em->getRepository(UserBoutique::class)
  6163.                         ->findOneBy(
  6164.                             array(
  6165.                             'user' => $user->getId(),
  6166.                             'boutique' => $boutique->getId()
  6167.                             )
  6168.                         );
  6169.         $form $this->createForm(TVAType::class, $tva);
  6170.         
  6171.         $ok_soumission '';
  6172.         $error '';
  6173.         
  6174.         if($request->getMethod() == 'POST'){
  6175.             
  6176.                $form->handleRequest($request);
  6177.                if($form->isValid()){
  6178.                    $tva->setBoutique($boutique);
  6179.                   $em->persist($tva);
  6180.                   $em->flush();
  6181.         
  6182.                 $ok_soumission =" Votre message a été pris en compte";
  6183.                     
  6184.                 unset($tva);
  6185.                 unset($form);
  6186.                 $tva = new TVA;
  6187.                 
  6188.                 $form $this->createForm(TVAType::class, $tva);
  6189.                     
  6190.                 } else {
  6191.                     $error =" Veillez corrigez vos erreurs";
  6192.                 }
  6193.         }
  6194.     
  6195.         return $this->render('admin/nouvelle_tva.html.twig', [
  6196.            'boutique' => $boutique,
  6197.            'form' => $form->createView(),
  6198.            'userBoutique' => $userBoutique
  6199.         ]);
  6200.     }
  6201.     
  6202.     /**
  6203.      * @Route("/{slug}/edit-tax/{tva}", name="admin.edit_tax")
  6204.      * @return \Symfony\Component\HttpFoundation\Response
  6205.      */
  6206.     public function editTaxAction(Request $request$slug$tva)
  6207.     {
  6208.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6209.            return $this->redirectToRoute('security_login');
  6210.         }
  6211.         $em $this->getDoctrine()
  6212.                     ->getManager();
  6213.         
  6214.         $boutique $em->getRepository(Boutique::class)
  6215.                         ->findOneBySlug($slug);
  6216.                         
  6217.         $tva $em->getRepository(TVA::class)
  6218.                         ->findOneBy(
  6219.                         array(
  6220.                             'boutique' => $boutique->getId(),
  6221.                             'id' => $tva
  6222.                         )
  6223.                         );
  6224.         
  6225.         $user $this->getUser();
  6226.         $userBoutique $em->getRepository(UserBoutique::class)
  6227.                         ->findOneBy(
  6228.                             array(
  6229.                             'user' => $user->getId(),
  6230.                             'boutique' => $boutique->getId()
  6231.                             )
  6232.                         );
  6233.         $userBoutique $em->getRepository(UserBoutique::class)
  6234.                         ->findOneBy(
  6235.                             array(
  6236.                             'user' => $user->getId(),
  6237.                             'boutique' => $boutique->getId()
  6238.                             )
  6239.                         );
  6240.         $form $this->createForm(TVAEditType::class, $tva);
  6241.         
  6242.         $ok_soumission '';
  6243.         $error '';
  6244.         
  6245.         if($request->getMethod() == 'POST'){
  6246.             
  6247.                $form->handleRequest($request);
  6248.                if($form->isValid()){
  6249.                   $em->flush();
  6250.         
  6251.                 $ok_soumission =" Votre message a été pris en compte";
  6252.                     
  6253.                     
  6254.                 } else {
  6255.                     $error =" Veillez corrigez vos erreurs";
  6256.                 }
  6257.         }
  6258.     
  6259.         return $this->render('admin/edit_tax.html.twig', [
  6260.            'boutique' => $boutique,
  6261.            'tva' => $tva,
  6262.            'form' => $form->createView(),
  6263.            'userBoutique' => $userBoutique
  6264.         ]);
  6265.     }
  6266.     
  6267.     /**
  6268.      * @Route("/{slug}/delete-tax/{id}", name="admin.delete_tax")
  6269.      * @return \Symfony\Component\HttpFoundation\Response
  6270.      */
  6271.     public function deleteTaxAction(Request $request$slugTVA $tva)
  6272.     {
  6273.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6274.            return $this->redirectToRoute('security_login');
  6275.         }
  6276.         $em $this->getDoctrine()
  6277.                     ->getManager();
  6278.         $boutique $em->getRepository(Boutique::class)
  6279.                         ->findOneBySlug($slug);
  6280.         
  6281.         $tva $em->getRepository(TVA::class)
  6282.                         ->findOneBy(
  6283.                         array(
  6284.                             'boutique' => $boutique->getId(),
  6285.                             'id' => $tva
  6286.                         )
  6287.                         );
  6288.         if(null !== $tva){
  6289.             $em->remove($tva);
  6290.             $em->flush();
  6291.         }
  6292.         return $this->redirectToRoute('admin.list_tax', array('slug' => $boutique->getSlug()));
  6293.     }
  6294.     
  6295.     /**
  6296.      * @Route("/{slug}/payment-method/list", name="admin.payment_methods")
  6297.      * @return \Symfony\Component\HttpFoundation\Response
  6298.      */
  6299.     public function paymentMethodsAction(Request $requestBoutique $boutique)
  6300.     {
  6301.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6302.            return $this->redirectToRoute('security_login');
  6303.         }
  6304.         $em $this->getDoctrine()
  6305.                     ->getManager();
  6306.         
  6307.         $paymentMethods $em->getRepository(PaymentMethod::class)
  6308.                         ->findByBoutique($boutique);
  6309.         $user $this->getUser();
  6310.         $userBoutique $em->getRepository(UserBoutique::class)
  6311.                         ->findOneBy(
  6312.                             array(
  6313.                             'user' => $user->getId(),
  6314.                             'boutique' => $boutique->getId()
  6315.                             )
  6316.                         );
  6317.         return $this->render('admin/payment_methods.html.twig', [
  6318.            'boutique' => $boutique,
  6319.            'paymentMethods' => $paymentMethods,
  6320.            'userBoutique' => $userBoutique
  6321.         ]);
  6322.     }
  6323.     
  6324.     /**
  6325.      * @Route("/{slug}/payment-method/new", name="admin.new_payment_method")
  6326.      * @return \Symfony\Component\HttpFoundation\Response
  6327.      */
  6328.     public function newPaymentMethodAction(Request $requestBoutique $boutique)
  6329.     {
  6330.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6331.            return $this->redirectToRoute('security_login');
  6332.         }
  6333.         $em $this->getDoctrine()
  6334.                     ->getManager();
  6335.         
  6336.         $paymentMethod = new PaymentMethod;
  6337.         
  6338.         $user $this->getUser();
  6339.         $userBoutique $em->getRepository(UserBoutique::class)
  6340.                         ->findOneBy(
  6341.                             array(
  6342.                             'user' => $user->getId(),
  6343.                             'boutique' => $boutique->getId()
  6344.                             )
  6345.                         );
  6346.         $form $this->createForm(PaymentMethodType::class, $paymentMethod);
  6347.         
  6348.         $ok_soumission '';
  6349.         $error '';
  6350.         
  6351.         if($request->getMethod() == 'POST'){
  6352.             
  6353.                $form->handleRequest($request);
  6354.                if($form->isValid()){
  6355.                    $paymentMethod->setBoutique($boutique);
  6356.                   $em->persist($paymentMethod);
  6357.                   $em->flush();
  6358.         
  6359.                 $ok_soumission =" Votre message a été pris en compte";
  6360.                     
  6361.                 $paymentMethod = new PaymentMethod;
  6362.                 
  6363.                 $form $this->createForm(PaymentMethodType::class, $paymentMethod);
  6364.                     
  6365.                 } else {
  6366.                     $error =" Veillez corrigez vos erreurs";
  6367.                 }
  6368.         }
  6369.     
  6370.         return $this->render('admin/new_payment_method.html.twig', [
  6371.            'boutique' => $boutique,
  6372.            'form' => $form->createView(),
  6373.            'userBoutique' => $userBoutique
  6374.         ]);
  6375.     }
  6376.     
  6377.     /**
  6378.      * @Route("/{slug}/payment-method/edit/{paymentMethod}", name="admin.edit_payment_method")
  6379.      * @return \Symfony\Component\HttpFoundation\Response
  6380.      */
  6381.     public function editPaymentMethodAction(Request $request,  $slug$paymentMethod)
  6382.     {
  6383.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6384.            return $this->redirectToRoute('security_login');
  6385.         }
  6386.         $em $this->getDoctrine()
  6387.                     ->getManager();
  6388.         
  6389.         $boutique $em->getRepository(Boutique::class)
  6390.                     ->findOneBySlug($slug);
  6391.         $user $this->getUser();
  6392.         $userBoutique $em->getRepository(UserBoutique::class)
  6393.                         ->findOneBy(
  6394.                             array(
  6395.                             'user' => $user->getId(),
  6396.                             'boutique' => $boutique->getId()
  6397.                             )
  6398.                         );
  6399.         $paymentMethod $em->getRepository(PaymentMethod::class)
  6400.                     ->findOneBy(
  6401.                         array(
  6402.                             'boutique' => $boutique->getId(),
  6403.                             'id' => $paymentMethod
  6404.                         )
  6405.                     );
  6406.         
  6407.         $form $this->createForm(PaymentMethodEditType::class, $paymentMethod);
  6408.         
  6409.         $ok_soumission '';
  6410.         $error '';
  6411.         
  6412.         if($request->getMethod() == 'POST'){
  6413.             
  6414.                $form->handleRequest($request);
  6415.                if($form->isValid()){
  6416.                   $em->flush();
  6417.         
  6418.                 $ok_soumission =" Votre message a été pris en compte";
  6419.                     
  6420.                     
  6421.                 } else {
  6422.                     $error =" Veillez corrigez vos erreurs";
  6423.                 }
  6424.         }
  6425.     
  6426.         return $this->render('admin/edit_payment_method.html.twig', [
  6427.            'boutique' => $boutique,
  6428.            'paymentMethod' => $paymentMethod,
  6429.            'form' => $form->createView(),
  6430.            'userBoutique' => $userBoutique
  6431.         ]);
  6432.     }
  6433.     
  6434.     /**
  6435.      * @Route("/{slug}/payment-method/delete/{id}", name="admin.delete_payment_method")
  6436.      * @return \Symfony\Component\HttpFoundation\Response
  6437.      */
  6438.     public function deletePaymentMethodAction(Request $request$slug$id)
  6439.     {
  6440.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6441.            return $this->redirectToRoute('security_login');
  6442.         }
  6443.         $em $this->getDoctrine()
  6444.                     ->getManager();
  6445.         $boutique $em->getRepository(Boutique::class)
  6446.                         ->findOneBySlug($slug);
  6447.                         
  6448.         $paymentMethod $em->getRepository(PaymentMethod::class)
  6449.                         ->findOneBy(
  6450.                         array(
  6451.                             'boutique' => $boutique->getId(),
  6452.                             'id' => $id
  6453.                         )
  6454.                         );
  6455.         if(null !== $paymentMethod){
  6456.             $em->remove($paymentMethod);
  6457.             $em->flush();
  6458.         }
  6459.         return $this->redirectToRoute('admin.payment_methods', array('slug' => $boutique->getSlug()));
  6460.     }
  6461.     
  6462.     /**
  6463.      * @Route("/{slug}/expensives/list", name="admin.expensives")
  6464.      * @return \Symfony\Component\HttpFoundation\Response
  6465.      */
  6466.     public function expensivesAction(Request $requestBoutique $boutique)
  6467.     {
  6468.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6469.            return $this->redirectToRoute('security_login');
  6470.         }
  6471.         $em $this->getDoctrine()
  6472.                     ->getManager();
  6473.         
  6474.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  6475.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  6476.         $dateDebut->setTime(00);
  6477.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  6478.         $dateFin->setTime(2359);
  6479.         
  6480.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  6481.         $startMonth $intervalleMois['debut'];
  6482.         $endMonth $intervalleMois['fin'];
  6483.         
  6484.         $expensives  $em->getRepository(Expensive::class)
  6485.                         ->depenseParDate($boutique->getId(), $dateDebut$dateFin);
  6486.         
  6487.         $startYear date('Y-01-01');
  6488.         $endYear date('Y-12-31');
  6489.         $user $this->getUser();
  6490.         $userBoutique $em->getRepository(UserBoutique::class)
  6491.                         ->findOneBy(
  6492.                             array(
  6493.                             'user' => $user->getId(),
  6494.                             'boutique' => $boutique->getId()
  6495.                             )
  6496.                         );
  6497.         if('POST' == $request->getMethod()){
  6498.             $dateDebut $_POST['dateDebut'];
  6499.             $dateFin $_POST['dateFin'];
  6500.             
  6501.             $dateDebut = new \DateTime($dateDebut);
  6502.             $dateFin = new \DateTime($dateFin);
  6503.             
  6504.             $expensives $em->getRepository(Expensive::class)
  6505.                         ->depenseParDate($boutique->getId(), $dateDebut$dateFin);
  6506.             
  6507.             
  6508.             return $this->render('admin/expensives_table_content.html.twig', [
  6509.                'boutique' => $boutique,
  6510.                'expensives' => $expensives,
  6511.                'userBoutique' => $userBoutique
  6512.             ]);
  6513.         }
  6514.         
  6515.             
  6516.         return $this->render('admin/expensives.html.twig', [
  6517.            'boutique' => $boutique,
  6518.            'expensives' => $expensives,
  6519.            'userBoutique' => $userBoutique,
  6520.            'intervalleDeDate' => $intervalleDeDate,
  6521.            'dateDebut' => $dateDebut,
  6522.            'dateFin' => $dateFin,
  6523.            'startMonth' => $startMonth,
  6524.            'intervalleMois' => $intervalleMois,
  6525.            'endMonth' => $endMonth,
  6526.            'startYear' => $startYear,
  6527.            'endYear' => $endYear
  6528.            
  6529.         ]);
  6530.     }
  6531.     
  6532.     /**
  6533.      * @Route("/{slug}/expensives/new", name="admin.new_expensive")
  6534.      * @return \Symfony\Component\HttpFoundation\Response
  6535.      */
  6536.     public function newExpensiveAction(Request $requestBoutique $boutique)
  6537.     {
  6538.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6539.            return $this->redirectToRoute('security_login');
  6540.         }
  6541.         $em $this->getDoctrine()
  6542.                     ->getManager();
  6543.         
  6544.         $expensive = new Expensive;
  6545.         
  6546.         $user $this->getUser();
  6547.         $userBoutique $em->getRepository(UserBoutique::class)
  6548.                         ->findOneBy(
  6549.                             array(
  6550.                             'user' => $user->getId(),
  6551.                             'boutique' => $boutique->getId()
  6552.                             )
  6553.                         );
  6554.         $form $this->createForm(ExpensiveType::class, $expensive, array('boutique' => $boutique->getId()));
  6555.         
  6556.         $ok_soumission '';
  6557.         $error '';
  6558.         $laDate '';
  6559.         if($request->getMethod() == 'POST'){
  6560.             
  6561.                $form->handleRequest($request);
  6562.                if($form->isValid()){
  6563.                 $data $form->getData();
  6564.                    $expensive->setBoutique($boutique);
  6565.                    $expensive->setCreePar($user);
  6566.                   $em->persist($expensive);
  6567.                   $em->flush();
  6568.         
  6569.                 $ok_soumission =" Votre message a été pris en compte";
  6570.                     
  6571.                 $moyenDePaiement $request->request->get('moyenDePaiement');
  6572.                 $expensive->setMoyenDePaiement($moyenDePaiement);
  6573.                 if($boutique->getSettings()->isGenererAutomatiquementEcrituresComptabilite()){
  6574.                 $libelle 'Règlement fournisseur';
  6575.                 if($expensive->getTiers() != null){
  6576.                     $libelle $libelle' '$expensive->getTiers()->getNom();
  6577.                 }
  6578.                 $groupeEcritureComptable = new GroupeEcritureComptable;
  6579.                 $groupeEcritureComptable->setBoutique($boutique);
  6580.                 $groupeEcritureComptable->setLibelleEcriture($libelle);
  6581.                 $groupeEcritureComptable->setDebit($data->getMontant());
  6582.                 $groupeEcritureComptable->setCredit($data->getMontant());
  6583.                 $groupeEcritureComptable->setLaDate($data->getLaDate());
  6584.                 $groupeEcritureComptable->setNumeroPiece($data->getPiece());
  6585.                 $groupeEcritureComptable->setAnnee($data->getLaDate()->format('Y'));
  6586.                 $groupeEcritureComptable->setMois($data->getLaDate()->format('m'));
  6587.                 $em->persist($groupeEcritureComptable);
  6588.                 $em->flush();
  6589.                     
  6590.                 //Ecriture comptable
  6591.                 
  6592.                 //$ecritureComptable->setLeJournal($boutique->getSettings()->getJournalDeVente());
  6593.                 if($moyenDePaiement == 'cash' || $moyenDePaiement == 'mobile-money'){
  6594.                     //Debit
  6595.                     
  6596.                     
  6597.                     $groupeEcritureComptable->setLeJournal($boutique->getSettings()->getJournalDeCaisse());
  6598.                     $ecritureComptable = new EcritureComptable;
  6599.                     
  6600.                     $ecritureComptable->setBoutique($boutique);
  6601.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  6602.                     
  6603.                     $ecritureComptable->setLeJournal($boutique->getSettings()->getJournalDeCaisse());
  6604.                     $compte $em->getRepository(Compte::class)
  6605.                                 ->findOneBy(
  6606.                                     array(
  6607.                                         'boutique' => $boutique,
  6608.                                         'numero' => '5711' //Caisse
  6609.                                     )    
  6610.                                 ); 
  6611.                     $compte->setSolde($compte->getSolde() - $data->getMontant());
  6612.                     $ecritureComptable->setCompte($compte);
  6613.                     $ecritureComptable->setLibelleEcriture($libelle);
  6614.                     $ecritureComptable->setCredit($data->getMontant());
  6615.                     $ecritureComptable->setSolde($compte->getSolde());
  6616.                     $ecritureComptable->setLaDate($data->getLaDate());
  6617.                     $ecritureComptable->setNumeroPiece($data->getPiece());
  6618.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  6619.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  6620.                     $em->persist($ecritureComptable);
  6621.                     //Debit
  6622.                     $ecritureComptable = new EcritureComptable;
  6623.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  6624.                     $ecritureComptable->setBoutique($boutique);
  6625.                     
  6626.                     $ecritureComptable->setLeJournal($boutique->getSettings()->getJournalDeCaisse());
  6627.                     $compte $em->getRepository(Compte::class)
  6628.                                 ->findOneBy(
  6629.                                     array(
  6630.                                         'boutique' => $boutique,
  6631.                                         'numero' => '658'
  6632.                                     )    
  6633.                                 ); //Charge divers
  6634.                     $compte->setSolde($compte->getSolde() + $data->getMontant());
  6635.                     $ecritureComptable->setCompte($compte);
  6636.                     $ecritureComptable->setLibelleEcriture($libelle);
  6637.                     $ecritureComptable->setDebit($data->getMontant());
  6638.                     $ecritureComptable->setSolde($compte->getSolde());
  6639.                     $ecritureComptable->setLaDate($data->getLaDate());
  6640.                     $ecritureComptable->setNumeroPiece($data->getPiece());
  6641.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  6642.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  6643.                     $em->persist($ecritureComptable);
  6644.                 }else{
  6645.                     $leJournal $boutique->getSettings()->getJournalDeBanque();
  6646.                     
  6647.                     $groupeEcritureComptable->setLeJournal($leJournal);
  6648.                     $ecritureComptable = new EcritureComptable;
  6649.                     
  6650.                     $ecritureComptable->setBoutique($boutique);
  6651.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  6652.                     
  6653.                     $ecritureComptable->setLeJournal($leJournal);
  6654.                     $compte $em->getRepository(Compte::class)
  6655.                                 ->findOneBy(
  6656.                                     array(
  6657.                                         'boutique' => $boutique,
  6658.                                         'numero' => '521'
  6659.                                     )    
  6660.                                 ); //Banque
  6661.                     $compte->setSolde($compte->getSolde() - $data->getMontant());
  6662.                     $ecritureComptable->setCompte($compte);
  6663.                     $ecritureComptable->setLibelleEcriture($libelle);
  6664.                     $ecritureComptable->setCredit($data->getMontant());
  6665.                     $ecritureComptable->setSolde($compte->getSolde());
  6666.                     $ecritureComptable->setLaDate($data->getLaDate());
  6667.                     $ecritureComptable->setNumeroPiece($data->getPiece());
  6668.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  6669.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  6670.                     $em->persist($ecritureComptable);
  6671.                     //Debit
  6672.                     $ecritureComptable = new EcritureComptable;
  6673.                     $ecritureComptable->setGroupeEcritureComptable($groupeEcritureComptable);
  6674.                     $ecritureComptable->setBoutique($boutique);
  6675.                     
  6676.                     $ecritureComptable->setLeJournal($leJournal);
  6677.                     $compte $em->getRepository(Compte::class)
  6678.                                 ->findOneBy(
  6679.                                     array(
  6680.                                         'boutique' => $boutique,
  6681.                                         'numero' => '658'
  6682.                                     )    
  6683.                                 ); //Charge divers
  6684.                     $compte->setSolde($compte->getSolde() + $data->getMontant());
  6685.                     $ecritureComptable->setCompte($compte);
  6686.                     $ecritureComptable->setLibelleEcriture($libelle);
  6687.                     $ecritureComptable->setDebit($data->getMontant());
  6688.                     $ecritureComptable->setSolde($compte->getSolde());
  6689.                     $ecritureComptable->setLaDate($data->getLaDate());
  6690.                     $ecritureComptable->setNumeroPiece($data->getPiece());
  6691.                     $ecritureComptable->setAnnee($ecritureComptable->getLaDate()->format('Y'));
  6692.                     $ecritureComptable->setMois($ecritureComptable->getLaDate()->format('m'));
  6693.                     $em->persist($ecritureComptable);
  6694.                 }
  6695.                 }
  6696.                 $em->flush();
  6697.                 $expensive = new Expensive;
  6698.                 
  6699.                 $form $this->createForm(ExpensiveType::class, $expensive);
  6700.                     
  6701.                 } else {
  6702.                     $error =" Veillez corrigez vos erreurs";
  6703.                 }
  6704.         }
  6705.     
  6706.         return $this->render('admin/new_expensive.html.twig', [
  6707.            'boutique' => $boutique,
  6708.            'form' => $form->createView(),
  6709.            'userBoutique' => $userBoutique
  6710.         ]);
  6711.     }
  6712.     
  6713.     /**
  6714.      * @Route("/{slug}/expensive/edit/{id}", name="admin.edit_expensive")
  6715.      * @return \Symfony\Component\HttpFoundation\Response
  6716.      */
  6717.     public function editExpensivesAction(Request $request,  $slug$id)
  6718.     {
  6719.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6720.            return $this->redirectToRoute('security_login');
  6721.         }
  6722.         $em $this->getDoctrine()
  6723.                     ->getManager();
  6724.         
  6725.         $boutique $em->getRepository(Boutique::class)
  6726.                     ->findOneBySlug($slug);
  6727.         $user $this->getUser();
  6728.         $userBoutique $em->getRepository(UserBoutique::class)
  6729.                         ->findOneBy(
  6730.                             array(
  6731.                             'user' => $user->getId(),
  6732.                             'boutique' => $boutique->getId()
  6733.                             )
  6734.                         );
  6735.         $expensive $em->getRepository(Expensive::class)
  6736.                     ->findOneBy(
  6737.                         array(
  6738.                             'boutique' => $boutique->getId(),
  6739.                             'id' => $id
  6740.                         )
  6741.                     );
  6742.         
  6743.         $form $this->createForm(ExpensiveEditType::class, $expensive, array('boutique' => $boutique->getId()));
  6744.         
  6745.         $ok_soumission '';
  6746.         $error '';
  6747.         
  6748.         if($request->getMethod() == 'POST'){
  6749.             
  6750.                $form->handleRequest($request);
  6751.                if($form->isValid()){
  6752.                 $expensive->setModifiePar($user);
  6753.                   $em->flush();
  6754.         
  6755.                 $ok_soumission =" Votre message a été pris en compte";
  6756.                     
  6757.                     
  6758.                 } else {
  6759.                     $error =" Veillez corrigez vos erreurs";
  6760.                 }
  6761.         }
  6762.     
  6763.         return $this->render('admin/edit_expensive.html.twig', [
  6764.            'boutique' => $boutique,
  6765.            'expensive' => $expensive,
  6766.            'form' => $form->createView(),
  6767.            'userBoutique' => $userBoutique
  6768.         ]);
  6769.     }
  6770.     
  6771.     /**
  6772.      * @Route("/{slug}/expensive/delete/{id}", name="admin.delete_expensive")
  6773.      * @return \Symfony\Component\HttpFoundation\Response
  6774.      */
  6775.     public function deleteExpensiveAction(Request $request$slug$id)
  6776.     {
  6777.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6778.            return $this->redirectToRoute('security_login');
  6779.         }
  6780.         $em $this->getDoctrine()
  6781.                     ->getManager();
  6782.         $boutique $em->getRepository(Boutique::class)
  6783.                         ->findOneBySlug($slug);
  6784.         $user $this->getUser();
  6785.                         
  6786.         $expensive $em->getRepository(Expensive::class)
  6787.                         ->findOneBy(
  6788.                         array(
  6789.                             'boutique' => $boutique->getId(),
  6790.                             'id' => $id
  6791.                         )
  6792.                         );
  6793.         if(null !== $expensive){
  6794.             $expensive->setEstSupprime(true);
  6795.             $expensive->setSupprimePar($user);
  6796.             //$em->remove($expensive);
  6797.             $em->flush();
  6798.         }
  6799.         return $this->redirectToRoute('admin.expensives', array('slug' => $boutique->getSlug()));
  6800.     }
  6801.     /**
  6802.      * @Route("/{slug}/categorie-depense/list", name="admin_categorie_depenses")
  6803.      * @return \Symfony\Component\HttpFoundation\Response
  6804.      */
  6805.     public function categorieDepenseAction(Request $requestBoutique $boutique)
  6806.     {
  6807.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6808.            return $this->redirectToRoute('security_login');
  6809.         }
  6810.         $em $this->getDoctrine()
  6811.                     ->getManager();
  6812.         
  6813.         $categorieDepenses  $em->getRepository(CategorieDepense::class)
  6814.                         ->findBy(
  6815.                             array(
  6816.                                 'boutique' => $boutique->getId()
  6817.                             )    
  6818.                         );
  6819.         
  6820.         $user $this->getUser();
  6821.         $userBoutique $em->getRepository(UserBoutique::class)
  6822.                         ->findOneBy(
  6823.                             array(
  6824.                             'user' => $user->getId(),
  6825.                             'boutique' => $boutique->getId()
  6826.                             )
  6827.                         );
  6828.         
  6829.         
  6830.             
  6831.         return $this->render('admin/categorie_depenses.html.twig', [
  6832.            'boutique' => $boutique,
  6833.            'userBoutique' => $userBoutique,
  6834.            'categorieDepenses' => $categorieDepenses
  6835.            
  6836.         ]);
  6837.     }
  6838.     
  6839.     /**
  6840.      * @Route("/{slug}/categorie-depense/nouveau", name="admin_nouvelle_categorie_dedepense")
  6841.      * @return \Symfony\Component\HttpFoundation\Response
  6842.      */
  6843.     public function nouvelleCategorieDepenseAction(Request $requestBoutique $boutique)
  6844.     {
  6845.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6846.            return $this->redirectToRoute('security_login');
  6847.         }
  6848.         $em $this->getDoctrine()
  6849.                     ->getManager();
  6850.         
  6851.         $categorieDepense = new CategorieDepense;
  6852.         
  6853.         $user $this->getUser();
  6854.         $userBoutique $em->getRepository(UserBoutique::class)
  6855.                         ->findOneBy(
  6856.                             array(
  6857.                             'user' => $user->getId(),
  6858.                             'boutique' => $boutique->getId()
  6859.                             )
  6860.                         );
  6861.         $form $this->createForm(CategorieDepenseType::class, $categorieDepense);
  6862.         
  6863.         $ok_soumission '';
  6864.         
  6865.         if($request->getMethod() == 'POST'){
  6866.             
  6867.                $form->handleRequest($request);
  6868.                if($form->isValid()){
  6869.                 $categorieDepense->setBoutique($boutique);
  6870.                   $em->persist($categorieDepense);
  6871.                   $em->flush();
  6872.         
  6873.                 $ok_soumission =" Votre message a été pris en compte";
  6874.                     
  6875.                 $categorieDepense = new CategorieDepense;
  6876.                 
  6877.                 $form $this->createForm(CategorieDepenseType::class, $categorieDepense);
  6878.                     
  6879.                 } else {
  6880.                     $error =" Veillez corrigez vos erreurs";
  6881.                 }
  6882.         }
  6883.     
  6884.         return $this->render('admin/nouvelle_categorie_depense.html.twig', [
  6885.            'boutique' => $boutique,
  6886.            'form' => $form->createView(),
  6887.            'userBoutique' => $userBoutique
  6888.         ]);
  6889.     }
  6890.     
  6891.     /**
  6892.      * @Route("/{slug}/categorie-depense/modifier/{id}", name="admin_modifier_categorie_depense")
  6893.      * @return \Symfony\Component\HttpFoundation\Response
  6894.      */
  6895.     public function modifierCategorieDepenseAction(Request $request,  $slug$id)
  6896.     {
  6897.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6898.            return $this->redirectToRoute('security_login');
  6899.         }
  6900.         $em $this->getDoctrine()
  6901.                     ->getManager();
  6902.         
  6903.         $boutique $em->getRepository(Boutique::class)
  6904.                     ->findOneBySlug($slug);
  6905.         $user $this->getUser();
  6906.         $userBoutique $em->getRepository(UserBoutique::class)
  6907.                         ->findOneBy(
  6908.                             array(
  6909.                             'user' => $user->getId(),
  6910.                             'boutique' => $boutique->getId()
  6911.                             )
  6912.                         );
  6913.         $categorieDepense $em->getRepository(CategorieDepense::class)
  6914.                     ->findOneBy(
  6915.                         array(
  6916.                             'boutique' => $boutique->getId(),
  6917.                             'id' => $id
  6918.                         )
  6919.                     );
  6920.         
  6921.         $form $this->createForm(CategorieDepenseEditType::class, $categorieDepense);
  6922.         
  6923.         $ok_soumission '';
  6924.         $error '';
  6925.         
  6926.         if($request->getMethod() == 'POST'){
  6927.             
  6928.                $form->handleRequest($request);
  6929.                if($form->isValid()){
  6930.                 
  6931.                   $em->flush();
  6932.         
  6933.                 $ok_soumission =" Votre message a été pris en compte";
  6934.                     
  6935.                     
  6936.                 } else {
  6937.                     $error =" Veillez corrigez vos erreurs";
  6938.                 }
  6939.         }
  6940.     
  6941.         return $this->render('admin/modifier_categorie_depense.html.twig', [
  6942.            'boutique' => $boutique,
  6943.            'categorieDepense' => $categorieDepense,
  6944.            'form' => $form->createView(),
  6945.            'userBoutique' => $userBoutique
  6946.         ]);
  6947.     }
  6948.     
  6949.     /**
  6950.      * @Route("/{slug}/categorie-depense/supprimer/{id}", name="admin_supprimer_categorie_depense")
  6951.      * @return \Symfony\Component\HttpFoundation\Response
  6952.      */
  6953.     public function supprimerCategorieDepenseAction(Request $request$slug$id)
  6954.     {
  6955.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6956.            return $this->redirectToRoute('security_login');
  6957.         }
  6958.         $em $this->getDoctrine()
  6959.                     ->getManager();
  6960.         $boutique $em->getRepository(Boutique::class)
  6961.                         ->findOneBySlug($slug);
  6962.         $user $this->getUser();
  6963.                         
  6964.         $categorieDepense $em->getRepository(CategorieDepense::class)
  6965.                         ->findOneBy(
  6966.                         array(
  6967.                             'boutique' => $boutique->getId(),
  6968.                             'id' => $id
  6969.                         )
  6970.                         );
  6971.         if(null !== $categorieDepense){
  6972.             
  6973.             $em->remove($categorieDepense);
  6974.             $em->flush();
  6975.         }
  6976.         return $this->redirectToRoute('admin_categorie_depenses', array('slug' => $boutique->getSlug()));
  6977.     }
  6978.     
  6979.     
  6980.     /**
  6981.      * @Route("/{slug}/third/list", name="admin.liste_tiers")
  6982.      * @return \Symfony\Component\HttpFoundation\Response
  6983.      */
  6984.     public function listeTiersAction(Request $requestBoutique $boutique)
  6985.     {
  6986.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  6987.            return $this->redirectToRoute('security_login');
  6988.         }
  6989.         $em $this->getDoctrine()
  6990.                     ->getManager();
  6991.         
  6992.         $tiers $em->getRepository(Tiers::class)
  6993.                     ->findBy(
  6994.                         array(
  6995.                             'boutique' => $boutique->getId(),
  6996.                             'estSupprime' => false
  6997.                             
  6998.                         ),
  6999.                         array(
  7000.                             'nom' => 'ASC'
  7001.                         )
  7002.                         );
  7003.         $user $this->getUser();
  7004.         $userBoutique $em->getRepository(UserBoutique::class)
  7005.                         ->findOneBy(
  7006.                             array(
  7007.                             'user' => $user->getId(),
  7008.                             'boutique' => $boutique->getId()
  7009.                             )
  7010.                         );
  7011.         return $this->render('admin/liste_tiers.html.twig', [
  7012.            'boutique' => $boutique,
  7013.            'tiers' => $tiers,
  7014.            'userBoutique' => $userBoutique
  7015.         ]);
  7016.     }
  7017.     
  7018.     //Service
  7019.     
  7020.     /**
  7021.      * @Route("/{slug}/new-third", name="admin.new_third")
  7022.      * @return \Symfony\Component\HttpFoundation\Response
  7023.      */
  7024.     public function newThirdAction(Request $requestBoutique $boutique)
  7025.     {
  7026.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7027.            return $this->redirectToRoute('security_login');
  7028.         }
  7029.         $em $this->getDoctrine()
  7030.                     ->getManager();
  7031.         
  7032.         $tiers = new Tiers;
  7033.         $form $this->createForm(TiersType::class, $tiers);
  7034.         
  7035.         $user $this->getUser();
  7036.         $userBoutique $em->getRepository(UserBoutique::class)
  7037.                         ->findOneBy(
  7038.                             array(
  7039.                             'user' => $user->getId(),
  7040.                             'boutique' => $boutique->getId()
  7041.                             )
  7042.                         );
  7043.         
  7044.         $ok_soumission '';
  7045.         $error '';
  7046.         
  7047.         if($request->getMethod() == 'POST'){
  7048.             
  7049.                $form->handleRequest($request);
  7050.                if($form->isValid()){
  7051.                    $tiers->setBoutique($boutique);
  7052.                    $tiers->setCreePar($user);
  7053.                   $em->persist($tiers);
  7054.                   $em->flush();
  7055.         
  7056.                 $ok_soumission =" Votre message a été pris en compte";
  7057.                 $tiers = new Tiers;
  7058.                 
  7059.                 $form $this->createForm(TiersType::class, $tiers);
  7060.                     
  7061.                 } else {
  7062.                     $error =" Veillez corrigez vos erreurs";
  7063.                 }
  7064.         }
  7065.         return $this->render('admin/nouveau_tiers.html.twig', [
  7066.            'boutique' => $boutique,
  7067.            'form' => $form->createView(),
  7068.            'userBoutique' => $userBoutique
  7069.         ]);
  7070.     }
  7071.     /**
  7072.      * @Route("/{slug}/edit-third/{third}", name="admin.edit_third")
  7073.      * @return \Symfony\Component\HttpFoundation\Response
  7074.      */
  7075.     public function editThirdAction(Request $requestBoutique $boutique$third)
  7076.     {
  7077.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7078.            return $this->redirectToRoute('security_login');
  7079.         }
  7080.         $em $this->getDoctrine()
  7081.                     ->getManager();
  7082.                     
  7083.         $user $this->getUser();
  7084.         $userBoutique $em->getRepository(UserBoutique::class)
  7085.                         ->findOneBy(
  7086.                             array(
  7087.                             'user' => $user->getId(),
  7088.                             'boutique' => $boutique->getId()
  7089.                             )
  7090.                         );
  7091.         $third $em->getRepository(Tiers::class)
  7092.                     ->findOneById($third);
  7093.         $form $this->createForm(TiersEditType::class, $third);
  7094.         
  7095.         $ok_soumission '';
  7096.         $error '';
  7097.         
  7098.         if($request->getMethod() == 'POST'){
  7099.             
  7100.                $form->handleRequest($request);
  7101.                if($form->isValid()){
  7102.                     $third->setModifiePar($user);
  7103.                   $em->flush();
  7104.         
  7105.                 $ok_soumission =" Votre message a été pris en compte";
  7106.                     
  7107.                 } else {
  7108.                     $error =" Veillez corrigez vos erreurs";
  7109.                 }
  7110.         }
  7111.         return $this->render('admin/edit_third.html.twig', [
  7112.            'boutique' => $boutique,
  7113.            'form' => $form->createView(),
  7114.            'third' => $third,
  7115.            'userBoutique' => $userBoutique
  7116.         ]);
  7117.     }
  7118.     /**
  7119.      * @Route("/{slug}/delete-third/{third}", name="admin.delete_third")
  7120.      * @return \Symfony\Component\HttpFoundation\Response
  7121.      */
  7122.     public function deleteThirdAction(Request $requestBoutique $boutique$third)
  7123.     {
  7124.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7125.            return $this->redirectToRoute('security_login');
  7126.         }
  7127.         $em $this->getDoctrine()
  7128.                     ->getManager();
  7129.         $user $this->getUser();
  7130.         $third $em->getRepository(Tiers::class)
  7131.                     ->findOneById($third);
  7132.                     
  7133.         if(null != $third){
  7134.             $third->setEstSupprime(true);
  7135.             $third->setSupprimePar($user);
  7136.             $em->flush();
  7137.         }
  7138.         
  7139.         return $this->redirectToRoute('admin.liste_tiers', array('slug' => $boutique->getSlug()));
  7140.     }
  7141.     /**
  7142.      * @Route("/{slug}/statistics", name="admin.statistics")
  7143.      * @return \Symfony\Component\HttpFoundation\Response
  7144.      */
  7145.     public function statisticsAction(Request $requestBoutique $boutique)
  7146.     {
  7147.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7148.            return $this->redirectToRoute('security_login');
  7149.         }
  7150.         $em $this->getDoctrine()
  7151.                     ->getManager();
  7152.         
  7153.         $tiers $em->getRepository(Tiers::class)
  7154.                     ->findByBoutique($boutique);
  7155.         $user $this->getUser();
  7156.         $userBoutique $em->getRepository(UserBoutique::class)
  7157.                         ->findOneBy(
  7158.                             array(
  7159.                             'user' => $user->getId(),
  7160.                             'boutique' => $boutique->getId()
  7161.                             )
  7162.                         );
  7163.                         
  7164.         return $this->render('admin/statistics.html.twig', [
  7165.            'boutique' => $boutique,
  7166.            'tiers' => $tiers,
  7167.            'userBoutique' => $userBoutique
  7168.         ]);
  7169.     }
  7170.     
  7171.     /**
  7172.      * @Route("/{slug}/promotions", name="admin.promotions")
  7173.      * @return \Symfony\Component\HttpFoundation\Response
  7174.      */
  7175.     public function promotionsAction(Request $requestBoutique $boutique)
  7176.     {
  7177.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7178.            return $this->redirectToRoute('security_login');
  7179.         }
  7180.         $em $this->getDoctrine()
  7181.                     ->getManager();
  7182.         
  7183.         $tiers $em->getRepository(Tiers::class)
  7184.                     ->findByBoutique($boutique);
  7185.         $user $this->getUser();
  7186.         $userBoutique $em->getRepository(UserBoutique::class)
  7187.                         ->findOneBy(
  7188.                             array(
  7189.                             'user' => $user->getId(),
  7190.                             'boutique' => $boutique->getId()
  7191.                             )
  7192.                         );
  7193.         return $this->render('admin/liste_tiers.html.twig', [
  7194.            'boutique' => $boutique,
  7195.            'tiers' => $tiers,
  7196.            'userBoutique' => $userBoutique
  7197.         ]);
  7198.     }
  7199.     
  7200.     /**
  7201.      * @Route("/{slug}/new-payment-patern", name="admin.new_payment_patern")
  7202.      * @return \Symfony\Component\HttpFoundation\Response
  7203.      */
  7204.     public function newPayementPaternMethodAction(Request $requestBoutique $boutique)
  7205.     {
  7206.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7207.            return $this->redirectToRoute('security_login');
  7208.         }
  7209.         $em $this->getDoctrine()
  7210.                     ->getManager();
  7211.         
  7212.         $modeleReglement = new ModeleReglement;
  7213.         $form $this->createForm(ModeleReglementType::class, $modeleReglement);
  7214.         
  7215.         $ok_soumission '';
  7216.         $error '';
  7217.         $user $this->getUser();
  7218.         $userBoutique $em->getRepository(UserBoutique::class)
  7219.                         ->findOneBy(
  7220.                             array(
  7221.                             'user' => $user->getId(),
  7222.                             'boutique' => $boutique->getId()
  7223.                             )
  7224.                         );
  7225.         if($request->getMethod() == 'POST'){
  7226.             
  7227.                $form->handleRequest($request);
  7228.                if($form->isValid()){
  7229.                    $modeleReglement->setBoutique($boutique);
  7230.                   $em->persist($modeleReglement);
  7231.                   $em->flush();
  7232.         
  7233.                 $ok_soumission =" Votre message a été pris en compte";
  7234.                     
  7235.                 unset($modeleReglement);
  7236.                 unset($form);
  7237.                 $modeleReglement = new ModeleReglement;
  7238.                 
  7239.                 $form $this->createForm(ModeleReglementType::class, $modeleReglement);
  7240.                     
  7241.                 } else {
  7242.                     $error =" Veillez corrigez vos erreurs";
  7243.                 }
  7244.         }
  7245.         return $this->render('admin/nouveau_modele_reglement.html.twig', [
  7246.            'boutique' => $boutique
  7247.            'form' => $form->createView(),
  7248.            'userBoutique' => $userBoutique
  7249.         ]);
  7250.     }
  7251.     
  7252.     /**
  7253.      * @Route("/{slug}/payment-patern/list", name="admin.list_payment_patern")
  7254.      * @return \Symfony\Component\HttpFoundation\Response
  7255.      */
  7256.     public function listeModeleReglementAction(Request $requestBoutique $boutique)
  7257.     {
  7258.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7259.            return $this->redirectToRoute('security_login');
  7260.         }
  7261.         $em $this->getDoctrine()
  7262.                     ->getManager();
  7263.         
  7264.         $modeleReglements $em->getRepository(ModeleReglement::class)
  7265.                     ->findByBoutique($boutique);
  7266.         $user $this->getUser();
  7267.         $userBoutique $em->getRepository(UserBoutique::class)
  7268.                         ->findOneBy(
  7269.                             array(
  7270.                             'user' => $user->getId(),
  7271.                             'boutique' => $boutique->getId()
  7272.                             )
  7273.                         );
  7274.                         
  7275.         return $this->render('admin/liste_modele_reglement.html.twig', [
  7276.            'boutique' => $boutique,
  7277.            'modeleReglements' => $modeleReglements,
  7278.            'userBoutique' => $userBoutique
  7279.         ]);
  7280.     }
  7281.     
  7282.     /**
  7283.      * @Route("/{slug}/send-document-mail/{id}", name="admin.send_document_mail")
  7284.      * @return \Symfony\Component\HttpFoundation\Response
  7285.      */
  7286.     public function sendDocumentMailAction(Request $request, \Swift_Mailer $mailer$slug$id)
  7287.     {
  7288.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7289.            return $this->redirectToRoute('security_login');
  7290.         }
  7291.         $em $this->getDoctrine()
  7292.                     ->getManager();
  7293.         $boutique $em->getRepository(Boutique::class)
  7294.                         ->findOneBySlug($slug);
  7295.         $user $this->getUser();
  7296.         $userBoutique $em->getRepository(UserBoutique::class)
  7297.                         ->findOneBy(
  7298.                             array(
  7299.                             'user' => $user->getId(),
  7300.                             'boutique' => $boutique->getId()
  7301.                             )
  7302.                         );        
  7303.         $commande $em->getRepository(Commande::class)
  7304.                     ->findOneBy(
  7305.                         array(
  7306.                         'boutique' => $boutique->getId(),
  7307.                         'id' => $id
  7308.                         )
  7309.                     );
  7310.         
  7311.         $appName $this->getParameter('app_name');
  7312.         if('POST'== $request->getMethod()){
  7313.             $from $_POST['from'];
  7314.             $to $_POST['to_mail'];
  7315.             $subject $_POST['subject'];
  7316.             $contenu $_POST['message'];
  7317.             $sendAttachment = (bool)$_POST['send_attachment'];
  7318.             
  7319.             $message = (new \Swift_Message($subject))
  7320.             ->setFrom([$from  => $appName])
  7321.             ->setTo([$to])
  7322.             ->setBody(
  7323.                 $this->renderView(
  7324.                 'admin/document_email.html.twig',
  7325.                 [
  7326.                 'message' => $contenu
  7327.                 ]
  7328.                 ),
  7329.             'text/html'
  7330.             );
  7331.             if($sendAttachment){
  7332.                 $message->attach(\Swift_Attachment::fromPath($commande->getLienPDF()));
  7333.             }
  7334.             
  7335.             $mailer->send($message);
  7336.             
  7337.         }
  7338.         
  7339.         return $this->render('admin/send_document_mail.html.twig', [
  7340.            'boutique' => $boutique,
  7341.            'commande' => $commande,
  7342.            'userBoutique' => $userBoutique
  7343.         ]);
  7344.     }
  7345.     
  7346.     
  7347.     /**
  7348.      * @Route("/{slug}/nombre-commande-en-retard", name="admin.nombre_commande_en_retard")
  7349.      * @return \Symfony\Component\HttpFoundation\Response
  7350.      */
  7351.     public function nombreCommandeEnRetard(Request $requestBoutique $boutique)
  7352.     {
  7353.         $em $this->getDoctrine()
  7354.                     ->getManager();
  7355.         $nombreCommandeEnRetard $em->getRepository(Commande::class)
  7356.                         -> nombreCommandeEnRetard($boutique->getId());
  7357.                         
  7358.         $nombreCommandeEnRetard count($nombreCommandeEnRetard);
  7359.         $user $this->getUser();
  7360.         $userBoutique $em->getRepository(UserBoutique::class)
  7361.                         ->findOneBy(
  7362.                             array(
  7363.                             'user' => $user->getId(),
  7364.                             'boutique' => $boutique->getId()
  7365.                             )
  7366.                         );
  7367.         return $this->render('admin/nombre_commande_en_retard.html.twig', [
  7368.            'boutique' => $boutique,
  7369.            'nombreCommandeEnRetard' => $nombreCommandeEnRetard,
  7370.            'userBoutique' => $userBoutique
  7371.         ]);
  7372.     }
  7373.     
  7374.     /**
  7375.      * @Route("/{slug}/liste-commande-en-retard", name="admin.liste_commande_en_retard")
  7376.      * @return \Symfony\Component\HttpFoundation\Response
  7377.      */
  7378.     public function listeCommandeEnRetard(Request $requestBoutique $boutique)
  7379.     {
  7380.         $em $this->getDoctrine()
  7381.                     ->getManager();
  7382.         $nombreCommandeEnRetards $em->getRepository(Commande::class)
  7383.                         -> nombreCommandeEnRetard($boutique->getId());
  7384.                         
  7385.         $user $this->getUser();
  7386.         $userBoutique $em->getRepository(UserBoutique::class)
  7387.                         ->findOneBy(
  7388.                             array(
  7389.                             'user' => $user->getId(),
  7390.                             'boutique' => $boutique->getId()
  7391.                             )
  7392.                         );
  7393.         
  7394.         return $this->render('admin/liste_commande_en_retard.html.twig', [
  7395.            'boutique' => $boutique,
  7396.            'nombreCommandeEnRetards' => $nombreCommandeEnRetards,
  7397.            'userBoutique' => $userBoutique
  7398.         ]);
  7399.     }
  7400.     
  7401.     /**
  7402.      * @Route("/{slug}/my-invoices", name="admin.my_invoices")
  7403.      * @return \Symfony\Component\HttpFoundation\Response
  7404.      */
  7405.     public function myInvoicesAction(Request $requestBoutique $boutique)
  7406.     {
  7407.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7408.            return $this->redirectToRoute('security_login');
  7409.         }
  7410.         $em $this->getDoctrine()
  7411.                     ->getManager();
  7412.                     
  7413.         
  7414.                         
  7415.         $toutesLesValiditeServices $em->getRepository(ValiditeService::class)
  7416.                     ->toutesLesValiditeService($boutique->getId());
  7417.                     
  7418.         
  7419.         $user $this->getUser();
  7420.         $userBoutique $em->getRepository(UserBoutique::class)
  7421.                         ->findOneBy(
  7422.                             array(
  7423.                             'user' => $user->getId(),
  7424.                             'boutique' => $boutique->getId()
  7425.                             )
  7426.                         );
  7427.                         
  7428.         return $this->render('admin/my_invoices.html.twig', [
  7429.            'toutesLesValiditeServices' => $toutesLesValiditeServices,
  7430.            'boutique' => $boutique,
  7431.            'userBoutique' => $userBoutique
  7432.         ]);
  7433.     }
  7434.     
  7435.     /**
  7436.      * @Route("/{slug}/my-tickets/{id}", name="admin.my_tickets")
  7437.      * @return \Symfony\Component\HttpFoundation\Response
  7438.      */
  7439.     public function myTicketsAction(Request $request$slug$id)
  7440.     {
  7441.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7442.            return $this->redirectToRoute('security_login');
  7443.         }
  7444.         $em $this->getDoctrine()
  7445.                     ->getManager();
  7446.                     
  7447.         $boutique $em->getRepository(Boutique::class)
  7448.                         ->findOneBySlug($slug);
  7449.         $user $this->getUser();
  7450.         $userBoutique $em->getRepository(UserBoutique::class)
  7451.                         ->findOneBy(
  7452.                             array(
  7453.                             'user' => $user->getId(),
  7454.                             'boutique' => $boutique->getId()
  7455.                             )
  7456.                         );
  7457.         
  7458.         $tickets $em->getRepository(Ticket::class)
  7459.                         ->findBy(
  7460.                             array(
  7461.                                 'boutique'=>$boutique->getId(),
  7462.                                 'user' => $user->getId()
  7463.                             )
  7464.                         );
  7465.         
  7466.         return $this->render('admin/my_tickets.html.twig', [
  7467.            'boutique' => $boutique,
  7468.            'tickets'  => $tickets,
  7469.            'userBoutique' => $userBoutique
  7470.         ]);
  7471.     }
  7472.     
  7473.     /**
  7474.      * @Route("/{slug}/new-ticket", name="admin.new_ticket")
  7475.      * @return \Symfony\Component\HttpFoundation\Response
  7476.      */
  7477.     public function newTicketAction(Request $request$slug)
  7478.     {
  7479.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7480.            return $this->redirectToRoute('security_login');
  7481.         }
  7482.         $em $this->getDoctrine()
  7483.                     ->getManager();
  7484.                     
  7485.         $boutique $em->getRepository(Boutique::class)
  7486.                         ->findOneBySlug($slug);
  7487.         $user $this->getUser();
  7488.         
  7489.         $ticket = new Ticket;
  7490.         
  7491.         $user $this->getUser();
  7492.         $userBoutique $em->getRepository(UserBoutique::class)
  7493.                         ->findOneBy(
  7494.                             array(
  7495.                             'user' => $user->getId(),
  7496.                             'boutique' => $boutique->getId()
  7497.                             )
  7498.                         );
  7499.         $form $this->createForm(TicketType::class, $ticket);
  7500.         
  7501.         $ok_soumission '';
  7502.         $error '';
  7503.         
  7504.         if($request->getMethod() == 'POST'){
  7505.             
  7506.                $form->handleRequest($request);
  7507.                if($form->isValid()){
  7508.                    $ticket->setBoutique($boutique);
  7509.                    $ticket->setUser($user);
  7510.                    
  7511.                   $em->persist($ticket);
  7512.                   $em->flush();
  7513.                   
  7514.                 return $this->redirectToRoute('admin.display_ticket', array('slug' => $boutique->getSlug(), 'id' => $ticket->getId()));
  7515.                 $ok_soumission =" Votre message a été pris en compte";
  7516.                     
  7517.                 $ticket = new Ticket;
  7518.                 
  7519.                 $form $this->createForm(TicketType::class, $ticket);
  7520.                     
  7521.                 } else {
  7522.                     $error =" Veillez corrigez vos erreurs";
  7523.                 }
  7524.         }
  7525.         
  7526.         return $this->render('admin/new_ticket.html.twig', [
  7527.            'boutique' => $boutique,
  7528.            'form' => $form->createView(),
  7529.            'userBoutique' => $userBoutique
  7530.         ]);
  7531.     }
  7532.     
  7533.     /**
  7534.      * @Route("/{slug}/display-ticket/{id}", name="admin.display_ticket")
  7535.      * @return \Symfony\Component\HttpFoundation\Response
  7536.      */
  7537.     public function displayTicketAction(Request $request$slug$id)
  7538.     {
  7539.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7540.            return $this->redirectToRoute('security_login');
  7541.         }
  7542.         $em $this->getDoctrine()
  7543.                     ->getManager();
  7544.                     
  7545.         $boutique $em->getRepository(Boutique::class)
  7546.                         ->findOneBySlug($slug);
  7547.         $user $this->getUser();
  7548.         $userBoutique $em->getRepository(UserBoutique::class)
  7549.                         ->findOneBy(
  7550.                             array(
  7551.                             'user' => $user->getId(),
  7552.                             'boutique' => $boutique->getId()
  7553.                             )
  7554.                         );
  7555.         
  7556.         $ticket $em->getRepository(Ticket::class)
  7557.                     ->findOneBy(
  7558.                         array(
  7559.                             'boutique' => $boutique->getId(),
  7560.                             'id' => $id
  7561.                         )
  7562.                     );
  7563.         $commentaires $em->getRepository(CommentaireTicket::class)
  7564.                             ->findByTicket($ticket->getId());
  7565.         $commentaireTicket = new CommentaireTicket;
  7566.         
  7567.         $user $this->getUser();
  7568.         $form $this->createForm(CommentaireTicketType::class, $commentaireTicket);
  7569.         
  7570.         $ok_soumission '';
  7571.         $error '';
  7572.         
  7573.         if($request->getMethod() == 'POST'){
  7574.             
  7575.                $form->handleRequest($request);
  7576.                if($form->isValid()){
  7577.                    
  7578.                    $commentaireTicket->setTicket($ticket);
  7579.                    $commentaireTicket->setUser($user);
  7580.                    
  7581.                   $em->persist($commentaireTicket);
  7582.                   $em->flush();
  7583.                 
  7584.                 $commentaires $em->getRepository(CommentaireTicket::class)
  7585.                             ->findByTicket($ticket->getId());
  7586.                 $ok_soumission =" Votre message a été pris en compte";
  7587.                     
  7588.                 $commentaireTicket = new CommentaireTicket;
  7589.                 
  7590.                 $form $this->createForm(CommentaireTicketType::class, $commentaireTicket);
  7591.                     
  7592.                 } else {
  7593.                     $error =" Veillez corrigez vos erreurs";
  7594.                 }
  7595.         }
  7596.         
  7597.         return $this->render('admin/display_ticket.html.twig', [
  7598.            'boutique' => $boutique,
  7599.            'ticket' => $ticket,
  7600.            'form' => $form->createView(),
  7601.            'commentaires' => $commentaires,
  7602.            'userBoutique' => $userBoutique
  7603.         ]);
  7604.     }
  7605.     
  7606.     /**
  7607.      * @Route("/{slug}/close-ticket/{id}", name="admin.close_ticket")
  7608.      * @return \Symfony\Component\HttpFoundation\Response
  7609.      */
  7610.     public function closeTicketAction(Request $request$slug$id)
  7611.     {
  7612.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7613.            return $this->redirectToRoute('security_login');
  7614.         }
  7615.         $em $this->getDoctrine()
  7616.                     ->getManager();
  7617.                     
  7618.         $boutique $em->getRepository(Boutique::class)
  7619.                         ->findOneBySlug($slug);
  7620.         
  7621.         $ticket $em->getRepository(Ticket::class)
  7622.                     ->findOneBy(
  7623.                         array(
  7624.                             'boutique' => $boutique->getId(),
  7625.                             'id' => $id
  7626.                         )
  7627.                     );
  7628.         
  7629.         if(null !== $ticket){
  7630.             $ticket->setLesCommentairesSontFermes(true);
  7631.             $em->flush();
  7632.         }
  7633.         
  7634.         return $this->redirectToRoute('admin.display_ticket',array('slug'=>$boutique->getSlug(), 'id'=>$ticket->getId()));
  7635.     }
  7636.     
  7637.     
  7638.     /**
  7639.      * @Route("/{slug}/delete-ticket/{id}", name="admin.delete_ticket")
  7640.      * @return \Symfony\Component\HttpFoundation\Response
  7641.      */
  7642.     public function deleteTicketAction(Request $request$slug$id)
  7643.     {
  7644.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7645.            return $this->redirectToRoute('security_login');
  7646.         }
  7647.         $em $this->getDoctrine()
  7648.                     ->getManager();
  7649.                     
  7650.         $boutique $em->getRepository(Boutique::class)
  7651.                         ->findOneBySlug($slug);
  7652.         $user $this->getUser();
  7653.         
  7654.         
  7655.         $ok_soumission '';
  7656.         $error '';
  7657.         
  7658.         $ticket $em->getRepository(Ticket::class)
  7659.                     ->findOneBy(
  7660.                         array(
  7661.                             'boutique' => $boutique->getId(),
  7662.                             'id' => $id
  7663.                         )
  7664.                     );
  7665.         if(null !== $ticket){
  7666.             $commentaireTickets $em->getRepository(CommentaireTicket::class)
  7667.                                     ->findByTicket($ticket->getId());
  7668.             foreach($commentaireTickets as $commentaireTicket)
  7669.             {
  7670.                 $em->remove($commentaireTicket);
  7671.             }
  7672.             $em->remove($ticket);
  7673.             $em->flush();
  7674.         }
  7675.         
  7676.         return $this->redirectToRoute('admin.my_tickets',array('slug'=>$boutique->getSlug(), 'id'=>$user->getId()));
  7677.     }
  7678.     
  7679.     
  7680.     /**
  7681.      * @Route("/{slug}/delete-commentaire-ticket/{id}", name="admin.delete_commentaire_ticket")
  7682.      * @return \Symfony\Component\HttpFoundation\Response
  7683.      */
  7684.     public function deleteCommentaireTicketAction(Request $request$slug$id)
  7685.     {
  7686.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7687.            return $this->redirectToRoute('security_login');
  7688.         }
  7689.         $em $this->getDoctrine()
  7690.                     ->getManager();
  7691.                     
  7692.         $boutique $em->getRepository(Boutique::class)
  7693.                         ->findOneBySlug($slug);
  7694.         $user $this->getUser();
  7695.     
  7696.         $commentaireTicket $em->getRepository(CommentaireTicket::class)
  7697.                     ->findOneById($id);
  7698.                     
  7699.         if(null !== $commentaireTicket){
  7700.             
  7701.             $em->remove($commentaireTicket);
  7702.             $em->flush();
  7703.         }
  7704.         
  7705.         return $this->redirectToRoute('admin.my_tickets',array('slug'=>$boutique->getSlug(), 'id'=>$user->getId()));
  7706.     }
  7707.     
  7708.     /**
  7709.      * @Route("/{slug}/liste-produit-lors-commande", name="admin.liste_produit_lors_commande")
  7710.      * @return \Symfony\Component\HttpFoundation\Response
  7711.      */
  7712.     public function listeProduitLorsCommandeAction(Request $requestBoutique $boutique)
  7713.     {
  7714.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7715.            return $this->redirectToRoute('security_login');
  7716.         }
  7717.         
  7718.         $em $this->getDoctrine()
  7719.                     ->getManager();
  7720.                     
  7721.         $produits $em->getRepository(Produit::class)
  7722.                         ->findBy(
  7723.                             array(
  7724.                                 'boutique' => $boutique->getId(),
  7725.                                 'estSupprime' => false
  7726.                             )    
  7727.                         );
  7728.         $user $this->getUser();
  7729.         $userBoutique $em->getRepository(UserBoutique::class)
  7730.                         ->findOneBy(
  7731.                             array(
  7732.                             'user' => $user->getId(),
  7733.                             'boutique' => $boutique->getId()
  7734.                             )
  7735.                         );
  7736.         
  7737.         
  7738.         return $this->render('admin/liste_produit_lors_commande.html.twig', [
  7739.            'boutique' => $boutique,
  7740.            'produits' => $produits,
  7741.            'userBoutique' => $userBoutique
  7742.         ]);
  7743.     }
  7744.     
  7745.     /**
  7746.      * @Route("/{slug}/stock-management", name="admin.stock_management")
  7747.      * @return \Symfony\Component\HttpFoundation\Response
  7748.      */
  7749.     public function stockManagementAction(Request $requestBoutique $boutique)
  7750.     {
  7751.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7752.            return $this->redirectToRoute('security_login');
  7753.         }
  7754.         $em $this->getDoctrine()
  7755.                     ->getManager();
  7756.                     
  7757.         $produits $em->getRepository(Produit::class)
  7758.                         ->findByBoutique($boutique->getId());
  7759.         $user $this->getUser();
  7760.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  7761.         
  7762.         
  7763.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  7764.         $startMonth $intervalleMois['debut'];
  7765.         $endMonth $intervalleMois['fin'];
  7766.         
  7767.         $dateDebut = new \DateTime($startMonth);
  7768.         $dateFin = new \DateTime($endMonth);
  7769.         $startYear date('Y-01-01');
  7770.         $endYear date('Y-12-31');
  7771.         $user $this->getUser();
  7772.         
  7773.         $userBoutique $em->getRepository(UserBoutique::class)
  7774.                         ->findOneBy(
  7775.                             array(
  7776.                             'user' => $user->getId(),
  7777.                             'boutique' => $boutique->getId()
  7778.                             )
  7779.                         );
  7780.         
  7781.         $stockEntries  $em->getRepository(EntreeDeStock::class)
  7782.                         ->entreeParDateEtType($boutique->getId(),  $dateDebut$dateFin);
  7783.         $produitVendus  $em->getRepository(ProduitCommande::class)
  7784.                         ->produitVenduSurUnePeriode($boutique->getId(), 'invoice'$dateDebut$dateFin);
  7785.         if('POST' == $request->getMethod()){
  7786.             $dateDebut $_POST['dateDebut'];
  7787.             $dateFin $_POST['dateFin'];
  7788.             
  7789.             $dateDebut = new \DateTime($dateDebut);
  7790.             $dateFin = new \DateTime($dateFin);
  7791.             
  7792.             $stockEntries  $em->getRepository(EntreeDeStock::class)
  7793.                         ->entreeParDateEtType($boutique->getId(),  $dateDebut$dateFin);
  7794.             
  7795.             return $this->render('admin/entries_table_content.html.twig', [
  7796.                'boutique' => $boutique,
  7797.                'stockEntries' => $stockEntries,
  7798.                'userBoutique' => $userBoutique
  7799.             ]);
  7800.             
  7801.         }
  7802.         
  7803.         return $this->render('admin/stock_management.html.twig', [
  7804.            'boutique' => $boutique,
  7805.            'produits' => $produits,
  7806.            'userBoutique' => $userBoutique,
  7807.            'dateDebut' => $dateDebut,
  7808.            'dateFin' => $dateFin,
  7809.            'startMonth' => $startMonth,
  7810.            'endMonth' => $endMonth,
  7811.            'startYear' => $startYear,
  7812.            'endYear' => $endYear,
  7813.            'stockEntries' => $stockEntries,
  7814.            'produitVendus' => $produitVendus
  7815.         ]);
  7816.     }
  7817.     
  7818.     /**
  7819.      * @Route("/{slug}/nouvel-inventaire", name="admin_nouvel_inventaire")
  7820.      * @return \Symfony\Component\HttpFoundation\Response
  7821.      */
  7822.     public function nouvelInventaireAction(Request $requestBoutique $boutique)
  7823.     {
  7824.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7825.            return $this->redirectToRoute('security_login');
  7826.         }
  7827.         $em $this->getDoctrine()
  7828.                     ->getManager();
  7829.                     
  7830.         $produits $em->getRepository(Produit::class)
  7831.                         ->findByBoutique($boutique->getId());
  7832.         $user $this->getUser();
  7833.         $intervalleDeDate  $this->intervalleSemaine(date('Y-m-d'));
  7834.         $dateDebut = new \DateTime($intervalleDeDate['debut']);
  7835.         $dateFin = new \DateTime($intervalleDeDate['fin']);
  7836.         
  7837.         $intervalleMois $this->intervalleMois(date('Y-m-d'));
  7838.         $startMonth $intervalleMois['debut'];
  7839.         $endMonth $intervalleMois['fin'];
  7840.         
  7841.         $startYear date('Y-01-01');
  7842.         $endYear date('Y-12-31');
  7843.         $user $this->getUser();
  7844.         
  7845.         $userBoutique $em->getRepository(UserBoutique::class)
  7846.                         ->findOneBy(
  7847.                             array(
  7848.                             'user' => $user->getId(),
  7849.                             'boutique' => $boutique->getId()
  7850.                             )
  7851.                         );
  7852.         
  7853.         $stockEntries  $em->getRepository(EntreeDeStock::class)
  7854.                         ->entreeParDateEtType($boutique->getId(),  $dateDebut$dateFin);
  7855.         $produits $em->getRepository(Produit::class)
  7856.                         ->findBy(
  7857.                             array(
  7858.                                 'boutique' => $boutique->getId() 
  7859.                             ),
  7860.                             array(
  7861.                                 'nom' => 'ASC'
  7862.                             )
  7863.                         );
  7864.         if('POST' == $request->getMethod()){
  7865.             $dateDebut $_POST['dateDebut'];
  7866.             $dateFin $_POST['dateFin'];
  7867.             
  7868.             $dateDebut = new \DateTime($dateDebut);
  7869.             $dateFin = new \DateTime($dateFin);
  7870.             
  7871.             $stockEntries  $em->getRepository(EntreeDeStock::class)
  7872.                         ->entreeParDateEtType($boutique->getId(),  $dateDebut$dateFin);
  7873.             
  7874.             return $this->render('admin/entries_table_content.html.twig', [
  7875.                'boutique' => $boutique,
  7876.                'stockEntries' => $stockEntries
  7877.             ]);
  7878.             
  7879.         }
  7880.         
  7881.         return $this->render('admin/nouvel_inventaire.html.twig', [
  7882.            'boutique' => $boutique,
  7883.            'produits' => $produits,
  7884.            'userBoutique' => $userBoutique,
  7885.            'dateDebut' => $dateDebut,
  7886.            'dateFin' => $dateFin,
  7887.            'startMonth' => $startMonth,
  7888.            'endMonth' => $endMonth,
  7889.            'startYear' => $startYear,
  7890.            'endYear' => $endYear,
  7891.            'stockEntries' => $stockEntries,
  7892.            'produits' => $produits
  7893.         ]);
  7894.     }
  7895.     /**
  7896.      * @Route("/{slug}/payer-entree-de-stock/{id}", name="admin_payer_entree_de_stock")
  7897.      * @return \Symfony\Component\HttpFoundation\Response
  7898.      */
  7899.     public function payerEntreeDeSTockAction(Request $request,  $slug$id)
  7900.     {
  7901.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7902.            return $this->redirectToRoute('security_login');
  7903.         }
  7904.         $em $this->getDoctrine()
  7905.                     ->getManager();
  7906.         $entreeDeStock $em->getRepository(EntreeDeStock::class)
  7907.                                 ->findOneById($id);    
  7908.                                 
  7909.         $boutique $em->getRepository(Boutique::class)
  7910.                                 ->findOneBySlug($slug);    
  7911.         
  7912.                     
  7913.         $user $this->getUser();
  7914.         $userBoutique $em->getRepository(UserBoutique::class)
  7915.                         ->findOneBy(
  7916.                             array(
  7917.                             'user' => $user->getId(),
  7918.                             'boutique' => $boutique->getId()
  7919.                             )
  7920.                         );
  7921.         
  7922.         if($request->getMethod() == 'POST'){
  7923.             
  7924.             $montant = (float)$_POST['montant'];
  7925.             $moyenDePaiement $_POST['moyenDePaiement'];
  7926.             
  7927.             
  7928.             $depense = new Expensive;
  7929.             $depense->setBoutique($boutique);
  7930.             $depense->setMontant($montant);
  7931.             $categorieDepense $em->getRepository(CategorieDepense::class)
  7932.                                 ->findOneBy(
  7933.                                     array(
  7934.                                         'boutique' => $boutique,
  7935.                                         'nom' => 'ACHAT DE MARCHANDISES'
  7936.                                     )
  7937.                                 );
  7938.             
  7939.             $depense->setCategorieDepense($categorieDepense);
  7940.         
  7941.             $em->persist($depense);
  7942.             $entreeDeStock->setResteAPayer($entreeDeStock->getResteAPayer() - $montant);
  7943.             $entreeDeStock->setMontantPaye($entreeDeStock->getMontantPaye() + $montant);
  7944.             $em->flush();
  7945.             
  7946.         }
  7947.     
  7948.         return $this->render('admin/payer_entree_de_stock.html.twig', [
  7949.            'boutique' => $boutique,
  7950.            'userBoutique' => $userBoutique,
  7951.            
  7952.            'entreeDeStock' => $entreeDeStock
  7953.         ]);
  7954.     }
  7955.     /**
  7956.      * @Route("/{slug}/new-stock-entry", name="admin.new_stock_entry")
  7957.      * @return \Symfony\Component\HttpFoundation\Response
  7958.      */
  7959.     public function newStockEntryAction(Request $requestBoutique $boutique)
  7960.     {
  7961.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  7962.            return $this->redirectToRoute('security_login');
  7963.         }
  7964.         $em $this->getDoctrine()
  7965.                     ->getManager();
  7966.         $tiers $em->getRepository(Tiers::class)
  7967.                                 ->findByBoutique($boutique);        
  7968.         
  7969.                     
  7970.         $produits $em->getRepository(Produit::class)
  7971.                         ->findByBoutique($boutique->getId());
  7972.         $user $this->getUser();
  7973.         $userBoutique $em->getRepository(UserBoutique::class)
  7974.                         ->findOneBy(
  7975.                             array(
  7976.                             'user' => $user->getId(),
  7977.                             'boutique' => $boutique->getId()
  7978.                             )
  7979.                         );
  7980.         $editMode'new';
  7981.         
  7982.         if($request->getMethod() == 'POST'){
  7983.             
  7984.             $dateCommande $_POST['dateCommande'];
  7985.             $tiers $_POST['tiers'];
  7986.             
  7987.             $tiers $em->getRepository(Tiers::class)
  7988.                         ->findOneById($tiers);
  7989.             $fraisDeTransport =  (float)$_POST['fraisDeTransport'];
  7990.             $autreFrais =  (float)$_POST['autreFrais'];
  7991.             $listeProduits json_decode($_POST['listeProduits']);
  7992.             
  7993.             $entreeDeStock = new EntreeDeStock;
  7994.             $entreeDeStock->setBoutique($boutique);
  7995.         
  7996.             $laDate = new \DateTime($dateCommande);
  7997.             $entreeDeStock->setLaDate($laDate);
  7998.         
  7999.             $em->persist($entreeDeStock);
  8000.             $em->flush();
  8001.             $produitCommandes = array();
  8002.             $sousTotal 0;
  8003.             foreach($listeProduits as $listeProduit){
  8004.                 $listeProduit = (array)$listeProduit;
  8005.                 $idDuProduit $listeProduit['idProduit'];
  8006.                 
  8007.                 $leProduit $em->getRepository(Produit::class)
  8008.                         ->findOneById($idDuProduit);
  8009.                 $leProduit->setStockDisponible($leProduit->getStockDisponible() + $listeProduit['quantite']);
  8010.                 
  8011.                 $produitEntreeDeStock = new ProduitEntreeDeStock;
  8012.                 $produitEntreeDeStock->setProduit($leProduit);
  8013.                 $produitEntreeDeStock->setEntreeDeStock($entreeDeStock);
  8014.                 $produitEntreeDeStock->setQuantite((float)$listeProduit['quantite']);
  8015.                 $produitEntreeDeStock->setPrixDAchat((float)$listeProduit['prixDAchat']);
  8016.                 $produitEntreeDeStock->setSousTotal((float)$listeProduit['sousTotal']);
  8017.                 
  8018.                 $sousTotal += (float)$listeProduit['sousTotal'];
  8019.                 $em->persist($produitEntreeDeStock);
  8020.             }
  8021.             $entreeDeStock->setTotalAchat($sousTotal);
  8022.             $entreeDeStock->setFraisDeTransport($fraisDeTransport);
  8023.             $entreeDeStock->setAutreFrais($autreFrais);
  8024.             $entreeDeStock->setNetPaye($autreFrais $sousTotal);
  8025.             $entreeDeStock->setResteAPayer($sousTotal $autreFrais);
  8026.             $entreeDeStock->setTiers($tiers);
  8027.             
  8028.             $em->flush();
  8029.             
  8030.         }
  8031.     
  8032.         return $this->render('admin/new_stock_entry.html.twig', [
  8033.            'boutique' => $boutique,
  8034.            'produits' => $produits,
  8035.            'userBoutique' => $userBoutique,
  8036.            'editMode' => $editMode,
  8037.            'tiers' => $tiers
  8038.         ]);
  8039.     }
  8040.     
  8041.     /**
  8042.      * @Route("/{slug}/edit-stock-entry/{id}", name="admin.edit_stock_entry")
  8043.      * @return \Symfony\Component\HttpFoundation\Response
  8044.      */
  8045.     public function editStockEntryAction(Request $request$slug$id)
  8046.     {
  8047.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  8048.            return $this->redirectToRoute('security_login');
  8049.         }      
  8050.         $em $this->getDoctrine()
  8051.                     ->getManager();
  8052.         $boutique  $em->getRepository(Boutique::class)
  8053.                         ->findOneBySlug($slug);
  8054.         $tiers $em->getRepository(Tiers::class)
  8055.                     ->findByBoutique($boutique);
  8056.     
  8057.         $produits  $em->getRepository(Produit::class)
  8058.                         ->findByBoutique($boutique->getId());
  8059.     
  8060.         $entreeDeStock  $em->getRepository(EntreeDeStock::class)
  8061.                         ->findOneBy(
  8062.                             array(
  8063.                                 'boutique' => $boutique->getId(),
  8064.                                 'id' => $id
  8065.                         ));
  8066.         
  8067.         $ancienProduitEntreeDeStocks  $em->getRepository(ProduitEntreeDeStock::class)
  8068.                         ->findBy(
  8069.                             array(
  8070.                                 'entreeDeStock' => $entreeDeStock->getId()
  8071.                         ));
  8072.                         
  8073.         $user $this->getUser();
  8074.         $userBoutique $em->getRepository(UserBoutique::class)
  8075.                         ->findOneBy(
  8076.                             array(
  8077.                             'user' => $user->getId(),
  8078.                             'boutique' => $boutique->getId()
  8079.                             )
  8080.                         );
  8081.     
  8082.         $ok_soumission '';
  8083.         $error '';
  8084.         $editMode 'edit';
  8085.         if($request->getMethod() == 'POST'){
  8086.             $dateCommande $_POST['dateCommande'];
  8087.             $listeProduits json_decode($_POST['listeProduits']);
  8088.             
  8089.             $tiers $_POST['tiers'];
  8090.             
  8091.             $tiers $em->getRepository(Tiers::class)
  8092.                         ->findOneById($tiers);
  8093.             $fraisDeTransport =  (float)$_POST['fraisDeTransport'];
  8094.             $autreFrais =  (float)$_POST['autreFrais'];
  8095.             $em->flush();
  8096.             
  8097.             //Supprimer les ancien ProduitCommande lié 
  8098.             foreach($ancienProduitEntreeDeStocks as $ancienProduitEntreeDeStock){
  8099.                 $em->remove($ancienProduitEntreeDeStock);
  8100.                 
  8101.                 $leProduit $em->getRepository(Produit::class)
  8102.                         ->findOneById($ancienProduitEntreeDeStock->getProduit()->getId());
  8103.                 $leProduit->setStockDisponible($leProduit->getStockDisponible() - $ancienProduitEntreeDeStock->getQuantite());
  8104.             }
  8105.             $em->flush();
  8106.             $produitEntreeDeStocks = array();
  8107.             $sousTotal 0;
  8108.             foreach($listeProduits as $listeProduit){
  8109.                 $listeProduit = (array)$listeProduit;
  8110.                 $idDuProduit $listeProduit['idProduit'];
  8111.                 
  8112.                 $leProduit $em->getRepository(Produit::class)
  8113.                         ->findOneById($idDuProduit);
  8114.                 $leProduit->setStockDisponible($leProduit->getStockDisponible() + $listeProduit['quantite']);
  8115.         
  8116.                 
  8117.                 $produitEntreeDeStock = new ProduitEntreeDeStock;
  8118.                 $produitEntreeDeStock->setProduit($leProduit);
  8119.                 $produitEntreeDeStock->setEntreeDeStock($entreeDeStock);
  8120.                 $produitEntreeDeStock->setQuantite($listeProduit['quantite']);
  8121.                 
  8122.                 $produitEntreeDeStock->setPrixDAchat((float)$listeProduit['prixDAchat']);
  8123.                 $produitEntreeDeStock->setSousTotal((float)$listeProduit['sousTotal']);
  8124.                 
  8125.                 $sousTotal += (float)$listeProduit['sousTotal'];
  8126.                 $em->persist($produitEntreeDeStock);
  8127.             }
  8128.             
  8129.             $entreeDeStock->setTotalAchat($sousTotal);
  8130.             $entreeDeStock->setFraisDeTransport($fraisDeTransport);
  8131.             $entreeDeStock->setAutreFrais($autreFrais);
  8132.             $entreeDeStock->setNetPaye($autreFrais $sousTotal);
  8133.             $entreeDeStock->setResteAPayer($sousTotal $autreFrais);
  8134.             $entreeDeStock->setTiers($tiers);
  8135.             $em->flush();
  8136.         }
  8137.     
  8138.         return $this->render('admin/edit_stock_entry.html.twig', [
  8139.            'boutique' => $boutique,
  8140.            'produits' => $produits,
  8141.            'editMode' => $editMode,
  8142.            'entreeDeStock' => $entreeDeStock,
  8143.            'ancienProduitEntreeDeStocks' => $ancienProduitEntreeDeStocks,
  8144.            'userBoutique' => $userBoutique,
  8145.            'tiers' => $tiers
  8146.         ]);
  8147.     }
  8148.     
  8149.     
  8150.     /**
  8151.      * @Route("/{slug}/delete-stock-entry/{id}", name="admin.delete_stock_entry")
  8152.      * @return \Symfony\Component\HttpFoundation\Response
  8153.      */
  8154.     public function deleteStockEntryAction(Request $request,  $slug$id)
  8155.     {
  8156.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  8157.            return $this->redirectToRoute('security_login');
  8158.         }  
  8159.         $em $this->getDoctrine()
  8160.                     ->getManager();
  8161.         
  8162.         $boutique  $em->getRepository(Boutique::class)
  8163.                         ->findOneBySlug($slug);
  8164.         
  8165.         $user $this->getUser();
  8166.         $userBoutique $em->getRepository(UserBoutique::class)
  8167.                         ->findOneBy(
  8168.                             array(
  8169.                             'user' => $user->getId(),
  8170.                             'boutique' => $boutique->getId()
  8171.                             )
  8172.                         );
  8173.         $entreeDeStock  $em->getRepository(EntreeDeStock::class)
  8174.                         ->findOneBy(
  8175.                             array(
  8176.                                 'boutique' => $boutique->getId(),
  8177.                                 'id' => $id
  8178.                             )
  8179.                         );
  8180.         
  8181.         if(null != $entreeDeStock){
  8182.             $produitEntreeDeStocks $em->getRepository(ProduitEntreeDeStock::class)
  8183.                                         ->findBy(
  8184.                                             array(
  8185.                                                 'entreeDeStock' => $entreeDeStock->getId()
  8186.                                             )
  8187.                                         );
  8188.             foreach($produitEntreeDeStocks as $produitEntreeDeStock){
  8189.                 $em->remove($produitEntreeDeStock);
  8190.                 $produit $em->getRepository(Produit::class)
  8191.                                 ->findOneById($produitEntreeDeStock->getProduit()->getId());
  8192.                 $produit->setStockDisponible($produit->getStockDisponible() - $produitEntreeDeStock->getQuantite());
  8193.             }
  8194.             $em->flush();
  8195.             
  8196.             $em->remove($entreeDeStock);
  8197.             $em->flush();
  8198.         }
  8199.         return $this->redirectToRoute('admin.stock_management', array('slug' => $boutique->getSlug()));
  8200.     }
  8201.     /**
  8202.      * @Route("/{slug}/produits-vendus", name="admin_produits_vendus")
  8203.      * @return \Symfony\Component\HttpFoundation\Response
  8204.      */
  8205.     public function produitsVendusActionRequest $requestBoutique $boutique)
  8206.     {
  8207.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  8208.            return $this->redirectToRoute('security_login');
  8209.         }
  8210.         
  8211.         $em $this->getDoctrine()
  8212.                     ->getManager();
  8213.         
  8214.         $userBoutique $em->getRepository(UserBoutique::class)
  8215.                         ->findOneBy(
  8216.                             array(
  8217.                             'user' => $this->getUser()->getId(),
  8218.                             'boutique' => $boutique->getId()
  8219.                             )
  8220.                         );
  8221.         
  8222.         if('POST' == $request->getMethod()){
  8223.             $dateDebut $_POST['dateDebut'];
  8224.             $dateFin $_POST['dateFin'];
  8225.             
  8226.             $dateDebut = new \DateTime($dateDebut);
  8227.             $dateDebut->setTime(00);
  8228.             $dateFin = new \DateTime($dateFin);
  8229.             $dateFin->setTime(2359);
  8230.             
  8231.             $produitsVendus  $em->getRepository(ProduitCommande::class)
  8232.                         ->produitVenduSurUnePeriode($boutique->getId(), 'invoice'$dateDebut$dateFin);
  8233.             
  8234.             
  8235.             return $this->render('admin/produits_vendus.html.twig', [
  8236.                'boutique' => $boutique,
  8237.                'produitsVendus' => $produitsVendus
  8238.             ]);
  8239.             
  8240.         }
  8241.         
  8242.         return $this->render('admin/sortie_de_stock.html.twig', [
  8243.            'boutique' => $boutique,
  8244.            'dateDebut' => $dateDebut,
  8245.            'dateFin' => $dateFin,
  8246.            'userBoutique' => $userBoutique,
  8247.            'typeFacture' => $typeFacture
  8248.         ]);
  8249.     }
  8250.     
  8251.     /**
  8252.      * @Route("/{slug}/import-products", name="admin.import_products")
  8253.      * @return \Symfony\Component\HttpFoundation\Response
  8254.      */
  8255.     public function importProductsAction(Request $requestBoutique $boutique)
  8256.     {
  8257.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  8258.            return $this->redirectToRoute('security_login');
  8259.         }
  8260.         $em $this->getDoctrine()
  8261.                     ->getManager();
  8262.                     
  8263.         $user $this->getUser();
  8264.         
  8265.         $userBoutique $em->getRepository(UserBoutique::class)
  8266.                         ->findOneBy(
  8267.                             array(
  8268.                             'user' => $user->getId(),
  8269.                             'boutique' => $boutique->getId()
  8270.                             )
  8271.                         );
  8272.         
  8273.         $error '';
  8274.         $success '';
  8275.         if('POST' == $request->getMethod()){
  8276.             if(isset($_FILES['fichier']) && $_FILES['fichier']['error'] == 0)
  8277.             {
  8278.                 
  8279.             
  8280.                 $em->flush();
  8281.                 if ($this->gererFichierMultipleImportation($_FILES['fichier'], $boutique)){
  8282.                     $success 'success';
  8283.                 } else{
  8284.                     $error 'error';
  8285.                 }
  8286.                 
  8287.             }
  8288.         }
  8289.         
  8290.         return $this->render('admin/import_products.html.twig', [
  8291.            'boutique' => $boutique,
  8292.            'userBoutique' => $userBoutique,
  8293.            'error' => $error,
  8294.            'success' => $success
  8295.         ]);
  8296.     }
  8297.     
  8298.     /**
  8299.      * @Route("/{slug}/import-customers", name="admin.import_customers")
  8300.      * @return \Symfony\Component\HttpFoundation\Response
  8301.      */
  8302.     public function importCustomersAction(Request $requestBoutique $boutique)
  8303.     {
  8304.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  8305.            return $this->redirectToRoute('security_login');
  8306.         }
  8307.         $em $this->getDoctrine()
  8308.                     ->getManager();
  8309.                     
  8310.         $user $this->getUser();
  8311.         
  8312.         $userBoutique $em->getRepository(UserBoutique::class)
  8313.                         ->findOneBy(
  8314.                             array(
  8315.                             'user' => $user->getId(),
  8316.                             'boutique' => $boutique->getId()
  8317.                             )
  8318.                         );
  8319.         
  8320.         $error '';
  8321.         $success '';
  8322.         if('POST' == $request->getMethod()){
  8323.             if(isset($_FILES['fichier']) && $_FILES['fichier']['error'] == 0)
  8324.             {
  8325.                 
  8326.             
  8327.                 $em->flush();
  8328.                 if ($this->gererFichierMultipleCustomerImportation($_FILES['fichier'], $boutique)){
  8329.                     $success 'success';
  8330.                 } else{
  8331.                     $error 'error';
  8332.                 }
  8333.                 
  8334.             }
  8335.         }
  8336.         
  8337.         return $this->render('admin/import_customers.html.twig', [
  8338.            'boutique' => $boutique,
  8339.            'userBoutique' => $userBoutique,
  8340.            'error' => $error,
  8341.            'success' => $success
  8342.         ]);
  8343.     }
  8344.     
  8345.     /**
  8346.      * @Route("/{slug}/ajout-utilisateur-employe", name="admin_ajout_utilisateur_employe")
  8347.      * @return \Symfony\Component\HttpFoundation\Response
  8348.      */
  8349.     public function ajoutUtilisateurEmployeAction(Request $requestBoutique $boutique)
  8350.     {
  8351.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  8352.            return $this->redirectToRoute('security_login');
  8353.         }
  8354.         $em $this->getDoctrine()
  8355.                     ->getManager();
  8356.                     
  8357.         $droits DroitUtilisateur::getDroits();
  8358.         $userBoutiques $em->getRepository(UserBoutique::class)
  8359.                         ->findBy(
  8360.                             array(
  8361.                                 'boutique' => $boutique->getId(),
  8362.                                 'estParti' => false
  8363.                             )    
  8364.                         );
  8365.         $user $this->getUser();
  8366.         $userBoutique $em->getRepository(UserBoutique::class)
  8367.                         ->findOneBy(
  8368.                             array(
  8369.                             'user' => $user->getId(),
  8370.                             'boutique' => $boutique->getId()
  8371.                             )
  8372.                         );
  8373.         
  8374.         return $this->render('admin/ajout_utilisateur_employe.html.twig', [
  8375.            'boutique' => $boutique,
  8376.            'userBoutiques' => $userBoutiques,
  8377.            'userBoutique' => $userBoutique,
  8378.            'droits' => $droits
  8379.            
  8380.         ]);
  8381.     }
  8382.     /**
  8383.      * @Route("/{slug}/users", name="admin.users")
  8384.      * @return \Symfony\Component\HttpFoundation\Response
  8385.      */
  8386.     public function usersAction(Request $requestBoutique $boutique)
  8387.     {
  8388.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  8389.            return $this->redirectToRoute('security_login');
  8390.         }
  8391.         $em $this->getDoctrine()
  8392.                     ->getManager();
  8393.                     
  8394.         $userBoutiques $em->getRepository(UserBoutique::class)
  8395.                         ->findByBoutique($boutique->getId());
  8396.         $user $this->getUser();
  8397.         $userBoutique $em->getRepository(UserBoutique::class)
  8398.                         ->findOneBy(
  8399.                             array(
  8400.                             'user' => $user->getId(),
  8401.                             'boutique' => $boutique->getId()
  8402.                             )
  8403.                         );
  8404.         
  8405.         return $this->render('admin/users.html.twig', [
  8406.            'boutique' => $boutique,
  8407.            'userBoutiques' => $userBoutiques,
  8408.            'userBoutique' => $userBoutique,
  8409.            
  8410.         ]);
  8411.     }
  8412.     
  8413.     /**
  8414.      * @Route("/{slug}/add-user", name="admin.add_user")
  8415.      * @return \Symfony\Component\HttpFoundation\Response
  8416.      */
  8417.     public function addUserAction(Request $request, \Swift_Mailer $mailerBoutique $boutique)
  8418.     {
  8419.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  8420.            return $this->redirectToRoute('security_login');
  8421.         }
  8422.         $em $this->getDoctrine()
  8423.                     ->getManager();
  8424.                     
  8425.         $userBoutiques $em->getRepository(UserBoutique::class)
  8426.                         ->findByBoutique($boutique->getId());
  8427.         $user $this->getUser();
  8428.         $userBoutique $em->getRepository(UserBoutique::class)
  8429.                         ->findOneBy(
  8430.                             array(
  8431.                             'user' => $user->getId(),
  8432.                             'boutique' => $boutique->getId()
  8433.                             )
  8434.                         );
  8435.         $appName $this->getParameter('app_name');
  8436.         
  8437.     
  8438.         if('POST' == $request->getMethod()){
  8439.             $email $_POST['email'];
  8440.             $role $_POST['role'];
  8441.             
  8442.             $requeteAjoutBoutique  = new RequeteAjoutBoutique;
  8443.             
  8444.             $requeteAjoutBoutique->setRole($role);
  8445.             $requeteAjoutBoutique->setEmail($email);
  8446.             $requeteAjoutBoutique->setBoutique($boutique);
  8447.             
  8448.             $em->persist($requeteAjoutBoutique);
  8449.             $em->flush();
  8450.             
  8451.             //Envoi de mail
  8452.             $message = (new \Swift_Message('Welcome to '.$appName))
  8453.             ->setFrom(['no-reply-myinvoice@assiemail.com'  => $appName])
  8454.             ->setTo([$email])
  8455.             ->setBody(
  8456.                 $this->renderView(
  8457.                 'admin/requete_ajout_boutique_email.html.twig',
  8458.                 [
  8459.                     'appName' => $appName,
  8460.                     'role' => $role,
  8461.                     'boutique' => $boutique
  8462.                 ]
  8463.                 ),
  8464.             'text/html'
  8465.             );
  8466.             
  8467.             $mailer->send($message);
  8468.         }
  8469.         
  8470.         return $this->render('admin/users.html.twig', [
  8471.            'boutique' => $boutique,
  8472.            'userBoutiques' => $userBoutiques,
  8473.            'userBoutique' => $userBoutique
  8474.         ]);
  8475.     }
  8476.     /**
  8477.      * @Route("/{slug}/mon-compte", name="admin_mon_compte")
  8478.      * @return \Symfony\Component\HttpFoundation\Response
  8479.      */
  8480.     public function monCompteAction(Request $requestBoutique $boutique)
  8481.     {
  8482.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  8483.            return $this->redirectToRoute('security_login');
  8484.         }
  8485.         $em $this->getDoctrine()
  8486.                     ->getManager();
  8487.     return $this->render('admin/mon_compte.html.twig', [
  8488.            'boutique' => $boutique,
  8489.            'userBoutiques' => $userBoutiques,
  8490.            'userBoutique' => $userBoutique
  8491.         ]);
  8492.     }
  8493.     /**
  8494.      * @Route("/{slug}/mot-de-passe", name="admin_mot_de_passe")
  8495.      * @return \Symfony\Component\HttpFoundation\Response
  8496.      */
  8497.     public function motDePasseAction(Request $requestUserPasswordHasherInterface $passwordHasherBoutique $boutique)
  8498.     {
  8499.         if(!$this->isGranted('IS_AUTHENTICATED_FULLY')){
  8500.            return $this->redirectToRoute('security_login');
  8501.         }
  8502.         $em $this->getDoctrine()
  8503.                     ->getManager();
  8504.         
  8505.         $user $this->getUser();
  8506.         $error '';
  8507.         $ok_submission '';
  8508.         $error_submission '';
  8509.         $actuel $user->getPassword();
  8510.         $hashed '';
  8511.         if('POST' == $request->getMethod())
  8512.         {
  8513.             $motDePasseActuel $request->request->get('motDePasseActuel');
  8514.             $nouveauMotDePasse $request->request->get('nouveauMotDePasse');
  8515.             
  8516.             $repeterMotDePasse $request->request->get('repeterMotDePasse'); 
  8517.             //$user->setPassword('');
  8518.             //$hashed = $passwordHasher->hashPassword($user, $motDePasseActuel);
  8519.             //if(  $hashed == $user->getPassword()){
  8520.                 $user->setPassword('');
  8521.                 $hashedPassword $passwordHasher->hashPassword($user$nouveauMotDePasse);
  8522.                 $user->setPassword($hashedPassword);
  8523.                 $ok_submission 'Mot de passe changé';
  8524.             //}else{
  8525.             //    $error_submission = 'Ancien mot de passe incorrect';
  8526.             //}
  8527.             //Effacer l'ancien mot de passe
  8528.             
  8529.             
  8530.             $em->flush();
  8531.         }
  8532.         $userBoutique $em->getRepository(UserBoutique::class)
  8533.                             ->findOneBy(
  8534.                                 array(
  8535.                                     'user' => $user,
  8536.                                     'boutique' => $boutique
  8537.                                 )
  8538.                             );
  8539.     return $this->render('admin/mot_de_passe.html.twig', [
  8540.            'boutique' => $boutique,
  8541.            'userBoutique' => $userBoutique,
  8542.            'ok_submission' => $ok_submission,
  8543.            'error_submission' => $error_submission,
  8544.            'hashed' => $hashed,
  8545.            'actuel' => $actuel
  8546.         ]);
  8547.     }
  8548.     
  8549.     
  8550.     
  8551.     public function getDomain()
  8552.     {
  8553.         $domaine $_SERVER['HTTP_HOST'];
  8554.         $protocol '';
  8555.         if($domaine == 'localhost' || $domaine == '127.0.0.1'){
  8556.             $domaine $domaine.'/myinvoice-def/public';
  8557.         }
  8558.         if(!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off'){
  8559.             $protocol 'https://';
  8560.         } else{
  8561.             $protocol 'http://';
  8562.         }
  8563.         
  8564.         return $protocol.$domaine;
  8565.     }
  8566.     
  8567.     public function getNumero($type$boutique)
  8568.     {
  8569.         $numero '';
  8570.         $em $this->getDoctrine()
  8571.                     ->getManager();
  8572.         $nombre 0;
  8573.         if($type == 'deposit'){
  8574.             $nombre $em->getRepository(FactureAcompte::class)
  8575.                     ->getNumero($type$boutique->getId());
  8576.         } else{
  8577.             $nombre $em->getRepository(Commande::class)
  8578.                     ->getNumero($type$boutique->getId());
  8579.         
  8580.         }
  8581.         if(empty($nombre)){
  8582.             $nombre ;
  8583.         } else {
  8584.             $nombre = (int)$nombre[0]['nombre'];
  8585.             $nombre++;
  8586.         }
  8587.         
  8588.         
  8589.         
  8590.         switch($type){
  8591.             case 'invoice':
  8592.                 $numero .= $boutique->getSettings()->getLettreDebutFacture();
  8593.             break;
  8594.             
  8595.             case 'deposit':
  8596.                 $numero .= $boutique->getSettings()->getLettreDebutFactureAcompte();
  8597.             break;
  8598.             case 'bill_credit':
  8599.                 $numero .= $boutique->getSettings()->getLettreDebutFactureAvoir();
  8600.             break;
  8601.             
  8602.             case 'proposal':
  8603.                 $numero .= $boutique->getSettings()->getLettreDebutDevis();
  8604.             break;
  8605.         }
  8606.         
  8607.         if($boutique->getSettings()->getIncluAnnee()){
  8608.             $numero .= date('y');
  8609.         }
  8610.         
  8611.         $nombreDeZeroAAjouter strlen((string)$nombre);
  8612.         
  8613.         $nombreDeZeroAAjouter =  $boutique->getSettings()->getNombreDeChiffre() - $nombreDeZeroAAjouter;
  8614.         
  8615.         for($i 0$i $nombreDeZeroAAjouter$i++){
  8616.             $numero .= '0';
  8617.         }
  8618.         
  8619.         $numero .= $nombre;
  8620.         
  8621.         return $numero;
  8622.         
  8623.     }
  8624.     
  8625.     function intervalleMois($datestr)
  8626.     {
  8627.        date_default_timezone_set (date_default_timezone_get());
  8628.         $dt strtotime ($datestr);
  8629.        return array (
  8630.          "debut" => date ('Y-m-d'strtotime ('first day of this month'$dt)),
  8631.          "fin" => date ('Y-m-d'strtotime ('last day of this month'$dt))
  8632.        );
  8633.     }
  8634.     function intervalleSemaine($datestr) {
  8635.        date_default_timezone_set (date_default_timezone_get());
  8636.        $dt strtotime ($datestr);
  8637.        return array (
  8638.          "debut" => date ('N'$dt) == date ('Y-m-d'$dt) : date ('Y-m-d'strtotime ('last monday'$dt)),
  8639.          "fin" => date('N'$dt) == date ('Y-m-d'$dt) : date ('Y-m-d'strtotime ('next sunday'$dt))
  8640.        );
  8641.     }
  8642.     
  8643.     public function gererFichierMultipleImportation($data$boutique)
  8644.     {        
  8645.             $leRetour false;
  8646.             $em $this->getDoctrine()->getManager();
  8647.             
  8648.             $ex pathinfo($data['name'])['extension'];
  8649.             $exA = array('csv');
  8650.             
  8651.             if (in_array(strtolower($ex), $exA)){
  8652.             } else{
  8653.                 throw new \RuntimeException('Désolé, vous n\'avez pas le droit de télécharger ce type de fichier: '.$ex);
  8654.             }
  8655.             
  8656.             $name time();
  8657.             $namePourRepertoire $name;
  8658.             //hydratation des attributs de l'objet
  8659.             $domaine $_SERVER['HTTP_HOST'];
  8660.             $protocol '';
  8661.             if(!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off'){
  8662.                 $protocol 'https://';
  8663.             } else{
  8664.                 $protocol 'http://';
  8665.             }
  8666.             
  8667.             //$url = $protocol.$domaine.'myinvoice-def/uploads/img/'.$name.'.'.$ex;
  8668.             //$url = $protocol.$domaine.'/uploads/img/'.$name.'.'.$ex;
  8669.             $url $boutique->getLogo()->getUploadRootDir().'/'.$name.'.'.$ex;
  8670.             
  8671.             //deplacement (création de l'image original)
  8672.             //$this->file->move($photo->getUploadRootDir().'/original/', $name.'.'.photo->getExtension()));
  8673.             
  8674.             
  8675.             if(!is_dir($boutique->getLogo()->getUploadRootDir()) && !mkdir($boutique->getLogo()->getUploadRootDir(), 0777true))
  8676.             {
  8677.                 throw new \RuntimeException('Impossible de créer le dossier de destination');
  8678.             }
  8679.             
  8680.             if (!move_uploaded_file($data['tmp_name'], $boutique->getLogo()->getUploadRootDir().'/'.$name.'.'.$ex))
  8681.             {
  8682.                 throw new \RuntimeException('Désolé, une erreur s\'est produite.');
  8683.             }
  8684.             
  8685.             $fileToHandle fopen($url'r');
  8686.             $row 1;
  8687.             while (($data fgetcsv($fileToHandle10000",")) !== false) {
  8688.                 $num count($data);
  8689.                 //echo "<p> $num champs à la ligne $row: <br /></p>\n";
  8690.                 $row++;
  8691.                 $categorie $data[0];
  8692.                 $categorieProduit $em->getRepository(CategorieProduit::class)
  8693.                                 ->findOneByNom($categorie);
  8694.                 if(null == $categorieProduit){
  8695.                     $categorieProduit = new CategorieProduit;
  8696.                     $categorieProduit->setNom($categorie);
  8697.                     $em->persist($categorieProduit);
  8698.                     $em->flush();
  8699.                 }
  8700.                 
  8701.                 $ref             $data[1];
  8702.                 $nomProd         $data[2];
  8703.                 $prix            $data[3];
  8704.                 $stockDisponible $data[4];
  8705.                 $stockDAlerte    $data[5];
  8706.                 $stockDeSecurite $data[6];
  8707.                 $stockMinimum    $data[7];
  8708.                 $stockMaximum    $data[8];
  8709.                 $stockOutil      $data[9];
  8710.                 $coutDeStockage  $data[10];
  8711.                 
  8712.                 $produit $em->getRepository(Produit::class)
  8713.                                 ->findOneBy(
  8714.                                     array(
  8715.                                         'reference' => $ref,
  8716.                                         'nom' => $nomProd
  8717.                                     )
  8718.                                 );
  8719.                 if(null == $produit){
  8720.                     $produit = new Produit;
  8721.                     $produit->setCategorieProduit($categorieProduit);
  8722.                     $produit->setReference($ref);
  8723.                     $produit->setNom($nomProd);
  8724.                     
  8725.                     $prixActuel = new PrixProduit;
  8726.                     $prixActuel->setValeur($prix);
  8727.                     $produit->addPrix($prixActuel);
  8728.                     $produit->setPrixActuel($prixActuel);
  8729.                     $produit->setStockDisponible($stockDisponible);
  8730.                     $produit->setStockDAlerte($stockDAlerte);
  8731.                     $produit->setStockDeSecurite($stockDeSecurite);
  8732.                     $produit->setStockMinimum($stockMinimum);
  8733.                     $produit->setStockMaximum($stockMaximum);
  8734.                     $produit->setStockOutil($stockOutil);
  8735.                     $produit->setCoutDeStockage($coutDeStockage);
  8736.                     
  8737.                     $produit->setBoutique($boutique);
  8738.                     $em->persist($produit);
  8739.                     $em->flush();
  8740.                 }
  8741.                 
  8742.                 
  8743.             }
  8744.             $leRetour true;
  8745.             fclose($fileToHandle);
  8746.             
  8747.             //$this->getDoctrine()->getManager()->flush();
  8748.             
  8749.         return $leRetour;
  8750.     }
  8751.     public function gererFichierMultiple($anyObject$data)
  8752.     {
  8753.         $nbFichier 0
  8754.         
  8755.             $tableauFichier $this->reArrayFiles($data);
  8756.             //var_dump($tableauFichier);
  8757.             $i 0;
  8758.             foreach ($tableauFichier as $file)
  8759.             {
  8760.                 $i++;
  8761.             //print 'File Name: ' . $file['name'];
  8762.             //print 'File Type: ' . $file['type'];
  8763.             //print 'File Size: ' . $file['size'];
  8764.         
  8765.             
  8766.                 $photo = new VisitePhoto;
  8767.                 $photo->setFile($file);
  8768.                 
  8769.                 
  8770.                 
  8771.                 $ex pathinfo($file['name'])['extension'];
  8772.                 $exA = array('jpg''jpeg''png''gif''webp''svg');
  8773.                 
  8774.                 if (in_array(strtolower($ex), $exA)){
  8775.                 
  8776.                     $photo->setExtension($ex);
  8777.                 } else {
  8778.                     throw new \RuntimeException('Désolé, vous n\'avez pas le droit de télécharger ce type de fichier: '.$ex);
  8779.                 }
  8780.                 
  8781.                 $name $anyObject->getId().$i.time();
  8782.                 $namePourRepertoire $name;
  8783.                 //hydratation des attributs de l'objet
  8784.                 $photo->setUrl($name.'.'.$photo->getExtension());
  8785.                 $photo->setAlt('Image de '.$anyObject->getNom());
  8786.                 $fromSecure 'http://';
  8787.                         if( isset($_SERVER['HTTPS'] ) ){
  8788.                             $fromSecure 'https://';
  8789.                         }
  8790.                 $host $_SERVER['HTTP_HOST'];
  8791.                 var_dump($host);
  8792.                 if($host == '127.0.0.1'){
  8793.                     $host .= '/myinvoice-def/public';
  8794.                 }
  8795.                 $photo->setUrl($fromSecure.$host.'/'.$photo->getUploadDir().'/original/'.$photo->getUrl());
  8796.                     
  8797.                 //deplacement (création de l'image original)
  8798.                 //$this->file->move($photo->getUploadRootDir().'/original/', $name.'.'.photo->getExtension()));
  8799.                 
  8800.                 $anyObject->addPhoto($photo);
  8801.                 if(!is_dir($photo->getUploadRootDir().'/original/') && !mkdir($photo->getUploadRootDir().'/original'0777true))
  8802.                 {
  8803.                     throw new \RuntimeException('Impossible de créer le dossier de destination');
  8804.                 }
  8805.                 
  8806.                 if (!move_uploaded_file($file['tmp_name'], $photo->getUploadRootDir().'/original/'.$name.'.'.$photo->getExtension()))
  8807.                 {
  8808.                     throw new \RuntimeException('Désolé, une erreur s\'est producte.');
  8809.                 }
  8810.                 $this->getDoctrine()->getManager()->persist($photo);
  8811.         }
  8812.         
  8813.         $this->getDoctrine()->getManager()->flush();
  8814.         
  8815.     }
  8816.     public function reArrayFiles($file_post)
  8817.     {
  8818.         $file_ary = array();
  8819.         $file_count count($file_post['name']);
  8820.         $file_keys array_keys($file_post);
  8821.         for ($i=0$i<$file_count$i++)
  8822.         {
  8823.             foreach ($file_keys as $key)
  8824.             {
  8825.                 $file_ary[$i][$key] = $file_post[$key][$i];
  8826.             }
  8827.         }
  8828.         return $file_ary;
  8829.     }
  8830.     
  8831.     public function gererFichierMultipleCustomerImportation($data$boutique)
  8832.     {        
  8833.             $leRetour false;
  8834.             $em $this->getDoctrine()->getManager();
  8835.             
  8836.             $ex pathinfo($data['name'])['extension'];
  8837.             $exA = array('csv');
  8838.             
  8839.             if (in_array(strtolower($ex), $exA)){
  8840.             } else{
  8841.                 throw new \RuntimeException('Désolé, vous n\'avez pas le droit de télécharger ce type de fichier: '.$ex);
  8842.             }
  8843.             
  8844.             $name time();
  8845.             $namePourRepertoire $name;
  8846.             //hydratation des attributs de l'objet
  8847.             $domaine $_SERVER['HTTP_HOST'];
  8848.             $protocol '';
  8849.             if(!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off'){
  8850.                 $protocol 'https://';
  8851.             } else{
  8852.                 $protocol 'http://';
  8853.             }
  8854.             
  8855.             //$url = $protocol.$domaine.'myinvoice-def/uploads/img/'.$name.'.'.$ex;
  8856.             //$url = $protocol.$domaine.'/uploads/img/'.$name.'.'.$ex;
  8857.             $url $boutique->getLogo()->getUploadRootDir().'/'.$name.'.'.$ex;
  8858.             
  8859.             //deplacement (création de l'image original)
  8860.             //$this->file->move($photo->getUploadRootDir().'/original/', $name.'.'.photo->getExtension()));
  8861.             
  8862.             
  8863.             if(!is_dir($boutique->getLogo()->getUploadRootDir()) && !mkdir($boutique->getLogo()->getUploadRootDir(), 0777true))
  8864.             {
  8865.                 throw new \RuntimeException('Impossible de créer le dossier de destination');
  8866.             }
  8867.             
  8868.             if (!move_uploaded_file($data['tmp_name'], $boutique->getLogo()->getUploadRootDir().'/'.$name.'.'.$ex))
  8869.             {
  8870.                 throw new \RuntimeException('Désolé, une erreur s\'est produite.');
  8871.             }
  8872.             
  8873.             $fileToHandle fopen($url'r');
  8874.             $row 1;
  8875.             while (($data fgetcsv($fileToHandle10000",")) !== false) {
  8876.                 $num count($data);
  8877.                 $row++;
  8878.                 
  8879.                 $nomClient    $data[0];
  8880.                 $adresse      $data[1];
  8881.                 $codePostal   $data[2];
  8882.                 $nomPays      $data[3];
  8883.                 $ville        $data[4];
  8884.                 $email        $data[5];
  8885.                 $telephone    $data[6];
  8886.                 $soumisALaTVA $data[7];
  8887.                 $codeTVA      $data[8];
  8888.                 
  8889.                 $tier $em->getRepository(Tiers::class)
  8890.                                 ->findOneBy(
  8891.                                     array(
  8892.                                     'boutique' => $boutique->getId(),
  8893.                                     'nom' => $nomClient
  8894.                                     )
  8895.                                 );
  8896.                 if(null == $tier){
  8897.                     $tier = new Tiers;
  8898.                     $tier->setNom($nomClient);
  8899.                     $tier->setAdresse($adresse);
  8900.                     $tier->setCodePostal($codePostal);
  8901.                     $tier->setEmail($email);
  8902.                     $tier->setTelephone($telephone);
  8903.                     $tier->setVille($ville);
  8904.                     $tier->setAssujettiALaTVA($soumisALaTVA);
  8905.                     $tier->setCodeTVA($codeTVA);
  8906.                     
  8907.                     $pays $em->getRepository(Pays::class)
  8908.                                 ->findOneBy(
  8909.                                     array(
  8910.                                     'nom' => $nomPays
  8911.                                     )
  8912.                                 );
  8913.                     if (null == $pays){
  8914.                         $pays $em->getRepository(Pays::class)
  8915.                                 ->findOneBy(
  8916.                                     array(
  8917.                                     'nomFr' => $nomPays
  8918.                                     )
  8919.                                 );
  8920.                         if(null == $pays){
  8921.                             $pays = new Pays;
  8922.                             $pays->setNom($nomPays);
  8923.                             $em->persist($pays);
  8924.                             $em->flush();
  8925.                         }
  8926.                     }
  8927.                     
  8928.                     $tier->setPays($pays);
  8929.                     $tier->setBoutique($boutique);
  8930.                     $em->persist($tier);
  8931.                     $em->flush();
  8932.                 }    
  8933.             }
  8934.             $leRetour true;
  8935.             fclose($fileToHandle);
  8936.             
  8937.             //$this->getDoctrine()->getManager()->flush();
  8938.             
  8939.         return $leRetour;
  8940.     }
  8941.     public function getMois()
  8942.     {
  8943.         $mois = array(
  8944.             array(
  8945.                 'index' => 1,
  8946.                 'nom' => 'Janvier'
  8947.             ),
  8948.             array(
  8949.                 'index' => 2,
  8950.                 'nom' => 'Février'
  8951.             ),
  8952.             array(
  8953.                 'index' => 3,
  8954.                 'nom' => 'Mars'
  8955.             ),
  8956.             array(
  8957.                 'index' => 4,
  8958.                 'nom' => 'Avril'
  8959.             ),
  8960.             array(
  8961.                 'index' => 5,
  8962.                 'nom' => 'Mai'
  8963.             ),
  8964.             array(
  8965.                 'index' => 6,
  8966.                 'nom' => 'Juin'
  8967.             ),
  8968.             array(
  8969.                 'index' => 7,
  8970.                 'nom' => 'Juillet'
  8971.             ),
  8972.             array(
  8973.                 'index' => 8,
  8974.                 'nom' => 'Août'
  8975.             ),
  8976.             array(
  8977.                 'index' => 9,
  8978.                 'nom' => 'Septembre'
  8979.             ),
  8980.             array(
  8981.                 'index' => 10,
  8982.                 'nom' => 'Octobre'
  8983.             ),
  8984.             array(
  8985.                 'index' => 11,
  8986.                 'nom' => 'Novembre'
  8987.             ),
  8988.             array(
  8989.                 'index' => 12,
  8990.                 'nom' => 'Décembre'
  8991.             ),
  8992.         );
  8993.         return $mois;
  8994.     }
  8995.     public function getAnnee()
  8996.     {
  8997.         $actuel date('Y');
  8998.         $annees = array();
  8999.         for($i $actuel$i >= 2020$i--){
  9000.             array_push($annees$i);
  9001.         }
  9002.         return $annees;
  9003.     }
  9004. }