Export: fix filter household by composition

This commit is contained in:
Julien Fastré 2023-09-12 15:10:23 +02:00
parent c2c14be9d7
commit 9e017b0d66
Signed by: julienfastre
GPG Key ID: BDE2190974723FCB
2 changed files with 13 additions and 14 deletions

View File

@ -45,23 +45,23 @@ class CompositionFilter implements FilterInterface
public function alterQuery(QueryBuilder $qb, $data)
{
if (!in_array('composition_type_filter', $qb->getAllAliases(), true)) {
$clause =
$qb->expr()->andX(
$qb->expr()->lte('composition_type_filter.startDate', ':ondate_composition_type_filter'),
$qb->expr()->orX(
$qb->expr()->gt('composition_type_filter.endDate', ':ondate_composition_type_filter'),
$qb->expr()->isNull('composition_type_filter.endDate')
)
);
dump(__METHOD__);
// there is no test on the aliases here: the name should be unique
$clause =
$qb->expr()->andX(
$qb->expr()->lte('composition_type_filter_composition.startDate', ':ondate_composition_type_filter'),
$qb->expr()->orX(
$qb->expr()->gt('composition_type_filter_composition.endDate', ':ondate_composition_type_filter'),
$qb->expr()->isNull('composition_type_filter_composition.endDate')
)
);
$qb->join('household.compositions', 'composition', Expr\Join::WITH, $clause);
}
$qb->join('household.compositions', 'composition_type_filter_composition', Expr\Join::WITH, $clause);
$whereClause = $qb->expr()->in('composition_type_filter.householdCompositionType', ':compositions');
$whereClause = $qb->expr()->in('composition_type_filter_composition.householdCompositionType', ':compositions_composition_type_filter');
$qb->andWhere($whereClause);
$qb->setParameter('compositions', $data['accepted_composition']);
$qb->setParameter('compositions_composition_type_filter', $data['accepted_composition']);
$qb->setParameter(
'ondate_composition_type_filter',
$this->rollingDateConverter->convert($data['on_date'])

View File

@ -15,7 +15,6 @@ use Chill\MainBundle\Test\Export\AbstractFilterTest;
use Chill\PersonBundle\Entity\Household\Household;
use Chill\PersonBundle\Entity\Household\HouseholdCompositionType;
use Chill\PersonBundle\Export\Filter\HouseholdFilters\CompositionFilter;
use DateTime;
use Doctrine\ORM\EntityManagerInterface;
/**