ninegate/src/cadolesuser-1.0/src/Cadoles/PortalBundle/Controller/PageController.php

310 lines
12 KiB
PHP
Raw Normal View History

2019-03-21 17:15:06 +01:00
<?php
namespace Cadoles\PortalBundle\Controller;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Doctrine\Common\Collections\ArrayCollection;
use Cadoles\PortalBundle\Entity\Page;
use Cadoles\PortalBundle\Form\PageSubmitType;
use Cadoles\PortalBundle\Form\PageUpdateURLType;
use Cadoles\PortalBundle\Form\PageUpdateWidgetType;
use Cadoles\PortalBundle\Form\PageUpdateEditorType;
class PageController extends Controller
{
private $labelentity="CadolesPortalBundle:Page";
private $routeprimary="cadoles_portal_config_page";
public function listAction()
{
return $this->render($this->labelentity.':list.html.twig',[
'useheader' => true,
'usemenu' => false,
'usesidebar' => true,
]);
}
public function ajaxlistAction(Request $request,$access="config")
{
// S'assurer que c'est un appel ajax
if (!$request->isXmlHttpRequest()) {
return new JsonResponse(array('message' => 'Interdit'), 400);
}
$em = $this->getDoctrine()->getManager();
$start=$request->query->get('start');
$length= $request->query->get('length');
$search= $request->query->get('search');
$draw= $request->query->get('draw');
$order= $request->query->get('order');
// Query de base
$qbase=$em->createQueryBuilder()->from($this->labelentity,'table');
$qsearch=$qbase->where('table.id LIKE :value')
->orWhere('table.name LIKE :value')
->setParameter("value", "%".$search["value"]."%");
// Nombre total d'enregistrement
$total = $qbase->select('COUNT(table)')->getQuery()->getSingleScalarResult();
// Nombre d'enregistrement filtré
if($search["value"]=="")
$totalf = $total;
else {
$totalf= $qsearch->select('COUNT(table)')->getQuery()->getSingleScalarResult();
}
// Parcours des Enregistrement
if($search["value"]=="")
$qb = $qbase->select('table');
else
$qb = $qsearch->select('table');
// Order
switch($order[0]["column"]) {
case 1 :
$qb->orderBy('table.roworder',$order[0]["dir"]);
break;
case 2 :
$qb->orderBy('table.name',$order[0]["dir"]);
break;
}
// Execution de la requete d'affichage
$datas=$qb->setFirstResult($start)->setMaxResults($length)->getQuery()->getResult();
// Construction du tableau de retour
$output = array(
'draw' => $draw,
'recordsFiltered' => $totalf,
'recordsTotal' => $total,
'data' => array(),
);
foreach($datas as $data) {
$route=str_replace("_config_","_".$access."_",$this->routeprimary);
$action = "";
//$action.="<a href='".$this->generateUrl($route.'_update', array('id'=>$data->getId()))."'><i class='fa fa-file fa-fw'></i></a>";
$action.="<a href='".$this->generateUrl($route.'_delete', array('id'=>$data->getId()))."' data-method='delete'><i class='fa fa-trash fa-fw'></i></a>";
$action.="<a href='".$this->generateUrl($route.'_view', array('id'=>$data->getId()))."'><i class='fa fa-eye'></i></a>";
array_push($output["data"],array($action,$data->getRoworder(),$data->getName(),$data->getPagecategory()->getName()));
}
// Retour
return new Response(json_encode($output), 200);
}
private function entityForm(Page $entity,$access="config")
{
$route=str_replace("_config_","_".$access."_",$this->routeprimary);
if ($this->getDoctrine()->getManager()->contains($entity)) {
// Type URL
if($entity->getPagecategory()->getId()==1 ) {
return $this->createForm(PageUpdateURLType::class, $entity, [
"mode" => "update",
"access" => $access
]);
}
// Type Widget
elseif($entity->getPagecategory()->getId()==2 ) {
return $this->createForm(PageUpdateWidgetType::class, $entity, [
"mode" => "update",
"access" => $access
]);
}
// Type Editeur
elseif($entity->getPagecategory()->getId()==3 ) {
return $this->createForm(PageUpdateEditorType::class, $entity, [
"mode" => "update",
"access" => $access
]);
}
}
else {
return $this->createForm(PageSubmitType::class, $entity, [
"mode" => "update",
"access" => $access
]);
}
}
public function submitAction(Request $request,$access="config")
{
$entity = new Page();
2019-04-02 11:26:41 +02:00
$entity->setMaxwidth(0);
$entity->setRoworder(0);
2019-03-21 17:15:06 +01:00
$form = $this->entityForm($entity,$access);
$form->handleRequest($request);
if ($form->isValid()) {
$em = $this->getDoctrine()->getManager();
2019-04-02 11:26:41 +02:00
if($access=="user") $entity->setUser($this->getUser());
2019-03-21 17:15:06 +01:00
$em->persist($entity);
$em->flush();
$route=str_replace("_config_","_".$access."_",$this->routeprimary);
return $this->redirect($this->generateUrl($route.'_update',["id"=>$entity->getId()]));
}
return $this->render($this->labelentity.':submit.html.twig', [
'useheader' => true,
'usemenu' => false,
'usesidebar' => ($access=="config"),
'entity' => $entity,
'mode' => "submit",
'access' => $access,
'form' => $form->createView()
]);
}
public function updateAction(Request $request, $id,$access="config")
{
$em = $this->getDoctrine()->getManager();
$entity = $em->getRepository($this->labelentity)->find($id);
2019-04-02 11:26:41 +02:00
if (!$entity) throw $this->createNotFoundException('Unable to find entity.');
2019-03-21 17:15:06 +01:00
2019-04-02 11:26:41 +02:00
// On s'assure que l'utilisateur à la permission de modifier
if($access=="user") {
$em->getRepository($this->labelentity)->getPermission($this->getUser(),$entity,$cansee,$canupdate);
if(!$canupdate) throw $this->createNotFoundException('Permission denied');
}
// Création du formulaire
2019-03-21 17:15:06 +01:00
$form = $this->entityForm($entity,$access);
$form->handleRequest($request);
if ($form->isValid()) {
$em = $this->getDoctrine()->getManager();
$em->persist($entity);
$em->flush();
2019-04-02 11:26:41 +02:00
if($access=="config")
return $this->redirect($this->generateUrl($this->routeprimary.'_view',["id"=>$id]));
else
return $this->redirect($this->generateUrl('cadoles_core_home',["id"=>$id]));
2019-03-21 17:15:06 +01:00
}
// Type URL
if($entity->getPagecategory()->getId()==1 ) {
return $this->render($this->labelentity.':updateurl.html.twig', [
'useheader' => true,
'usemenu' => false,
'usesidebar' => ($access=="config"),
'entity' => $entity,
'access' => $access,
'mode' => "update",
'form' => $form->createView(),
]);
}
// Type Widget
elseif($entity->getPagecategory()->getId()==2 ) {
return $this->render($this->labelentity.':updatewidget.html.twig', [
'useheader' => true,
'usemenu' => false,
'usesidebar' => ($access=="config"),
'entity' => $entity,
'access' => $access,
'mode' => "update",
'form' => $form->createView(),
]);
}
// Type Editeur
elseif($entity->getPagecategory()->getId()==3 ) {
return $this->render($this->labelentity.':updateeditor.html.twig', [
'useheader' => true,
'usemenu' => false,
'usesidebar' => ($access=="config"),
'entity' => $entity,
'access' => $access,
'mode' => "update",
'form' => $form->createView(),
]);
}
}
public function deleteAction(Request $request, $id,$access="config")
{
$em = $this->getDoctrine()->getManager();
2019-04-02 11:26:41 +02:00
$entity = $this->getDoctrine()->getRepository($this->labelentity)->find($id);
if (!$entity) throw $this->createNotFoundException('Unable to find entity.');
// On s'assure que l'utilisateur à la permission de supprimer
if($access=="user") {
$em->getRepository($this->labelentity)->getPermission($this->getUser(),$entity,$cansee,$canupdate);
if(!$canupdate) throw $this->createNotFoundException('Permission denied');
}
// Suppression
2019-03-21 17:15:06 +01:00
$em->remove($entity);
$em->flush();
2019-04-02 11:26:41 +02:00
// Retour
if($access=="config")
return $this->redirect($this->generateUrl($this->routeprimary));
else
return $this->redirect($this->generateUrl("cadoles_core_home"));
2019-03-21 17:15:06 +01:00
}
public function viewAction($id,$access=null) {
$em = $this->getDoctrine()->getManager();
$entity = $em->getRepository($this->labelentity)->find($id);
2019-04-02 11:26:41 +02:00
if (!$entity) throw $this->createNotFoundException('Unable to find entity.');
2019-03-21 17:15:06 +01:00
2019-04-02 11:26:41 +02:00
// Permissions
2019-03-21 17:15:06 +01:00
if($access=="config") {
2019-04-02 11:26:41 +02:00
$canupdate = true;
2019-03-21 17:15:06 +01:00
}
else {
2019-04-02 11:26:41 +02:00
// On s'assure que l'utilisateur à la permission de voir
$em->getRepository($this->labelentity)->getPermission($this->getUser(),$entity,$cansee,$canupdate);
if(!$cansee) throw $this->createNotFoundException('Permission denied');
2019-03-21 17:15:06 +01:00
}
2019-04-02 11:26:41 +02:00
2019-03-21 17:15:06 +01:00
// Type URL
if($entity->getPageCategory()->getId()==1) {
return $this->render($this->labelentity.':viewurl.html.twig', [
2019-04-02 11:26:41 +02:00
'useheader' => ($access=="config"),
2019-03-21 17:15:06 +01:00
'usemenu' => false,
'usesidebar' => ($access=="config"),
'entity' => $entity,
'access' => $access,
2019-04-02 11:26:41 +02:00
'canupdate' => $canupdate
2019-03-21 17:15:06 +01:00
]);
}
// Type Editeur
if($entity->getPageCategory()->getId()==2) {
return $this->render($this->labelentity.':viewwidget.html.twig', [
2019-04-02 11:26:41 +02:00
'useheader' => ($access=="config"),
2019-03-21 17:15:06 +01:00
'usemenu' => false,
'usesidebar' => ($access=="config"),
'entity' => $entity,
'access' => $access,
2019-04-02 11:26:41 +02:00
'canupdate' => $canupdate,
2019-03-21 17:15:06 +01:00
'widgets' => $this->getDoctrine()->getRepository("CadolesPortalBundle:Widget")->findAll()
]);
}
// Type Editeur
if($entity->getPageCategory()->getId()==3) {
return $this->render($this->labelentity.':vieweditor.html.twig', [
2019-04-02 11:26:41 +02:00
'useheader' => ($access=="config"),
2019-03-21 17:15:06 +01:00
'usemenu' => false,
'usesidebar' => ($access=="config"),
'entity' => $entity,
'access' => $access,
2019-04-02 11:26:41 +02:00
'canupdate' => $canupdate
2019-03-21 17:15:06 +01:00
]);
}
}
}