<?php
namespace App\Controller\GestionComerciale;
use App\Entity\Articles\Article;
use App\Entity\Clients\Client;
use App\Entity\FO\Societe;
use App\Entity\GestionComerciale\ArticleCommande;
use App\Entity\GestionComerciale\BonPreparation;
use App\Entity\GestionComerciale\Commande;
use App\Entity\GestionComerciale\CommandeFournisseur;
use App\Entity\GestionComerciale\StatutCommande;
use App\Model\GestionCommerciale\TypeDocumentCommercial;
use App\Form\GestionComerciale\BonPreparationType;
use App\Form\GestionComerciale\CommandeType;
use App\Library\Datatable\Util\Datatable;
use App\Security\Voter\EntityVoter;
use App\Service\GestionComerciale\AcompteService;
use App\Service\GestionComerciale\BonLivraisonService;
use App\Service\GestionComerciale\BonPreparationService;
use App\Service\GestionComerciale\CommandeService;
use App\Service\Utilisateur\ColonneTableauService;
use Doctrine\ORM\EntityManagerInterface;
use Knp\Snappy\Pdf;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\JsonResponse;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\Validator\Validator\ValidatorInterface;
use Symfony\Contracts\Translation\TranslatorInterface;
class BonPreparationController extends AbstractController
{
/**
* @Route("/vente/bons-preparations/nouveau/{id}/{type}", name="dtc_bon_preparation_ajouter")
*/
public function ajouterAction(Request $request, $id, $type = "", EntityManagerInterface $em, BonPreparationService $bonPreparationService, TranslatorInterface $translator,
ValidatorInterface $validator
) {
$titre_modal = $translator->trans("Nouveau bon de préparation");
$forceQteDispo = $request->query->get('forceQteDispo');
$repo_objet = $em->getRepository(Commande::class);
$objet = $repo_objet->find($id);
$bonPrepa = clone $objet;
$bonPrepa->setDateBon(new \Datetime);
$bonPrepa->setDate(new \Datetime);
$user = $this->getUser();
//$bonPrepa->setUtilisateur($user);
if (is_object($bonPrepa->getUtilisateur()) && ! empty($this->getParameter('utilisateur_site_internet')) && $bonPrepa->getUtilisateur()->getId(
) == $this->getParameter('utilisateur_site_internet')) {
} else {
//$bonPrepa->setUtilisateur($user);
}
$bonPrepa->setModifiable(false);
$form = $this->createForm(BonPreparationType::class, $bonPrepa);
$errors = "";
$form->handleRequest($request);
$idsArticleCommande = $request->query->get('choixArticles');
$repo_objet = $em->getRepository(Commande::class);
$objet = $repo_objet->find($id);
$bonPrepa->setCommande($objet);
$link = $this->generateUrl('dtc_bon_preparation_ajouter', ['id' => $objet->getId(), 'type' => 'commande']);
//$articleCommande = $em->getRepository(ArticleCommande::class)->listeArticleCommandeSelectionne($idsArticleCommande);
$articleCommande = $objet->getArticleCommande();
if ($form->isSubmitted()) {
if ($form->isValid()) {
/*$articles = array('idArticleCommande'=>$request->request->get('idArticleCommande'),'quantiteInit'=>$request->request->get('quantiteInit'),'quantite'=>$request->request->get('quantite'));
$valeurs = array("articles"=>$articles);
$bonPreparationService->sauvegarder($bonPrepa,$valeurs);
*/
$em->persist($bonPrepa);
$em->flush();
$em->refresh($bonPrepa);
$operation = $request->request->get('operation');
$articles = [
'valider' => $request->request->get('valider'),
'ids' => $request->request->get('ids'),
'idArticleCommande' => $request->request->get('idArticleCommande'),
'idArticleCommandeOrigine' => $request->request->get('idArticleCommandeOrigine'),
'montantRemise' => $request->request->get('montantRemise'),
'remiseCalcule' => $request->request->get('remiseCalcule'),
'remise' => $request->request->get('remise'),
'commentaire' => $request->request->get('commentaire'),
'commentairePrive' => $request->request->get('commentairePrive'),
'remiseSuppl' => $request->request->get('remiseSuppl'),
'ecocontribution' => $request->request->get('ecocontribution'),
'prix' => $request->request->get('prix'),
//'fraisPortLigne'=>$request->request->get('fraisPortLigne'),
'libellesSecondaires' => $request->request->get('libellesSecondaires'),
'libelles' => $request->request->get('libelles'),
'tva' => $request->request->get('tva'),
'qte' => $request->request->get('qte'),
'force' => $request->request->get('force'),
'commentaireSuppl' => $request->request->get('commentaireSuppl'),
'emplacement' => $request->request->get('emplacement'),
'nbEmplacement' => $request->request->get('nbEmplacement'),
'position' => $request->request->get('position'),
'articlesCommandeRepris' => $request->request->get('articlesCommandeRepris'),
'qteDispo' => $request->request->get('qteDispo'),
'transporteurs' => $request->request->get('transporteurs'),
'articlesCommandeAssocies' => $request->request->get('articlesCommandeAssocies'),
];
$valeurs = ["articles" => $articles, 'typeDocument' => 'commande', 'operation' => 'commande', 'action' => 'nouveau'];
$bonPreparationService->sauvegarderBon($bonPrepa, $valeurs);
//print_r($valeurs);
$url = $this->generateUrl('dtc_bon_preparation_modifier', ['id' => $bonPrepa->getId(), 'tab' => '', 'forceQteDispo' => true]);
$this->addFlash(
'notice',
$translator->trans('Bon de préparation ajouté avec succès !')
);
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url]);
} else {
$errors = $validator->validate($bonPrepa);
$rendu = $this->renderView(
'GestionComerciale/BonPreparation/ajouter.html.twig',
[
'form' => $form->createView(),
'errors' => $errors,
'id' => $id,
'type' => $type,
'articleCommande' => $articleCommande,
'commande' => $objet,
'idsArticleCommande' => $idsArticleCommande,
]
);
return new JsonResponse(['rendu' => $rendu, 'valide' => '0', 'url' => '', 'titre' => $titre_modal]);
}
}
$rendu = $this->renderView(
'GestionComerciale/BonPreparation/ajouter.html.twig',
[
'form' => $form->createView(),
'errors' => $errors,
'id' => $id,
'type' => $type,
'articleCommande' => $articleCommande,
'commande' => $objet,
'idsArticleCommande' => $idsArticleCommande,
'forceQteDispo' => $forceQteDispo,
]
);
return new JsonResponse(['rendu' => $rendu, 'valide' => '0', 'url' => '', 'link' => $link, 'titre' => $titre_modal]);
}
/**
* @Route("/vente/bons-preparations/modifier/{id}", name="dtc_bon_preparation_modifier")
*/
public function modifierAction(Request $request, Commande $bon, EntityManagerInterface $em, BonPreparationService $bonService,
CommandeService $commandeService, AcompteService $serviceAcompte, TranslatorInterface $translator, ValidatorInterface $validator
) {
$user = $this->getUser();
//$bon->setUtilisateur($user);
if (is_object($bon->getUtilisateur()) && ! empty($this->getParameter('utilisateur_site_internet')) && $bon->getUtilisateur()->getId() == $this->getParameter(
'utilisateur_site_internet'
)) {
} else {
$bon->setUtilisateur($user);
}
$forceQteDispo = $request->query->get('forceQteDispo');
//print_r($request->request->get('ids'));
$annuler = $request->request->get('annuler');
$sauvegarder = true;
$statutCommande = $bon->getStatutCommande();
if (is_object($statutCommande) && ! in_array($statutCommande->getOrdre(), [1])) {
//à préparer
$annuler = '';
$sauvegarder = false;
}
if ($annuler == "annuler" /*|| $annuler == "annuler_devis" || $annuler == "annuler_cmde"*/) {
$remboursement = 0;
$bonService->annuler($bon, $annuler);
if ($bon->getCommande()->getStatutCommande()->getOrdre() == "0") {
$remboursement = $serviceAcompte->proposerRemboursement($bon->getClient());
}
$this->addFlash('notice', $translator->trans('Bon de préparation annulé avec succès !'));
return $this->redirectToRoute('dtc_commande_modifier', ["id" => $bon->getCommande()->getId(), "r" => $remboursement, "c" => $bon->getClient()->getId()]);
//return $this->redirectToRoute('dtc_bon_preparation_liste',array("r"=>$remboursement,"c"=>$bon->getClient()->getId()));
exit;
}
//if($annuler == "annuler_devis" && $bon->getdevis() != NULL) {
if ($annuler == "annuler_devis") {
$remboursement = 0;
$bonService->annuler($bon, $annuler);
if ($bon->getCommande()->getStatutCommande()->getOrdre() == "0") {
$remboursement = $serviceAcompte->proposerRemboursement($bon->getClient());
}
$this->addFlash('notice', $translator->trans('Bon de préparation annulé avec succès !'));
if (count($bon->getCommande()->getArticleCommande()) > 0) {
return $this->redirectToRoute('dtc_commande_modifier', ["id" => $bon->getCommande()->getId(), "r" => $remboursement, "c" => $bon->getClient()->getId()]);
} else {
//return $this->redirectToRoute('dtc_devis_modifier',array("id"=>$bon->getdevis()->getId(),"r"=>$remboursement,"c"=>$bon->getClient()->getId()));
return $this->redirectToRoute('dtc_commande_liste', ["r" => $remboursement, "c" => $bon->getClient()->getId()]);
}
}
if ($annuler == "annuler_cmde") {
$remboursement = 0;
$bonService->annuler($bon, $annuler);
if ($bon->getCommande()->getStatutCommande()->getOrdre() == "0") {
$remboursement = $serviceAcompte->proposerRemboursement($bon->getClient());
}
$this->addFlash('notice', $translator->trans('Bon de préparation annulé avec succès !'));
$donnees = ["id" => $bon->getCommande()->getId(), "r" => $remboursement];
if (is_object($bon->getClient())) {
$donnees['c'] = $bon->getClient()->getId();
}
return $this->redirectToRoute('dtc_commande_modifier', $donnees);
}
$form = $this->createForm(CommandeType::class, $bon);
$articles = ['ids' => $request->request->get('ids'), 'prix' => $request->request->get('prix'), 'qte' => $request->request->get('qte')];
$valeurs = ["articles" => $articles];
$errors = "";
$form->handleRequest($request);
if ($form->isSubmitted() and $annuler != "annuler" and $annuler != "annuler_devis" and $annuler != "annuler_cmde") {
if ( ! $sauvegarder) {
$this->addFlash('warning', $translator->trans('Le statut de commande actuel ne permet pas cette action!'));
return $this->redirectToRoute('dtc_commande_modifier', ["id" => $bon->getId()]);
} elseif ($commandeService->estEditable($bon)) {
// TODO CHANGE THIS
$droit = $this->isGranted(EntityVoter::UPDATE, BonPreparation::class);
if ( ! $droit) {
return $this->redirectToRoute('dtc_bon_preparation_modifier', ["id" => $bon->getId()]);
}
if ($form->isValid()) {
/*
if($request->request->get('annuler') != '') {
$bonService->annulerCommande($bon);
$this->addFlash(
'notice',
$translator->trans('Bon de préparation annulée avec succès !')
);
return $this->redirectToRoute('dtc_bon_preparation_liste',array());
}
*/
//echo "<div>CC ".$bon->getClient()->getNom()."</div>";
$em->persist($bon);
$em->flush();
$operation = $request->request->get('operation');
$articles = [
'valider' => $request->request->get('valider'),
'ids' => $request->request->get('ids'),
'idArticleCommande' => $request->request->get('idArticleCommande'),
'idArticleCommandeOrigine' => $request->request->get('idArticleCommandeOrigine'),
'montantRemise' => $request->request->get('montantRemise'),
'remiseCalcule' => $request->request->get('remiseCalcule'),
'remise' => $request->request->get('remise'),
'commentaire' => $request->request->get('commentaire'),
'commentairePrive' => $request->request->get('commentairePrive'),
'remiseSuppl' => $request->request->get('remiseSuppl'),
'ecocontribution' => $request->request->get('ecocontribution'),
'prix' => $request->request->get('prix'),
//'fraisPortLigne'=>$request->request->get('fraisPortLigne'),
'libellesSecondaires' => $request->request->get('libellesSecondaires'),
'libelles' => $request->request->get('libelles'),
'tva' => $request->request->get('tva'),
'qte' => $request->request->get('qte'),
'force' => $request->request->get('force'),
'commentaireSuppl' => $request->request->get('commentaireSuppl'),
'emplacement' => $request->request->get('emplacement'),
'emplacement_nouveau' => $request->request->get('emplacement_nouveau'),
'nbEmplacement' => $request->request->get('nbEmplacement'),
'numero_serie' => $request->request->get('numero_serie'),
'duree_garantie' => $request->request->get('duree_garantie'),
'position' => $request->request->get('position'),
'articlesCommandeRepris' => $request->request->get('articlesCommandeRepris'),
'qteDispo' => $request->request->get('qteDispo'),
'transporteurs' => $request->request->get('transporteurs'),
'articlesCommandeAssocies' => $request->request->get('articlesCommandeAssocies'),
'societe_livraison_txt' => $request->request->get('societe_livraison_txt'),
'numero_livraison_txt' => $request->request->get('numero_livraison_txt'),
'rue_livraison_txt' => $request->request->get('rue_livraison_txt'),
'complement_livraison_txt' => $request->request->get('complement_livraison_txt'),
'complement2_livraison_txt' => $request->request->get('complement2_livraison_txt'),
'cp_livraison_txt' => $request->request->get('cp_livraison_txt'),
'ville_livraison_txt' => $request->request->get('ville_livraison_txt'),
'pays_livraison_txt' => $request->request->get('pays_livraison_txt'),
'societe_facturation_txt' => $request->request->get('societe_facturation_txt'),
'numero_facturation_txt' => $request->request->get('numero_facturation_txt'),
'rue_facturation_txt' => $request->request->get('rue_facturation_txt'),
'complement_facturation_txt' => $request->request->get('complement_facturation_txt'),
'complement2_facturation_txt' => $request->request->get('complement2_facturation_txt'),
'cp_facturation_txt' => $request->request->get('cp_facturation_txt'),
'ville_facturation_txt' => $request->request->get('ville_facturation_txt'),
'pays_facturation_txt' => $request->request->get('pays_facturation_txt'),
];
$valeurs = ["articles" => $articles, 'typeDocument' => 'commande', 'operation' => $operation, 'action' => 'modifier'];
$bonService->sauvegarderBon($bon, $valeurs);
//$donnees = array("numeros"=>$request->request->get('numero_serie'),"duree"=>$request->request->get('duree_garantie'));
//$bonService->sauvegarderNumeroSerie($bon,$donnees);
if ($operation == "facture") {
$this->addFlash('notice', $translator->trans('Facture sauvegardée avec succès !'));
$repo_statut_document = $em->getRepository(StatutCommande::class);
//$liste_statut = $repo_statut_document->findOneBy(array("documentCommercial"=>6,"ordre"=>array(1)));
$liste_statut = $repo_statut_document->findById([19, 21, 22]);
//$typesFac = $em->getRepository(TypeDocumentCommercial::class)->findById([6, 7]);
$typesFac = [TypeDocumentCommercial::FACTURE,TypeDocumentCommercial::AVOIR];
$repo_fac = $em->getRepository(Commande::class);
$facture = $repo_fac->findBy(["bp" => $bon, "typeDocumentCommercial" => $typesFac, "visible" => 1], ['id' => 'DESC'], 1, 0);
$temp_type_document_commercial = "";
foreach ($facture as $f) {
$temp_id_fac = $f->getId();
$temp_type_document_commercial = $f->getTypeDocumentCommercial();
}
if (is_object($temp_type_document_commercial) && $temp_type_document_commercial->getId() == 6) {
return $this->redirectToRoute('dtc_facture_afficher', ["id" => $temp_id_fac]);
} else {
return $this->redirectToRoute('dtc_avoir_modifier', ["id" => $temp_id_fac]);
}
} else {
$this->addFlash('notice', $translator->trans('Bon de préparation sauvegardé avec succès !'));
$commandeService->creerHistorique($bon, 2);
return $this->redirectToRoute('dtc_bon_preparation_modifier', ["id" => $bon->getId(), 'forceQteDispo' => true]);
}
} else {
$errors = $validator->validate($bon);
//\Doctrine\Common\Util\Debug::dump($errors);
}
} else {
$paiement = $bon->getStatutPaiement();
$em->refresh($bon);
$bon->setStatutPaiement($paiement);
$em->persist($bon);
$em->flush();
$this->addFlash('notice', $translator->trans('Statut du paiement de la commande modifié avec succès !'));
/*
$this->addFlash(
'warning',
"La commande n'est plus éditable ! "
);
*/
return $this->redirectToRoute('dtc_commande_modifier', ["id" => $bon->getId()]);
}
}
return $this->render(
'GestionComerciale/BonPreparation/modifier2.html.twig',
['form' => $form->createView(), 'errors' => $errors, 'commande' => $bon, 'forceQteDispo' => $forceQteDispo]
);
}
/*
public function modifierAction(Request $request, Commande $bon, EntityManagerInterface $em, TranslatorInterface $translator, ValidatorInterface $validator) {
$request = $request;
$bon->setDateExpedition(new \Datetime);
$form = $this->createForm(new BonPreparationModifierType($em), $bon);
$validator = $validator;
$errors = "";
$form->handleRequest($request);
if ($form->isSubmitted()) {
if ($form->isValid()) {
$bonPreparationService = $this->container->get('dtc.bonpreparation');
$donnees = array("numeros"=>$request->request->get('numero_serie'),"duree"=>$request->request->get('duree_garantie'));
$bonPreparationService->sauvegarderNumeroSerie($bon,$donnees);
$statutService = $this->container->get('dtc.statutcommande');
$mvmtStockService = $this->container->get('dtc.mvtstock');
$statutService->actionSurCommande($bon,$bon->getStatutCommande());
$mvmtStockService->destockerArticleExpedie($bon,$bon->getStatutCommande());
$this->addFlash(
'notice',
$translator->trans('Bon de préparation modifié avec succès !')
);
}
else {
$this->addFlash(
'warning',
$translator->trans("Une erreur est survenue !")
);
}
}
return $this->render('GestionComerciale/BonPreparation/modifier2.html.twig', array('form' => $form->createView(),'errors'=>$errors,'bon'=>$bon));
}
*/
/**
* @Route("/vente/bons-preparations", name="dtc_bon_preparation_liste")
*/
public function listerAction(Request $request, $id = "0", $type = "a", EntityManagerInterface $em, Datatable $datatable, TranslatorInterface $translator,
ColonneTableauService $serviceColonneTableau
) {
$param = $request->query->all();
$repo_objet = $em->getRepository(Commande::class);
$objet = $repo_objet->find($id);
if ($type == "commandeFournisseurBp") {
$repo_objet = $em->getRepository(CommandeFournisseur::class);
$objet = $repo_objet->find($id);
$this->datatableCommandeFournisseurBp($objet, "", $em, $datatable, $translator);
return $this->render('GestionComerciale/BonPreparation/lister_commande_fournisseur_bp.html.twig', ["id" => $id]);
} elseif ($type == "commandeFournisseur") {
$repo_objet = $em->getRepository(CommandeFournisseur::class);
$objet = $repo_objet->find($id);
$this->datatableCommandeFournisseur($objet, "", $em, $datatable, $translator);
return $this->render('GestionComerciale/BonPreparation/lister_commande_fournisseur.html.twig', ["id" => $id]);
} elseif (is_object($objet)) {
$tableau_class_cellule[] = ["className" => "visible_export colonne_id text-center", "targets" => [0], "visible" => true];
$tableau_class_cellule[] = ["className" => "visible_export colonne_id", "targets" => [1], "visible" => true];
$tableau_class_cellule[] = ["className" => "visible_export colonne_id", "targets" => [2], "visible" => true];
$tableau_class_cellule[] = ["className" => "visible_export colonne_id", "targets" => [3], "visible" => true];
$tableau_class_cellule[] = ["className" => "visible_export colonne_id", "targets" => [4], "visible" => true];
$tableau_class_cellule[] = ["className" => "visible_export colonne_id", "targets" => [5], "visible" => true];
$tableau_class_cellule[] = ["className" => "visible_export colonne_id ", "targets" => [6], "visible" => true];
$tableau_class_cellule[] = ["className" => "visible_export colonne_id text-center", "targets" => [7], "visible" => true];
$tableau_class_cellule[] = ["orderable" => false, "className" => "colonne_id", "targets" => [8], "visible" => true];
$repo_objet = $em->getRepository(Commande::class);
$objet = $repo_objet->find($id);
$this->datatableCommande($objet, $type, $em, $datatable, $translator);
return $this->render(
'GestionComerciale/BonPreparation/lister_commande.html.twig',
['tableauClassColonne' => $tableau_class_cellule, "id" => $id, "type" => $type, 'parametres' => $param,]
);
} else {
$tableau_class_cellule[] = ["className" => "colonne_id", "targets" => [0], "visible" => false, "orderable" => false];
$tableau_class_cellule[] = [
"className" => "visible_export colonne_id",
"targets" => [1],
"visible" => $serviceColonneTableau->getColonneUtilisateur(BonPreparation::class, "id"),
];
$tableau_class_cellule[] = [
"className" => "visible_export colonne_id text-center",
"targets" => [2],
"visible" => $serviceColonneTableau->getColonneUtilisateur(BonPreparation::class, "date"),
];
$tableau_class_cellule[] = [
"className" => "visible_export colonne_id",
"targets" => [3],
"visible" => $serviceColonneTableau->getColonneUtilisateur(BonPreparation::class, "reference"),
];
$tableau_class_cellule[] = [
"className" => "visible_export colonne_id",
"targets" => [4],
"visible" => $serviceColonneTableau->getColonneUtilisateur(BonPreparation::class, "refclient"),
];
$tableau_class_cellule[] = [
"className" => "visible_export colonne_id",
"targets" => [5],
"visible" => $serviceColonneTableau->getColonneUtilisateur(BonPreparation::class, "client"),
];
$tableau_class_cellule[] = [
"className" => "visible_export colonne_id",
"targets" => [6],
"visible" => $serviceColonneTableau->getColonneUtilisateur(BonPreparation::class, "equipier"),
];
$tableau_class_cellule[] = [
"className" => "visible_export colonne_id",
"targets" => [7],
"visible" => $serviceColonneTableau->getColonneUtilisateur(BonPreparation::class, "commentaire"),
];
$tableau_class_cellule[] = [
"className" => "visible_export colonne_id",
"targets" => [8],
"visible" => $serviceColonneTableau->getColonneUtilisateur(BonPreparation::class, "refCli"),
];
$tableau_class_cellule[] = [
"className" => "visible_export colonne_id text-center",
"targets" => [9],
"visible" => $serviceColonneTableau->getColonneUtilisateur(BonPreparation::class, "dateBon"),
];
$tableau_class_cellule[] = ["orderable" => false, "className" => "colonne_id", "targets" => [10], "visible" => true];
$this->datatable($request, $em, $datatable, $translator);
return $this->render(
'GestionComerciale/BonPreparation/lister.html.twig',
["id" => $id, "type" => $type, 'tableauClassColonne' => $tableau_class_cellule, 'parametres' => $param]
);
}
}
/**
* set datatable configs
*
* @return \App\Library\Datatable\Util\Datatable
*/
private function datatable(Request $request, EntityManagerInterface $em, Datatable $datatable, TranslatorInterface $translator)
{
$param = $request->query->all();
$repo_statut_document = $em->getRepository(StatutCommande::class);
$liste_statut = $repo_statut_document->findBy(["documentCommercial" => 4, "ordre" => [0]]);
$date = new \Datetime();
$datatable->setDatatableId('dta-bonpreparations')
->setEntity(Commande::class, "x")
->setFields(
[
$translator->trans("ID") => 'x.id',
$translator->trans("Date") => 'x.date',
$translator->trans("Réf") => 'x.reference',
$translator->trans("Réf client") => 'cl.reference',
$translator->trans("Client") => 'cl.nom',
$translator->trans("Équipier") => 'u.reference',
$translator->trans("Comm") => 'x.commentaire',
$translator->trans("Réf cmde cli") => 'x.referenceClient',
$translator->trans("A réaliser pour") => 'x.dateBon',
$translator->trans("Statut") => 's.libelle',
$translator->trans("Actions") => 'x.id',
"_identifier_" => 'x.id',
]
)
->addJoin('x.statutCommande', 's', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.commande', 'c', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.client', 'cl', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.utilisateur', 'u', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
/*->setWhere(
$type_jointure.' = :objet',
array('objet' => $objet)
)
*/
->setRenderers(
[
0 => [
'view' => 'FO/DataTable/avec_lien_edit_route.html.twig',
'params' => [
'edit_route' => 'dtc_bon_preparation_modifier',
],
],
1 => [
'view' => 'FO/DataTable/heure.html.twig',
'params' => [],
],
2 => [
'view' => 'FO/DataTable/avec_lien_edit_route.html.twig',
'params' => [
'edit_route' => 'dtc_bon_preparation_modifier',
],
],
3 => [
'view' => 'FO/DataTable/avec_lien_edit_route.html.twig',
'params' => [
'edit_route' => 'dtc_client_modifier',
'typeDocument' => 'client',
],
],
4 => [
'view' => 'FO/DataTable/client.html.twig',
'params' => [],
],
5 => [
'view' => 'FO/DataTable/avec_lien_edit_route.html.twig',
'params' => [
'edit_route' => 'dtc_utilisateur_modifier',
'typeDocument' => 'equipier',
],
],
8 => [
'view' => 'FO/DataTable/heure.html.twig',
'params' => [],
],
10 => [
'view' => 'FO/DataTable/actions.html.twig',
'params' => [
'edit_route' => 'dtc_bon_preparation_modifier',
//'supprimer_route' => 'dtc_bon_preparation_supprimer',
'pdf_route' => 'dtc_bon_preparation_pdf',
'entite' => 'bonPreparation',
'objet' => Commande::class,
'deplier' => true,
],
],
]
)
->setMultiple(
[
'print' => [
'title' => 'Imprimer',
'route' => 'dtc_bon_preparation_pdf_multiple',
],
]
)
->setOrder("x.id", "desc")
->setSearch(true)
->setSearchFields([2, 3, 4, 5, 7]);
$where = 'x.typeDocumentCommercial = :typeDocumentCommercial AND (x.dateBon IS NULL or x.dateBon <= :dateBon) AND x.visible = :visible AND x.statutCommande NOT IN (:statutCommande)';
$parameters = ['typeDocumentCommercial' => TypeDocumentCommercial::BP, 'dateBon' => $date->format("Y-m-d H:i:s"), 'visible' => true, 'statutCommande' => $liste_statut];
if (array_key_exists('parametres', $param)) {
if (array_key_exists('client', $param["parametres"]) and $param["parametres"]["client"] > 0) {
//$datatable->addJoin('x.client', 'client', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN);
$parameters["client"] = $param["parametres"]["client"];
if ($where != "") {
$where .= " AND ";
}
$where .= "cl.id = :client";
}
if (array_key_exists('client', $param["parametres"]) and $param["parametres"]["date_debut"] != "") {
$param["parametres"]["date_debut"] = \DateTime::createFromFormat('d/m/Y', $param["parametres"]["date_debut"]);
$param["parametres"]["date_debut"]->setTime(00, 00, 00);
$parameters["date_debut"] = $param["parametres"]["date_debut"];
if ($where != "") {
$where .= " AND ";
}
$where .= "x.date >= :date_debut";
}
if (array_key_exists('client', $param["parametres"]) and $param["parametres"]["date_fin"] != "") {
$param["parametres"]["date_fin"] = \DateTime::createFromFormat('d/m/Y', $param["parametres"]["date_fin"]);
$param["parametres"]["date_fin"]->setTime(23, 59, 59);
$parameters["date_fin"] = $param["parametres"]["date_fin"];
if ($where != "") {
$where .= " AND ";
}
$where .= "x.date <= :date_fin";
}
}
if ($where != '') {
$datatable->setWhere($where, $parameters);
}
// echo $where;
return $datatable;
}
/**
* set datatable configs
*
* @return \App\Library\Datatable\Util\Datatable
*/
private function datatableCommande($objet, $type = "", EntityManagerInterface $em, Datatable $datatable, TranslatorInterface $translator)
{
$repo_statut_document = $em->getRepository(StatutCommande::class);
$liste_statut = $repo_statut_document->findBy(["documentCommercial" => 4, "ordre" => [0]]);
$type_jointure = 'x.'.$type;
$datatable->setDatatableId('dta-bonpreparations')
->setEntity(Commande::class, "x")
->setFields(
[
$translator->trans("Date") => 'x.date',
$translator->trans("Réf") => 'x.reference',
$translator->trans("Ref client") => 'cl.reference',
$translator->trans("Client") => 'cl.nom',
$translator->trans("Équipier") => 'u.reference',
$translator->trans("Comm") => 'x.commentaire',
$translator->trans("Ref cmde cli") => 'x.referenceClient',
$translator->trans("A réaliser pour") => 'x.dateBon',
$translator->trans("Actions") => 'x.id',
"_identifier_" => 'x.id',
]
)
//->addJoin('x.pays', 'p', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
/*->setWhere(
$type_jointure.' = :objet',
array('objet' => $objet)
)
*/
->addJoin('x.statutCommande', 's', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.commande', 'c', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.client', 'cl', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.utilisateur', 'u', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->setWhere(
'x.commande = :objet AND x.typeDocumentCommercial = :typeDocumentCommercial AND x.statutCommande NOT IN (:statutCommande)',
['objet' => $objet, 'typeDocumentCommercial' => TypeDocumentCommercial::BP, 'statutCommande' => $liste_statut]
)
->setRenderers(
[
0 => [
'view' => 'FO/DataTable/heure.html.twig',
'params' => [],
],
1 => [
'view' => 'FO/DataTable/avec_lien_edit_route.html.twig',
'params' => [
'edit_route' => 'dtc_bon_preparation_modifier',
],
],
7 => [
'view' => 'FO/DataTable/heure.html.twig',
'params' => [],
],
8 => [
'view' => 'FO/DataTable/actions.html.twig',
'params' => [
'edit_route' => 'dtc_bon_preparation_modifier',
//'supprimer_route' => 'dtc_bon_preparation_supprimer',
'pdf_route' => 'dtc_bon_preparation_pdf',
'entite' => 'bonPreparation',
'objet' => Commande::class,
'deplier' => true,
],
],
]
)
->setOrder("x.date", "desc")
->setSearch(true)//->setSearchFields(array(1,2))
;
return $datatable;
}
/**
* @Route("/vente/bons-preparations/grid/{id}/{type}", name="dtc_bon_preparation_liste_grid")
*/
public function gridAction(Request $request, $id = "", $type = "", EntityManagerInterface $em, Datatable $datatable, TranslatorInterface $translator)
{
$repo_objet = $em->getRepository(Commande::class);
$objet = $repo_objet->find($id);
if (is_object($objet)) {
return $this->datatableCommande($objet, $type, $em, $datatable, $translator)->execute();
} else {
return $this->datatable($request, $em, $datatable, $translator)->execute();
}
}
/**
* @Route("", name="")
*/
public function listerCommandeClientAction(Request $request, Client $client)
{
$options = '';
$cpt = 0;
foreach ($client->getCommandes() as $bonPrepa) {
$selected = "";
//if($cpt == 0) $selected = 'selected="selected"';
$options .= '<option '.$selected.' value="'.$bonPrepa->getId().'">'.$bonPrepa->getLibelle().'</option>';
$cpt++;
}
$referenceCommandeClientObligatoire = $client->getReferenceClientObligatoire();
return new JsonResponse(
['options' => $options, 'valide' => '0', 'referenceClientObligatoire' => $referenceCommandeClientObligatoire]
);
}
/**
* @Route("/bons-preparations-or/pdf/{id}", name="dtc_bon_preparation_or_pdf")
*/
public function pdfBonPreparationOrAction(Request $request, Commande $bonPreparation, $retour = true, EntityManagerInterface $em, Pdf $snappy)
{
$societe = $em->getRepository(Societe::class)->find(1);
$date_Y = date("Y");
$date_M = date("m");
$date_D = date("d");
$date = $date_Y.'/'.$date_M.'/'.$date_D;
$chemin_pdf = 'PDF/BONSPREPA/'.$date.'/BONPREPA-'.$bonPreparation->getReference().'.pdf';
if (file_exists($chemin_pdf)) {
unlink($chemin_pdf);
}
$footer = $this->renderView('FO/PDF/footer_pagination_bp_pdf.html.twig', ['societe' => $societe, 'commande' => $bonPreparation]);
$header = $this->renderView('FO/PDF/header_bpa_pdf.html.twig', ['societe' => $societe, 'commande' => $bonPreparation]);
$snappy->setOption('header-html', $header);
$snappy->setOption('footer-html', $footer);
$snappy->setOption('header-spacing', "4");
$snappy->setOption('footer-spacing', "3");
$snappy->setOption('disable-smart-shrinking', true);
//$snappy->setOption('print-media-type', false );
$snappy->setOption('page-height', "297");
$snappy->setOption('page-width', "210");
$snappy->generateFromHtml(
$this->renderView(
'GestionComerciale/BonPreparationAtelier/template_pdf_2.html.twig',
[
'commande' => $bonPreparation,
'societe' => $societe,
]
),
$chemin_pdf
);
if ($retour == true) {
return $this->render('FO/PDF/conteneur_pdf.html.twig', ['objet' => $bonPreparation, 'chemin_pdf' => '/'.$chemin_pdf]);
}
}
/**
* @Route("/bons-preparations/pdf/{id}", name="dtc_bon_preparation_pdf")
*/
public function pdfBonPreparationAction(Request $request, Commande $bonPreparation, $retour = true, EntityManagerInterface $em, Pdf $snappy)
{
$societe = $em->getRepository(Societe::class)->find(1);
$date_Y = date("Y");
$date_M = date("m");
$date_D = date("d");
$date = $date_Y.'/'.$date_M.'/'.$date_D;
$chemin_pdf = 'PDF/BONSPREPA/'.$date.'/BONPREPA-'.$bonPreparation->getReference().'.pdf';
if (file_exists($chemin_pdf)) {
unlink($chemin_pdf);
}
//return $this->render('GestionComerciale/BonPreparation/template_pdf.html.twig',array('commande' => $bonPreparation,'societe' => $societe));
$footer = $this->renderView('FO/PDF/footer_bp_pagination_pdf.html.twig', ['societe' => $societe, 'commande' => $bonPreparation]);
$header = $this->renderView('FO/PDF/header_bp_pdf.html.twig', ['societe' => $societe, 'commande' => $bonPreparation]);
//$snappy->setOption('page-size', 'A4');
$snappy->setOption('header-html', $header);
$snappy->setOption('footer-html', $footer);
//$snappy->setOption('header-html',$footer);
$snappy->setOption('header-spacing', "4");
$snappy->setOption('footer-spacing', "3");
$snappy->setOption('disable-smart-shrinking', true);
//$snappy->setOption('print-media-type', false );
$snappy->setOption('page-height', "297");
$snappy->setOption('page-width', "210");
$snappy->generateFromHtml(
$this->renderView(
'GestionComerciale/BonPreparation/template_pdf.html.twig',
[
'commande' => $bonPreparation,
'societe' => $societe,
]
),
$chemin_pdf
);
if ($retour == true) {
return $this->render('FO/PDF/conteneur_pdf.html.twig', [
'objet' => $bonPreparation,
'chemin_pdf' => '/'.$chemin_pdf,
'visualiser' => $request->query->get('visualiser'),
]);
//return new RedirectResponse("/".$chemin_pdf);
}
}
/**
* @Route("/vente/bons-preparations/imprimer/multiple", name="dtc_bon_preparation_pdf_multiple")
*/
public function imprimerMultipleAction(Request $request, EntityManagerInterface $em)
{
$data = $request->get('dataTables');
$ids = $data['actions'];
$tableauPdf = [];
$pdfRelier = 'PDF/BONSPREPA/BONPREPA-'.date('d-m-Y').'.pdf';
$date_Y = date("Y");
$date_M = date("m");
$date_D = date("d");
$date = $date_Y.'/'.$date_M.'/'.$date_D;
//$ids = array("118","101","93");
for ($i = 0; $i < count($ids); $i++) {
$repo = $em->getRepository(Commande::class);
$bon = $repo->find($ids[$i]);
if (is_object($bon)) {
$this->pdfBonPreparationAction($bon, false);
$tableauPdf[] = $chemin_pdf = 'PDF/BONSPREPA/'.$date.'/BONPREPA-'.$bon->getReference().'.pdf';
}
}
$cmd = "gs -q -dNOPAUSE -dBATCH -sDEVICE=pdfwrite -sOutputFile=$pdfRelier ";
foreach ($tableauPdf as $file) {
$cmd .= $file." ";
}
$result = shell_exec($cmd);
return new JsonResponse(['target' => '_blank', 'url' => '/'.$pdfRelier, 'valide' => '1']);
}
/**
* set datatable configs
*
* @return \App\Library\Datatable\Util\Datatable
*/
private function datatableCommandeFournisseurBp($objet, $type = "", EntityManagerInterface $em, Datatable $datatable, TranslatorInterface $translator)
{
$articlesCommande = $objet->getArticleCommande();
$articles = [];
if (count($articlesCommande) > 0) {
foreach ($articlesCommande as $articleCommande) {
$articles[] = $articleCommande->getArticle();
}
}
$repo_article = $em->getRepository(Article::class);
//$commandesId = $repo_article->getBpPourCommandeFournisseur($articles,$this->getParameter('article_commentaire'));
$commandesId = $em->getRepository(ArticleCommande::class)->getBpPourCommandeFournisseur($articles, $this->getParameter('article_commentaire'));
$commandes = [];
foreach ($commandesId as $commandeId) {
$commandes[] = $commandeId['id'];
}
//$commandes = array(1668, 1670);
//$commandes=array();
$repo_statut_document = $em->getRepository(StatutCommande::class);
$liste_statut = $repo_statut_document->findBy(["documentCommercial" => 4, "ordre" => [0]]);
$type_jointure = 'x.'.$type;
$datatable->setDatatableId('dta-bonpreparations')
->setEntity(Commande::class, "x")
->setFields(
[
//$translator->trans("ID") => 'x.id',
$translator->trans("Date") => 'x.date',
$translator->trans("Réf") => 'x.reference',
$translator->trans("Ref client") => 'cl.reference',
$translator->trans("Client") => 'cl.nom',
$translator->trans("Équipier") => 'u.reference',
$translator->trans("Comm") => 'x.commentaire',
$translator->trans("Ref cmde cli") => 'x.referenceClient',
$translator->trans("A réaliser pour") => 'x.dateBon',
$translator->trans("Actions") => 'x.id',
"_identifier_" => 'x.id',
]
)
//->addJoin('x.pays', 'p', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
/*->setWhere(
$type_jointure.' = :objet',
array('objet' => $objet)
)
*/
->addJoin('x.statutCommande', 's', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.commande', 'c', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.client', 'cl', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.utilisateur', 'u', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->setWhere(
'x.id IN (:commandes) AND x.typeDocumentCommercial = :typeDocumentCommercial AND x.statutCommande NOT IN (:statutCommande)',
['commandes' => $commandes, 'typeDocumentCommercial' => TypeDocumentCommercial::BP, 'statutCommande' => $liste_statut]
)
->setRenderers(
[
0 => [
'view' => 'FO/DataTable/heure.html.twig',
'params' => [],
],
1 => [
'view' => 'FO/DataTable/avec_lien_edit_route.html.twig',
'params' => [
'edit_route' => 'dtc_bon_preparation_modifier',
],
],
7 => [
'view' => 'FO/DataTable/heure.html.twig',
'params' => [],
],
8 => [
'view' => 'FO/DataTable/actions.html.twig',
'params' => [
'edit_route' => 'dtc_bon_preparation_modifier',
//'supprimer_route' => 'dtc_bon_preparation_supprimer',
'pdf_route' => 'dtc_bon_preparation_pdf',
'entite' => 'bonPreparation',
'objet' => Commande::class,
'deplier' => true,
],
],
]
)
->setOrder("x.date", "desc")
->setSearch(true)//->setSearchFields(array(1,2))
;
return $datatable;
}
/**
* set datatable configs
*
* @return \App\Library\Datatable\Util\Datatable
*/
private function datatableCommandeFournisseur($objet, $type = "", EntityManagerInterface $em, Datatable $datatable, TranslatorInterface $translator)
{
$articlesCommande = $objet->getArticleCommande();
$articles = [];
if (count($articlesCommande) > 0) {
foreach ($articlesCommande as $articleCommande) {
if ($articleCommande->getArticle()->getEstCommentaire() != 1) {
$articles[] = $articleCommande->getArticle();
}
}
}
$repo_article = $em->getRepository(Article::class);
$commandesId = $repo_article->getCommandes($articles);
$commandes = [];
foreach ($commandesId as $commandeId) {
$commandes[] = $commandeId['id'];
}
//$commandes = array(1668, 1670);
$repo_statut_document = $em->getRepository(StatutCommande::class);
$liste_statut = $repo_statut_document->findBy(["documentCommercial" => 4, "ordre" => [0]]);
$type_jointure = 'x.'.$type;
$datatable->setDatatableId('dta-bonpreparations')
->setEntity(Commande::class, "x")
->setFields(
[
//$translator->trans("ID") => 'x.id',
$translator->trans("Date") => 'x.date',
$translator->trans("Réf") => 'x.reference',
$translator->trans("Ref client") => 'cl.reference',
$translator->trans("Client") => 'cl.nom',
$translator->trans("Équipier") => 'u.reference',
$translator->trans("Comm") => 'x.commentaire',
$translator->trans("Ref cmde cli") => 'x.referenceClient',
$translator->trans("A réaliser pour") => 'x.dateBon',
$translator->trans("Actions") => 'x.id',
"_identifier_" => 'x.id',
]
)
//->addJoin('x.pays', 'p', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
/*->setWhere(
$type_jointure.' = :objet',
array('objet' => $objet)
)
*/
->addJoin('x.statutCommande', 's', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.commande', 'c', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.client', 'cl', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->addJoin('x.utilisateur', 'u', \Doctrine\ORM\Query\Expr\Join::LEFT_JOIN)
->setWhere(
'x.commande IN (:commandes) AND x.typeDocumentCommercial = :typeDocumentCommercial AND x.statutCommande NOT IN (:statutCommande)',
['commandes' => $commandes, 'typeDocumentCommercial' => TypeDocumentCommercial::BP, 'statutCommande' => $liste_statut]
)
->setRenderers(
[
0 => [
'view' => 'FO/DataTable/heure.html.twig',
'params' => [],
],
1 => [
'view' => 'FO/DataTable/avec_lien_edit_route.html.twig',
'params' => [
'edit_route' => 'dtc_bon_preparation_modifier',
],
],
7 => [
'view' => 'FO/DataTable/heure.html.twig',
'params' => [],
],
8 => [
'view' => 'FO/DataTable/actions.html.twig',
'params' => [
'edit_route' => 'dtc_bon_preparation_modifier',
//'supprimer_route' => 'dtc_bon_preparation_supprimer',
'pdf_route' => 'dtc_bon_preparation_pdf',
'entite' => 'bonPreparation',
'objet' => Commande::class,
],
],
]
)
->setOrder("x.date", "desc")
->setSearch(true)//->setSearchFields(array(1,2))
;
return $datatable;
}
/**
* Grid action
* @return Response
*/
/**
* @Route("/vente/bons-preparations/commande-fournisseur/grid/{id}", name="dtc_bon_preparation_commande_fournisseur_liste_grid")
*/
public function gridCommandeFournisseurAction(Request $request, $id = "", EntityManagerInterface $em, Datatable $datatable, TranslatorInterface $translator)
{
$repo_objet = $em->getRepository(CommandeFournisseur::class);
$objet = $repo_objet->find($id);
if (is_object($objet)) {
return $this->datatableCommandeFournisseur($objet, "", $em, $datatable, $translator)->execute();
}
}
/**
* Grid action
* @return Response
*/
/**
* @Route("/vente/bons-preparations/commande-fournisseur/bp/grid/{id}", name="dtc_bon_preparation_commande_fournisseur_bp_liste_grid")
*/
public function gridCommandeFournisseurBpAction(Request $request, $id = "", EntityManagerInterface $em, Datatable $datatable, TranslatorInterface $translator)
{
$repo_objet = $em->getRepository(CommandeFournisseur::class);
$objet = $repo_objet->find($id);
if (is_object($objet)) {
return $this->datatableCommandeFournisseurBp($objet, '', $em, $datatable, $translator)->execute();
}
}
/**
* @Route("/vente/bons-preparation/retour-commande/{id}", name="dtc_bon_preparation_retour_commande")
*/
public function retourCommandeAction(Request $request, Commande $bon, EntityManagerInterface $em, BonPreparationService $bonPreparationService,
TranslatorInterface $translator
) {
$titre_modal = $translator->trans("Retour en commande");
$user = $this->getUser();
$errors = "";
$idsArticleCommande = $request->query->get('choixArticles');
$link = $this->generateUrl('dtc_bon_preparation_retour_commande', ['id' => $bon->getId()]);
$articleCommande = $em->getRepository(ArticleCommande::class)->listeArticleCommandeSelectionne($idsArticleCommande);
if ($request->isMethod('POST')) {
$articles = [
'idArticleCommande' => $request->request->get('idArticleCommande'),
'qte' => $request->request->get('qte'),
];
$bonPreparationService->retourCommande($articles, $bon);
$url = $this->generateUrl('dtc_commande_modifier', ['id' => $bon->getCommande()->getId()]);
$this->addFlash(
'notice',
$translator->trans('Retour des articles sur la commande réalisé avec succès !')
);
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url]);
}
$rendu = $this->renderView('GestionComerciale/BonPreparation/retour-commande.html.twig', ['errors' => $errors, 'articleCommande' => $articleCommande, 'commande' => $bon]);
return new JsonResponse(['rendu' => $rendu, 'valide' => '0', 'url' => '', 'link' => $link, 'titre' => $titre_modal]);
}
/**
* @Route("/vente/bons-preparations/nouveau-v2/{id}/{type}", name="dtc_bon_preparation_ajouter_v2")
*/
public function ajouterV2Action(Request $request, $id, $type = "", EntityManagerInterface $em, BonPreparationService $bonPreparationService, CommandeService $commandeService,
TranslatorInterface $translator
) {
$user = $this->getUser();
$idsArticleCommande = $request->request->get('choixArticles');
//$idsArticleCommande = $request->request->all();
//$qtesArticleCommande = $request->request->get('qteDispo');
if (count($idsArticleCommande) > 0) {
$repo_objet = $em->getRepository(Commande::class);
$errors = "";
//$articleCommande = $em->getRepository(ArticleCommande::class)->listeArticleCommandeSelectionne($idsArticleCommande);
$objet = $repo_objet->find($id);
//date de préparation ultérieure
$now = new \Datetime;
if (is_object($objet->getDateBon()) && $objet->getDateBon() > $now) {
$url = $this->generateUrl('dtc_commande_modifier', ['id' => $id, 'forceQteDispo' => false]);
$this->addFlash('warning', 'Cette commande ne peut être passée en BP/BL/Facture/Avoir car elle a une date de préparation au '.$objet->getDateBon()->format('d/m/Y').' !');
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url]);
}
if ($objet->getOrigine() == 'prestashop' && $objet->getValideManuellement() != 1) {
$url = $this->generateUrl('dtc_commande_modifier', ['id' => $id, 'forceQteDispo' => false]);
$this->addFlash(
'warning',
$translator->trans('Cette commande internet doit être validée avant le passage en BP !')
);
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url]);
}
if ($commandeService->estPreparable($objet)) {
$bon = clone $objet;
$bon->setCreateur($user);
$bon->setDateBon(new \DateTime());
$bon->setDate(new \DateTime());
$bon->setCommande($objet);
//$bon->setUtilisateur($user);
if (is_object($bon->getUtilisateur()) && ! empty($this->getParameter('utilisateur_site_internet')) && $bon->getUtilisateur()->getId(
) == $this->getParameter('utilisateur_site_internet')) {
} else {
$bon->setUtilisateur($user);
}
$bon->setModifiable(false);
$em->persist($bon);
$em->flush();
$em->refresh($bon);
//$operation = "commande";
$operation = "";
//$operation = $request->request->get('operation');
$articles = [
'valider' => $request->request->get('valider'),
'ids' => $request->request->get('ids'),
'idArticleCommande' => $request->request->get('idArticleCommande'),
//'idArticleCommandeOrigine'=>$request->request->get('idArticleCommandeOrigine'),
'idArticleCommandeOrigine' => [],
'idArticleCommandeParent' => $request->request->get('idArticleCommandeOrigine'),
'montantRemise' => $request->request->get('montantRemise'),
'remiseCalcule' => $request->request->get('remiseCalcule'),
'remise' => $request->request->get('remise'),
'commentaire' => $request->request->get('commentaire'),
'commentairePrive' => $request->request->get('commentairePrive'),
'remiseSuppl' => $request->request->get('remiseSuppl'),
'ecocontribution' => $request->request->get('ecocontribution'),
'prix' => $request->request->get('prix'),
//'fraisPortLigne'=>$request->request->get('fraisPortLigne'),
'libellesSecondaires' => $request->request->get('libellesSecondaires'),
'libelles' => $request->request->get('libelles'),
'tva' => $request->request->get('tva'),
'qte' => $request->request->get('qte'),
//'qte'=>$request->request->get('qteDispo'),
'commentaireSuppl' => $request->request->get('commentaireSuppl'),
'emplacement' => $request->request->get('emplacement'),
'nbEmplacement' => $request->request->get('nbEmplacement'),
'position' => $request->request->get('position'),
'articlesCommandeRepris' => $request->request->get('articlesCommandeRepris'),
'qteDispo' => $request->request->get('qteDispo'),
'transporteurs' => $request->request->get('transporteurs'),
'articlesCommandeAssocies' => $request->request->get('articlesCommandeAssocies'),
'tabPrixAchatNetEuros' => $request->request->get('tabPrixAchatNetEuros'),
'societe_livraison_txt' => $request->request->get('societe_livraison_txt'),
'numero_livraison_txt' => $request->request->get('numero_livraison_txt'),
'rue_livraison_txt' => $request->request->get('rue_livraison_txt'),
'complement_livraison_txt' => $request->request->get('complement_livraison_txt'),
'complement2_livraison_txt' => $request->request->get('complement2_livraison_txt'),
'cp_livraison_txt' => $request->request->get('cp_livraison_txt'),
'ville_livraison_txt' => $request->request->get('ville_livraison_txt'),
'societe_facturation_txt' => $request->request->get('societe_facturation_txt'),
'numero_facturation_txt' => $request->request->get('numero_facturation_txt'),
'rue_facturation_txt' => $request->request->get('rue_facturation_txt'),
'complement_facturation_txt' => $request->request->get('complement_facturation_txt'),
'complement2_facturation_txt' => $request->request->get('complement2_facturation_txt'),
'cp_facturation_txt' => $request->request->get('cp_facturation_txt'),
'ville_facturation_txt' => $request->request->get('ville_facturation_txt'),
];
$valeurs = ["articles" => $articles, 'typeDocument' => 'commande', 'operation' => 'commande', 'action' => 'nouveau'];
$bonPreparationService->sauvegarderBon($bon, $valeurs);
$url = $this->generateUrl('dtc_bon_preparation_modifier', ['id' => $bon->getId(), 'forceQteDispo' => true]);
$this->addFlash(
'notice',
$translator->trans('Bon de préparation ajouté avec succès !')
);
$commandeService->creerHistorique($bon, 1);
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url]);
} else {
$url = $this->generateUrl('dtc_commande_modifier', ['id' => $id, 'forceQteDispo' => false]);
$this->addFlash(
'warning',
$translator->trans('Cette commande est déjà préparée !')
);
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url]);
}
} else {
return new JsonResponse(
[
'rendu' => '',
'valide' => '0',
'url' => '',
'idsArticleCommande' => $idsArticleCommande,
]
);
}
}
/**
* @Route("/bp/charger-tableau/{id}/{type}", name="dtc_bp_charger_tableau")
*/
public function chargerTableauAction(Request $request, $id, $type = 'commande')
{
$rendu = $this->renderView('GestionComerciale/BonPreparation/charger_tableau.html.twig', ["id" => $id, "type" => $type]);
return new JsonResponse(['rendu' => $rendu]);
}
}