2021-03-29 13:58:05 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Controller\Blog;
|
|
|
|
|
|
|
|
use App\Core\Controller\Admin\AdminController;
|
|
|
|
use App\Core\Form\FileUploadHandler;
|
|
|
|
use App\Core\Manager\EntityManager;
|
|
|
|
use App\Entity\Blog\Post as Entity;
|
|
|
|
use App\Factory\Blog\PostFactory as EntityFactory;
|
2021-03-30 13:40:46 +02:00
|
|
|
use App\Form\Blog\Filter\PostFilterType;
|
2021-03-29 13:58:05 +02:00
|
|
|
use App\Form\Blog\PostType as EntityType;
|
|
|
|
use App\Repository\Blog\PostRepositoryQuery as RepositoryQuery;
|
|
|
|
use Symfony\Component\HttpFoundation\Request;
|
|
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
|
|
use Symfony\Component\HttpFoundation\Session\Session;
|
2021-03-30 13:40:46 +02:00
|
|
|
use Symfony\Component\Routing\Annotation\Route;
|
2021-03-29 13:58:05 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @Route("/admin/blog/post")
|
|
|
|
*/
|
|
|
|
class PostAdminController extends AdminController
|
|
|
|
{
|
|
|
|
protected $filters = [];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @Route("/{page}", name="admin_blog_post_index", requirements={"page": "\d+"})
|
|
|
|
*/
|
|
|
|
public function index(int $page = 1, RepositoryQuery $query, Request $request, Session $session): Response
|
|
|
|
{
|
|
|
|
$this->updateFilters($request, $session);
|
|
|
|
|
|
|
|
$pager = $query
|
|
|
|
->orderBy('.id', 'DESC')
|
|
|
|
->useFilters($this->filters)
|
2021-03-30 13:40:46 +02:00
|
|
|
->paginate($page)
|
|
|
|
;
|
2021-03-29 13:58:05 +02:00
|
|
|
|
|
|
|
return $this->render('blog/post_admin/index.html.twig', [
|
|
|
|
'pager' => $pager,
|
|
|
|
'hasFilters' => !empty($this->filters),
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @Route("/new", name="admin_blog_post_new")
|
|
|
|
*/
|
|
|
|
public function new(EntityFactory $factory, EntityManager $entityManager, Request $request): Response
|
|
|
|
{
|
|
|
|
$entity = $factory->create($this->getUser());
|
|
|
|
$form = $this->createForm(EntityType::class, $entity);
|
|
|
|
|
|
|
|
if ($request->isMethod('POST')) {
|
|
|
|
$form->handleRequest($request);
|
|
|
|
|
|
|
|
if ($form->isValid()) {
|
|
|
|
$entityManager->create($entity);
|
|
|
|
$this->addFlash('success', 'The data has been saved.');
|
|
|
|
|
|
|
|
return $this->redirectToRoute('admin_blog_post_edit', [
|
|
|
|
'entity' => $entity->getId(),
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
$this->addFlash('warning', 'The form is not valid.');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->render('blog/post_admin/new.html.twig', [
|
|
|
|
'form' => $form->createView(),
|
|
|
|
'entity' => $entity,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @Route("/edit/{entity}", name="admin_blog_post_edit")
|
|
|
|
*/
|
|
|
|
public function edit(Entity $entity, EntityManager $entityManager, FileUploadHandler $fileUpload, Request $request): Response
|
|
|
|
{
|
|
|
|
$form = $this->createForm(EntityType::class, $entity);
|
|
|
|
|
|
|
|
if ($request->isMethod('POST')) {
|
|
|
|
$form->handleRequest($request);
|
|
|
|
|
|
|
|
if ($form->isValid()) {
|
|
|
|
$directory = 'uploads/post/'.date('Y');
|
|
|
|
|
|
|
|
$fileUpload->handleForm(
|
|
|
|
$form->get('image')->getData(),
|
|
|
|
$directory,
|
|
|
|
function ($filename) use ($entity, $directory) {
|
|
|
|
$entity->setImage($directory.'/'.$filename);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
$entityManager->update($entity);
|
|
|
|
$this->addFlash('success', 'The form is not valid.');
|
|
|
|
|
|
|
|
return $this->redirectToRoute('admin_blog_post_edit', [
|
|
|
|
'entity' => $entity->getId(),
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
$this->addFlash('warning', 'The form is not valid.');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->render('blog/post_admin/edit.html.twig', [
|
|
|
|
'form' => $form->createView(),
|
|
|
|
'entity' => $entity,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @Route("/show/{entity}", name="admin_blog_post_show")
|
|
|
|
*/
|
|
|
|
public function show(Entity $entity): Response
|
|
|
|
{
|
|
|
|
return $this->render('blog/post_admin/show.html.twig', [
|
|
|
|
'entity' => $entity,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @Route("/filters", name="admin_blog_post_filters")
|
|
|
|
*/
|
|
|
|
public function filters(Session $session): Response
|
|
|
|
{
|
|
|
|
$form = $this->createForm(PostFilterType::class);
|
|
|
|
$form->submit($session->get('post_filter'));
|
|
|
|
|
|
|
|
return $this->render('blog/post_admin/filters.html.twig', [
|
|
|
|
'form' => $form->createView(),
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @Route("/delete/{entity}", name="admin_blog_post_delete", methods={"DELETE"})
|
|
|
|
*/
|
|
|
|
public function delete(Entity $entity, EntityManager $entityManager, Request $request): Response
|
|
|
|
{
|
|
|
|
if ($this->isCsrfTokenValid('delete'.$entity->getId(), $request->request->get('_token'))) {
|
|
|
|
$entityManager->delete($entity);
|
|
|
|
|
|
|
|
$this->addFlash('success', 'The data has been removed.');
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->redirectToRoute('admin_blog_post_index');
|
|
|
|
}
|
|
|
|
|
2021-03-30 13:40:46 +02:00
|
|
|
public function getSection(): string
|
|
|
|
{
|
|
|
|
return 'blog_post';
|
|
|
|
}
|
|
|
|
|
2021-03-29 13:58:05 +02:00
|
|
|
protected function updateFilters(Request $request, Session $session)
|
|
|
|
{
|
|
|
|
if ($request->query->has('post_filter')) {
|
|
|
|
$filters = $request->query->get('post_filter');
|
|
|
|
|
2021-03-30 13:40:46 +02:00
|
|
|
if ('0' === $filters) {
|
2021-03-29 13:58:05 +02:00
|
|
|
$filters = [];
|
|
|
|
}
|
|
|
|
} elseif ($session->has('post_filter')) {
|
|
|
|
$filters = $session->get('post_filter');
|
|
|
|
} else {
|
|
|
|
$filters = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
$form = $this->createForm(PostFilterType::class);
|
|
|
|
$form->submit($filters);
|
|
|
|
|
|
|
|
if (empty($filters)) {
|
|
|
|
$this->filters = $filters;
|
|
|
|
$session->set('post_filter', $this->filters);
|
|
|
|
} elseif ($form->isValid()) {
|
|
|
|
$this->filters = $form->getData();
|
|
|
|
$session->set('post_filter', $this->filters);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|