src/Controller/AdminController.php line 8246

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