src/Controller/AdminController.php line 412

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