332 lines
12 KiB
PHP
332 lines
12 KiB
PHP
|
<?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();
|
||
|
$form = $this->entityForm($entity,$access);
|
||
|
$form->handleRequest($request);
|
||
|
|
||
|
if ($form->isValid()) {
|
||
|
$em = $this->getDoctrine()->getManager();
|
||
|
$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);
|
||
|
|
||
|
if (!$entity) {
|
||
|
throw $this->createNotFoundException('Unable to find entity.');
|
||
|
}
|
||
|
|
||
|
$form = $this->entityForm($entity,$access);
|
||
|
|
||
|
$form->handleRequest($request);
|
||
|
|
||
|
if ($form->isValid()) {
|
||
|
$em = $this->getDoctrine()->getManager();
|
||
|
$em->persist($entity);
|
||
|
$em->flush();
|
||
|
|
||
|
$route=str_replace("_config_","_".$access."_",$this->routeprimary);
|
||
|
return $this->redirect($this->generateUrl($route.'_view',["id"=>$id]));
|
||
|
}
|
||
|
|
||
|
|
||
|
// 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")
|
||
|
{
|
||
|
$entity = $this->getDoctrine()
|
||
|
->getRepository($this->labelentity)
|
||
|
->find($id);
|
||
|
|
||
|
$em = $this->getDoctrine()->getManager();
|
||
|
$em->remove($entity);
|
||
|
$em->flush();
|
||
|
|
||
|
$route=str_replace("_config_","_".$access."_",$this->routeprimary);
|
||
|
return $this->redirect($this->generateUrl($route));
|
||
|
}
|
||
|
|
||
|
public function viewAction($id,$access=null) {
|
||
|
|
||
|
$em = $this->getDoctrine()->getManager();
|
||
|
|
||
|
$entity = $em->getRepository($this->labelentity)->find($id);
|
||
|
|
||
|
if (!$entity) {
|
||
|
throw $this->createNotFoundException('Unable to find entity.');
|
||
|
}
|
||
|
|
||
|
// Pages profilé
|
||
|
if($access=="config") {
|
||
|
$pages=new ArrayCollection();
|
||
|
$pages->add($entity);
|
||
|
}
|
||
|
else {
|
||
|
// Profilage
|
||
|
$user=$this->getUser();
|
||
|
$roles=($user?$user->getRoles():["ROLE_ANONYME"]);
|
||
|
$groups=($user?$user->getGroups():[]);
|
||
|
|
||
|
// Initialisation du calcul des pages
|
||
|
$pagesnotorder=new ArrayCollection();
|
||
|
|
||
|
// Récupération des pages par rôles
|
||
|
foreach($roles as $role) {
|
||
|
$qb = $em->createQueryBuilder();
|
||
|
$qb->select('page')
|
||
|
->from("CadolesPortalBundle:Page", 'page')
|
||
|
->where($qb->expr()->like('page.roles', $qb->expr()->literal("%$role%")));
|
||
|
|
||
|
$pagesroles=$qb->getQuery()->getResult();
|
||
|
foreach($pagesroles as $pagerole) {
|
||
|
if(!$pagesnotorder->contains($pagerole)) $pagesnotorder->add($pagerole);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Récupération des pages par group
|
||
|
foreach($groups as $group) {
|
||
|
$qb = $em->createQueryBuilder();
|
||
|
$qb->select('page')
|
||
|
->from("CadolesPortalBundle:Page", 'page')
|
||
|
->where(":group MEMBER OF page.groups")
|
||
|
->setParameter("group",$group->getGroup());
|
||
|
|
||
|
$pagesgroups=$qb->getQuery()->getResult();
|
||
|
foreach($pagesgroups as $pagegroup) {
|
||
|
if(!$pagesnotorder->contains($pagegroup)) $pagesnotorder->add($pagegroup);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Trie des pages
|
||
|
$pages = $pagesnotorder->getIterator();
|
||
|
$pages->uasort(function ($first, $second) {
|
||
|
return (int) $first->getRowOrder() > (int) $second->getRowOrder() ? 1 : -1;
|
||
|
});
|
||
|
}
|
||
|
|
||
|
// Type URL
|
||
|
if($entity->getPageCategory()->getId()==1) {
|
||
|
return $this->render($this->labelentity.':viewurl.html.twig', [
|
||
|
'useheader' => true,
|
||
|
'usemenu' => false,
|
||
|
'usesidebar' => ($access=="config"),
|
||
|
'entity' => $entity,
|
||
|
'access' => $access,
|
||
|
'pages' => $pages
|
||
|
]);
|
||
|
}
|
||
|
// Type Editeur
|
||
|
if($entity->getPageCategory()->getId()==2) {
|
||
|
return $this->render($this->labelentity.':viewwidget.html.twig', [
|
||
|
'useheader' => true,
|
||
|
'usemenu' => false,
|
||
|
'usesidebar' => ($access=="config"),
|
||
|
'entity' => $entity,
|
||
|
'access' => $access,
|
||
|
'pages' => $pages,
|
||
|
'widgets' => $this->getDoctrine()->getRepository("CadolesPortalBundle:Widget")->findAll()
|
||
|
]);
|
||
|
}
|
||
|
// Type Editeur
|
||
|
if($entity->getPageCategory()->getId()==3) {
|
||
|
return $this->render($this->labelentity.':vieweditor.html.twig', [
|
||
|
'useheader' => true,
|
||
|
'usemenu' => false,
|
||
|
'usesidebar' => ($access=="config"),
|
||
|
'entity' => $entity,
|
||
|
'access' => $access,
|
||
|
'pages' => $pages
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
}
|
||
|
}
|