<?php
namespace App\Controller\Localisation;
use App\Entity\Localisation\SecteurGeographique;
use App\Entity\Utilisateur\Utilisateur;
use App\Entity\Utilisateur\UtilisateurZoneGeographique;
use App\Form\Localisation\SecteurGeographiqueType;
use App\Form\Localisation\SupprimerSecteurGeographiqueType;
use App\Library\Datatable\Util\Datatable;
use App\Security\Voter\EntityVoter;
use App\Service\Utilisateur\ColonneTableauService;
use Doctrine\ORM\EntityManagerInterface;
use JMS\Serializer\SerializerBuilder;
use Knp\Component\Pager\PaginatorInterface;
use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\JsonResponse;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\Routing\Annotation\Route;
use Symfony\Component\Validator\Validator\ValidatorInterface;
use Symfony\Contracts\Translation\TranslatorInterface;
class SecteurGeographiqueController extends AbstractController
{
/**
* @Route("/secteur-geographique/dupliquer/{id}", name="dtc_secteur_geographique_dupliquer")
*/
public function dupliquerAction(Request $request, SecteurGeographique $secteurGeographique, EntityManagerInterface $em, TranslatorInterface $translator)
{
$secteurGeographique_duplique = clone $secteurGeographique;
$secteurGeographique_duplique->setLibelle("COPIE ".$secteurGeographique_duplique->getLibelle());
$em->persist($secteurGeographique_duplique);
$em->flush();
$this->addFlash('notice', $translator->trans('Secteur géographique dupliquée avec succès !'));
return $this->redirectToRoute('dtc_secteur_geographique_liste');
}
/**
* @Route("/secteur-geographique/nouveau", name="dtc_secteur_geographique_ajouter")
*/
public function ajouterAction(Request $request, EntityManagerInterface $em, TranslatorInterface $translator, ValidatorInterface $validator)
{
$titre_modal = $translator->trans("Nouveau secteur géographique");
$get = $request->query->all();
$secteurGeographique = new SecteurGeographique();
$user = $this->getUser();
$form = $this->createForm(SecteurGeographiqueType::class, $secteurGeographique);
$errors = "";
$form->handleRequest($request);
if ($form->isSubmitted()) {
if ($form->isValid()) {
$url = "";
$em->persist($secteurGeographique);
$em->flush();
if (array_key_exists('table', $get) && $get["table"] != "") {
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url, 'type' => 'recharger_datatable', 'id_datatable' => $get["table"]]);
} else {
$this->addFlash('notice', $translator->trans('Nouveau secteur géographique ajouté avec succès !'));
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url]);
}
} else {
$errors = $validator->validate($secteurGeographique);
$rendu = $this->renderView(
'Localisation/SecteurGeographique/ajouter.html.twig',
['form' => $form->createView(), 'errors' => $errors, 'secteurGeographique' => $secteurGeographique]
);
return new JsonResponse(['rendu' => $rendu, 'valide' => '0', 'url' => '', 'titre' => $titre_modal]);
}
}
$rendu = $this->renderView(
'Localisation/SecteurGeographique/ajouter.html.twig',
['form' => $form->createView(), 'errors' => $errors, 'secteurGeographique' => $secteurGeographique]
);
return new JsonResponse(['rendu' => $rendu, 'valide' => '0', 'url' => '', 'titre' => $titre_modal]);
}
/**
* @Route("/secteur-geographique/supprimer/multiple", name="dtc_secteur_geographique_liste_supprimer")
*/
public function supprimerMultipleAction(Request $request, EntityManagerInterface $em, TranslatorInterface $translator)
{
$url = $this->generateUrl('dtc_secteur_geographique_liste', []);
return new JsonResponse(['url' => $url, 'valide' => '1']);
$data = $request->get('dataTables');
$ids = $data['actions'];
$repo = $em->getRepository(SecteurGeographique::class);
for ($i = 0; $i < count($ids); $i++) {
$v = $repo->find($ids[$i]);
if (is_object($v)) {
$em->remove($v);
}
}
$em->flush();
$this->addFlash('notice', $translator->trans('Secteurs géographique supprimés avec succès !'));
$url = $this->generateUrl('dtc_secteur_geographique_liste', []);
return new JsonResponse(['url' => $url, 'valide' => '1']);
}
/**
* @Route("/secteur-geographique/supprimer/{id}", name="dtc_secteur_geographique_supprimer")
*/
public function supprimerAction(Request $request, SecteurGeographique $objet, EntityManagerInterface $em, TranslatorInterface $translator, ValidatorInterface $validator)
{
$secteurGeographique = $objet;
$titre_modal = $translator->trans("Demande de confirmation");
$user = $this->getUser();
$get = $request->query->all();
$form = $this->createForm(SupprimerSecteurGeographiqueType::class, $secteurGeographique);
$errors = "";
$form->handleRequest($request);
if ($form->isSubmitted()) {
if ($form->isValid()) {
$em->remove($secteurGeographique);
$em->flush();
$url = "";
if (array_key_exists('table', $get) && $get["table"] != "") {
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url, 'type' => 'recharger_datatable', 'id_datatable' => $get["table"]]);
} else {
$this->addFlash('notice', $translator->trans('Secteur géographique supprimée avec succès !'));
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url]);
}
} else {
$errors = $validator->validate($secteurGeographique);
$rendu = $this->renderView('FO/Supprimer/supprimer.html.twig', ['form' => $form->createView(), 'errors' => $errors]);
return new JsonResponse(['rendu' => $rendu, 'valide' => '0', 'url' => '', 'titre' => $titre_modal]);
}
}
$rendu = $this->renderView('FO/Supprimer/supprimer.html.twig', ['form' => $form->createView(), 'errors' => $errors]);
return new JsonResponse(['rendu' => $rendu, 'valide' => '0', 'url' => '', 'titre' => $titre_modal]);
}
/**
* @Route("/secteur-geographique/modifier/{id}", name="dtc_secteur_geographique_modifier")
*/
public function modifierAction(Request $request, SecteurGeographique $objet, EntityManagerInterface $em, TranslatorInterface $translator,
ValidatorInterface $validator
) {
$secteurGeographique = $objet;
$titre_modal = $translator->trans("Modifier le secteur géographique");
$get = $request->query->all();
$user = $this->getUser();
// $secteurGeographique->setUtilisateur($user);
$form = $this->createForm(SecteurGeographiqueType::class, $secteurGeographique);
$errors = "";
$form->handleRequest($request);
if ($form->isSubmitted()) {
$droit = $this->isGranted(EntityVoter::UPDATE, SecteurGeographique::class);
/*
if(!$droit) {
$rendu = $this->renderView('Localisation/SecteurGeographique/ajouter.html.twig', array('form' => $form->createView(),'errors'=>$errors,'id'=>$id,'type'=>$type,'objet'=>$objet));
return new Response(json_encode(array('rendu'=>$rendu,'valide'=>'0','url'=>'','titre'=>$titre_modal)), 200, array('Content-Type'=>'application/json'));
}
*/
$url = "";
if ($form->isValid()) {
$em->persist($secteurGeographique);
$em->flush();
if (array_key_exists('table', $get) && $get["table"] != "") {
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url, 'type' => 'recharger_datatable', 'id_datatable' => $get["table"]]);
} else {
$this->addFlash('notice', $translator->trans('Secteur géographique modifiée avec succès !'));
return new JsonResponse(['rendu' => '', 'valide' => '1', 'url' => $url]);
}
} else {
$errors = $validator->validate($secteurGeographique);
$rendu = $this->renderView(
'Localisation/SecteurGeographique/ajouter.html.twig',
['form' => $form->createView(), 'errors' => $errors, 'articleAutomatique' => $secteurGeographique]
);
return new JsonResponse(['rendu' => $rendu, 'valide' => '0', 'url' => '', 'titre' => $titre_modal]);
}
}
$rendu = $this->renderView(
'Localisation/SecteurGeographique/ajouter.html.twig',
['form' => $form->createView(), 'errors' => $errors, 'articleAutomatique' => $secteurGeographique]
);
return new JsonResponse(['rendu' => $rendu, 'valide' => '0', 'url' => '', 'titre' => $titre_modal]);
}
/**
* @Route("/secteur-geographique/", name="dtc_secteur_geographique_liste")
*/
public function listerAction(Request $request, ColonneTableauService $serviceColonneTableau, Datatable $datatable, TranslatorInterface $translator)
{
$tableau_class_cellule[] = ["className" => "colonne_id", "targets" => [0], "visible" => false, "orderable" => false];
$tableau_class_cellule[] = [
"className" => "colonne_id",
"targets" => [1],
"visible" => $serviceColonneTableau->getColonneUtilisateur(SecteurGeographique::class, "id"),
];
$tableau_class_cellule[] = [
"orderable" => true,
"className" => "colonne_id",
"targets" => [2],
"visible" => $serviceColonneTableau->getColonneUtilisateur(SecteurGeographique::class, "libelle"),
];
$tableau_class_cellule[] = ["orderable" => false, "className" => "colonne_id", "targets" => [3], "visible" => true];
$this->datatable($datatable, $translator);
return $this->render('Localisation/SecteurGeographique/lister.html.twig', ['tableauClassColonne' => $tableau_class_cellule]);
}
/**
* set datatable configs
*
* @return \App\Library\Datatable\Util\Datatable
*/
private function datatable(Datatable $datatable, TranslatorInterface $translator)
{
$datatable
->setDatatableId('dta-secteur-geographique')
->setEntity(SecteurGeographique::class, "x")
->setFields(
[
$translator->trans("ID") => 'x.id',
$translator->trans("Libellé") => 'x.libelle',
$translator->trans("Actions") => 'x.id',
"_identifier_" => 'x.id',
]
)
->setRenderers(
[
0 => [
'view' => 'FO/DataTable/avec_lien_edit_route.html.twig',
'params' => [
'edit_route' => 'dtc_secteur_geographique_modifier',
],
],
2 => [
'view' => 'FO/DataTable/actions_modal.html.twig',
'params' => [
'edit_route' => 'dtc_secteur_geographique_modifier',
'supprimer_route' => 'dtc_secteur_geographique_supprimer',
'type' => "",
'entite' => 'secteurGeographique',
'table' => 'dta-secteur-geographique',
'objet' => SecteurGeographique::class,
'width_modal' => 800,
],
],
/*
1 => array(
'view' => 'FO/DataTable/edit_texte.html.twig',
'params' => array(
'objet' => 'DTCLocalisationBundle:SecteurGeographique',
'champ' => 'setLibelle',
),
),*/
]
)
->setMultiple(
[
'delete' => [
'title' => $translator->trans('Non disponible'),
'route' => 'dtc_secteur_geographique_liste_supprimer',
],
]
)
->setOrder("x.id", "desc")
->setSearch(true)
->setSearchFields([1]);
//$datatable->setSearchFields(array(0,2));
return $datatable;
}
/**
* Grid action
* @return Response
*/
/**
* @Route("/secteur-geographique/grid", name="dtc_secteur_geographique_liste_grid")
*/
public function gridAction(Request $request, Datatable $datatable, TranslatorInterface $translator)
{
return $this->datatable($datatable, $translator)->execute();
}
//\Doctrine\Common\Util\Debug::dump($tabZonesLivraison);
//\Doctrine\Common\Util\Debug::dump($tabSecteursGeographique);
/**
* @Route("", name="")
*/
public function listerSecteurGeographiqueCheckboxAction(Request $request, $utilisateur = [], EntityManagerInterface $em)
{
$id = '';
$repo_utilisateur = $em->getRepository(Utilisateur::class);
$repo_secteur_geographique = $em->getRepository(SecteurGeographique::class);
$repo_utilisateur_secteur_geographique = $em->getRepository(UtilisateurZoneGeographique::class);
$id = $request->query->get('id');
if ($request->query->get('utilisateur') != '') {
$utilisateur = $repo_utilisateur->find($request->query->get('utilisateur'));
}
$secteursGeographique = $repo_secteur_geographique->getAllSecteurGeographique();
$tabSecteursGeographique = [];
foreach ($secteursGeographique as $c) {
$c['checked'] = 0;
//$c['totalSousCategorie'] = count($repo_secteur_geographique->findBy(array("categorieParent"=>$c)));
//$c['totalSousCategorie'] = 0;
$c['selection'] = 0;
if (is_object($utilisateur) and is_object($repo_utilisateur_secteur_geographique->findOneBy(['utilisateur' => $utilisateur, 'secteurGeographique' => $c]))) {
$c['checked'] = 1;
}
$tabSecteursGeographique[] = $c;
}
$secteursGeographique = $tabSecteursGeographique;
if ($request->isXmlHttpRequest()) {
$rendu = $this->renderView('Localisation/SecteurGeographique/checkbox.html.twig', ['secteursGeographique' => $secteursGeographique, 'utilisateur' => $utilisateur]);
return new JsonResponse(['rendu' => $rendu]);
}
return $this->render('Localisation/SecteurGeographique/checkbox.html.twig', ['secteursGeographique' => $secteursGeographique, 'utilisateur' => $utilisateur]);
}
/**
* @Route("/secteur-geographique/recherche", name="dtc_secteur_geographique_recherche")
*/
public function rechercheAction(Request $request, EntityManagerInterface $em, PaginatorInterface $paginator)
{
$q = $request->query->get('q');
$commercial = $request->query->get('commercial');
$repo = $em->getRepository(SecteurGeographique::class);
$results = $repo->getRechercheSecteurGeographique($q, $commercial);
$pagination = $paginator->paginate(
$results, /* query NOT result */
$request->query->getInt('page', 1)/*page number*/,
10/*limit per page*/
);
$pagination_results = $pagination->getItems();
$option_placeholde = ["libelle" => "Sélectionnez", "id" => ""];
if ($request->query->getInt('page', 1) == 1) {
array_unshift($pagination_results, $option_placeholde);
}
$pagination->setItems($pagination_results);
$serializer = SerializerBuilder::create()->build();
return JsonResponse::fromJsonString($serializer->serialize($pagination, 'json'));
}
}