소스 검색

Refactoring repositoryQuery id d'entité

packProduct
Fabien Normand 3 년 전
부모
커밋
c3a6f9924f
4개의 변경된 파일18개의 추가작업 그리고 3개의 파일을 삭제
  1. +1
    -0
      Definition/Field/Ticket/TicketFieldDefinition.php
  2. +7
    -1
      Field/Filter/ProductCategoriesFilter.php
  3. +8
    -0
      Repository/Product/ProductFamilyRepositoryQuery.php
  4. +2
    -2
      Repository/Product/ProductStore.php

+ 1
- 0
Definition/Field/Ticket/TicketFieldDefinition.php 파일 보기

@@ -29,6 +29,7 @@ class TicketFieldDefinition extends SovTicketFieldDefinition
return array_merge(parent::configureFields(), [
'type' => ChoiceField::new('type')
->autocomplete()
->setSortable(true)
->setChoices(
$this->translatorAdmin->transChoices(
TicketSolver::getTypeChoices(),

+ 7
- 1
Field/Filter/ProductCategoriesFilter.php 파일 보기

@@ -5,6 +5,7 @@ namespace Lc\CaracoleBundle\Field\Filter;
use Doctrine\ORM\EntityRepository;
use Doctrine\ORM\QueryBuilder;
use EasyCorp\Bundle\EasyAdminBundle\Dto\FieldDto;
use Lc\ShopBundle\Context\TreeInterface;
use Lc\SovBundle\Field\Filter\AssociationFilter;
use Lc\SovBundle\Field\Filter\FilterTrait;
use Lc\SovBundle\Repository\RepositoryQueryInterface;
@@ -43,7 +44,12 @@ class ProductCategoriesFilter extends AssociationFilter
{
$fieldProperty = $this->getFieldProperty($fieldDto);
if ($filteredValue !== null) {
$repositoryQuery->filterByProductCategory($filteredValue);
if ($filteredValue->getParent() == null) {
$param = array_merge(array($filteredValue), $filteredValue->getChildrens()->toArray());
} else {
$param = array($filteredValue);
}
$repositoryQuery->filterByProductCategoryArray($param);

}
}

+ 8
- 0
Repository/Product/ProductFamilyRepositoryQuery.php 파일 보기

@@ -104,6 +104,14 @@ class ProductFamilyRepositoryQuery extends AbstractRepositoryQuery
->setParameter('category', $category->getId());
}

public function filterByProductCategoryArray(Array $categoryArray): self
{
$this->joinProductCategories();
return $this
->andWhere(':categoryArray MEMBER OF .productCategories')
->setParameter('categoryArray', $categoryArray);
}


public function filterByPropertyNoveltyExpirationDate($dateTime = null): self
{

+ 2
- 2
Repository/Product/ProductStore.php 파일 보기

@@ -45,7 +45,7 @@ class ProductStore extends AbstractStore
$query->joinProductFamily();
$query->filterIsOnline();
$query->filterAvailableQuantityNegative();
$query->groupBy('pf.id');
$query->groupBy('productFamily.id');
$productListAvailableQuantityNegative = $query->find();

foreach ($productListAvailableQuantityNegative as $i=>$product) {
@@ -62,7 +62,7 @@ class ProductStore extends AbstractStore
$query->joinProductFamily();
$query->filterIsOnline();
$query->filterAvailableQuantitySupplierNegative();
$query->groupBy('pf.id');
$query->groupBy('productFamily.id');
$productListAvailableQuantityNegative = $query->find();

foreach ($productListAvailableQuantityNegative as $i=>$product) {

Loading…
취소
저장