add parent category in category, fix pager
This commit is contained in:
parent
655f9c9690
commit
b839f4df0b
|
@ -61,6 +61,11 @@ class CategoryAdminController extends CrudController
|
||||||
'button_attr' => ['class' => 'btn btn-sm btn-light'],
|
'button_attr' => ['class' => 'btn btn-sm btn-light'],
|
||||||
'raw' => true,
|
'raw' => true,
|
||||||
])
|
])
|
||||||
|
->setField('index', 'Catégorie', TextField::class, [
|
||||||
|
'property_builder' => function (EntityInterface $entity) {
|
||||||
|
return $entity->getParentCategory()?->getTitle() ?? '';
|
||||||
|
},
|
||||||
|
])
|
||||||
->setField('index', 'Status', ButtonField::class, [
|
->setField('index', 'Status', ButtonField::class, [
|
||||||
'sort' => ['isActive', '.isActive'],
|
'sort' => ['isActive', '.isActive'],
|
||||||
'attr' => ['class' => 'miw-100'],
|
'attr' => ['class' => 'miw-100'],
|
||||||
|
@ -106,8 +111,8 @@ class CategoryAdminController extends CrudController
|
||||||
public function show(Entity $entity, PostRepositoryQuery $postQuery): Response
|
public function show(Entity $entity, PostRepositoryQuery $postQuery): Response
|
||||||
{
|
{
|
||||||
$posts = $postQuery->create()
|
$posts = $postQuery->create()
|
||||||
->orderBy('.publishedAt', 'DESC')
|
->addOrderBy('.publishedAt', 'DESC')
|
||||||
->orderBy('.createdAt', 'DESC')
|
->addOrderBy('.createdAt', 'DESC')
|
||||||
->inCategory($entity)
|
->inCategory($entity)
|
||||||
->paginate(1, 10)
|
->paginate(1, 10)
|
||||||
;
|
;
|
||||||
|
|
|
@ -81,6 +81,9 @@ class PostAdminController extends CrudController
|
||||||
'sort' => ['status', '.status'],
|
'sort' => ['status', '.status'],
|
||||||
'attr' => ['class' => 'miw-100'],
|
'attr' => ['class' => 'miw-100'],
|
||||||
])
|
])
|
||||||
|
->setBatchAction('index', 'delete', 'Delete', function(EntityInterface $entity, EntityManager $manager) {
|
||||||
|
$manager->delete($entity);
|
||||||
|
})
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -125,7 +125,7 @@ class PostController extends PageController
|
||||||
public function category(Category $category, string $slug, int $page = 1): Response
|
public function category(Category $category, string $slug, int $page = 1): Response
|
||||||
{
|
{
|
||||||
$entities = $this->createQuery()
|
$entities = $this->createQuery()
|
||||||
->inCategory($category)
|
->inCategory($category, false)
|
||||||
->paginate($page, 5)
|
->paginate($page, 5)
|
||||||
;
|
;
|
||||||
|
|
||||||
|
|
|
@ -54,9 +54,20 @@ class Category implements EntityInterface
|
||||||
*/
|
*/
|
||||||
private $isActive;
|
private $isActive;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\ManyToOne(targetEntity=Category::class, inversedBy="categories")
|
||||||
|
*/
|
||||||
|
private $parentCategory;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ORM\OneToMany(targetEntity=Category::class, mappedBy="parentCategory")
|
||||||
|
*/
|
||||||
|
private $categories;
|
||||||
|
|
||||||
public function __construct()
|
public function __construct()
|
||||||
{
|
{
|
||||||
$this->posts = new ArrayCollection();
|
$this->posts = new ArrayCollection();
|
||||||
|
$this->categories = new ArrayCollection();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getId(): ?int
|
public function getId(): ?int
|
||||||
|
@ -150,4 +161,46 @@ class Category implements EntityInterface
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getParentCategory(): ?self
|
||||||
|
{
|
||||||
|
return $this->parentCategory;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setParentCategory(?self $parentCategory): self
|
||||||
|
{
|
||||||
|
$this->parentCategory = $parentCategory;
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return Collection|self[]
|
||||||
|
*/
|
||||||
|
public function getCategories(): Collection
|
||||||
|
{
|
||||||
|
return $this->categories;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function addCategory(self $category): self
|
||||||
|
{
|
||||||
|
if (!$this->categories->contains($category)) {
|
||||||
|
$this->categories[] = $category;
|
||||||
|
$category->setParentCategory($this);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function removeCategory(self $category): self
|
||||||
|
{
|
||||||
|
if ($this->categories->removeElement($category)) {
|
||||||
|
// set the owning side to null (unless already changed)
|
||||||
|
if ($category->getParentCategory() === $this) {
|
||||||
|
$category->setParentCategory(null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,8 @@ use Symfony\Component\Form\Extension\Core\Type\TextType;
|
||||||
use Symfony\Component\Form\FormBuilderInterface;
|
use Symfony\Component\Form\FormBuilderInterface;
|
||||||
use Symfony\Component\OptionsResolver\OptionsResolver;
|
use Symfony\Component\OptionsResolver\OptionsResolver;
|
||||||
use Symfony\Component\Validator\Constraints\NotBlank;
|
use Symfony\Component\Validator\Constraints\NotBlank;
|
||||||
|
use Doctrine\ORM\EntityRepository;
|
||||||
|
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
|
||||||
|
|
||||||
class CategoryType extends AbstractType
|
class CategoryType extends AbstractType
|
||||||
{
|
{
|
||||||
|
@ -29,6 +31,28 @@ class CategoryType extends AbstractType
|
||||||
]
|
]
|
||||||
);
|
);
|
||||||
|
|
||||||
|
$builder->add(
|
||||||
|
'parentCategory',
|
||||||
|
EntityType::class,
|
||||||
|
[
|
||||||
|
'label' => 'Catégorie parente',
|
||||||
|
'class' => Category::class,
|
||||||
|
'choice_label' => 'title',
|
||||||
|
'required' => false,
|
||||||
|
'multiple' => false,
|
||||||
|
'attr' => [
|
||||||
|
'data-jschoice' => '',
|
||||||
|
],
|
||||||
|
'query_builder' => function (EntityRepository $repo) {
|
||||||
|
return $repo->createQueryBuilder('a')
|
||||||
|
->orderBy('a.title', 'ASC')
|
||||||
|
;
|
||||||
|
},
|
||||||
|
'constraints' => [
|
||||||
|
],
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
$builder->add(
|
$builder->add(
|
||||||
'subTitle',
|
'subTitle',
|
||||||
TextareaType::class,
|
TextareaType::class,
|
||||||
|
|
|
@ -18,15 +18,29 @@ class PostRepositoryQuery extends RepositoryQuery
|
||||||
parent::__construct($repository, 'p', $paginator);
|
parent::__construct($repository, 'p', $paginator);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function inCategory(Category $category)
|
public function inCategory(Category $category, bool $strict = true)
|
||||||
{
|
{
|
||||||
$c = 'c'.mt_rand();
|
$c = 'c'.mt_rand();
|
||||||
|
|
||||||
$this
|
if ($strict) {
|
||||||
->innerJoin('p.categories', $c)
|
$this
|
||||||
->andWhere($c.'.id = :category')
|
->innerJoin('p.categories', $c)
|
||||||
->setParameter(':category', $category->getId())
|
->andWhere($c.'.id = :category')
|
||||||
;
|
->setParameter(':category', $category->getId())
|
||||||
|
;
|
||||||
|
} else {
|
||||||
|
$ids = [$category->getId()];
|
||||||
|
|
||||||
|
foreach ($category->getCategories() as $childCategory) {
|
||||||
|
$ids[] = $childCategory->getId();
|
||||||
|
}
|
||||||
|
|
||||||
|
$this
|
||||||
|
->innerJoin('p.categories', $c)
|
||||||
|
->andWhere($c.'.id IN (:categories)')
|
||||||
|
->setParameter(':categories', $ids)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-4 p-3">
|
<div class="col-md-4 p-3">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
{% for item in ['title', 'subTitle', 'slug', 'isActive'] %}
|
{% for item in ['title', 'subTitle', 'slug', 'parentCategory', 'isActive'] %}
|
||||||
<div class="col-md-12">
|
<div class="col-md-12">
|
||||||
{{ form_row(form[item]) }}
|
{{ form_row(form[item]) }}
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -34,7 +34,11 @@
|
||||||
{% block pager %}
|
{% block pager %}
|
||||||
{{ include('module/_pager.html.twig', {
|
{{ include('module/_pager.html.twig', {
|
||||||
route: _node.routeName,
|
route: _node.routeName,
|
||||||
routeParams: {_domain: _domain},
|
routeParams: {
|
||||||
|
_domain: _domain,
|
||||||
|
category: category.id,
|
||||||
|
slug: category.slug
|
||||||
|
},
|
||||||
pages: pager.paginationData.endPage,
|
pages: pager.paginationData.endPage,
|
||||||
currentPage: pager.paginationData.current
|
currentPage: pager.paginationData.current
|
||||||
}) }}
|
}) }}
|
||||||
|
|
Loading…
Reference in a new issue