mirror of
				https://gitlab.com/Chill-Projet/chill-bundles.git
				synced 2025-10-25 06:32:50 +00:00 
			
		
		
		
	evaluations aggregators
This commit is contained in:
		| @@ -14,10 +14,23 @@ namespace Chill\PersonBundle\Export\Aggregator\EvaluationAggregators; | ||||
| use Chill\MainBundle\Export\AggregatorInterface; | ||||
| use Chill\PersonBundle\Export\Declarations; | ||||
| use Doctrine\ORM\QueryBuilder; | ||||
| use LogicException; | ||||
| use Symfony\Component\Form\Extension\Core\Type\ChoiceType; | ||||
| use Symfony\Component\Form\FormBuilderInterface; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
|  | ||||
| class ByEndDateAggregator implements AggregatorInterface | ||||
| { | ||||
|     private const CHOICES = [ | ||||
|         'by week' => 'week', | ||||
|         'by month' => 'month', | ||||
|         'by year' => 'year', | ||||
|     ]; | ||||
|  | ||||
|     private const DEFAULT_CHOICE = 'year'; | ||||
|  | ||||
|     private TranslatorInterface $translator; | ||||
|  | ||||
|     public function addRole(): ?string | ||||
|     { | ||||
|         return null; | ||||
| @@ -25,8 +38,29 @@ class ByEndDateAggregator implements AggregatorInterface | ||||
|  | ||||
|     public function alterQuery(QueryBuilder $qb, $data) | ||||
|     { | ||||
|         $qb->addSelect('AS eval_by_end_date_aggregator') | ||||
|             ->addGroupBy('eval_by_end_date_aggregator'); | ||||
|         switch ($data['frequency']) { | ||||
|             case 'week': | ||||
|                 $fmt = 'YYYY-IW'; | ||||
|  | ||||
|                 break; | ||||
|  | ||||
|             case 'month': | ||||
|                 $fmt = 'YYYY-MM'; | ||||
|  | ||||
|                 break; | ||||
|  | ||||
|             case 'year': | ||||
|                 $fmt = 'YYYY'; | ||||
|  | ||||
|                 break; | ||||
|  | ||||
|             default: | ||||
|                 throw new LogicException(sprintf("The frequency data '%s' is invalid.", $data['frequency'])); | ||||
|         } | ||||
|  | ||||
|         $qb->addSelect(sprintf("TO_CHAR(workeval.endDate, '%s') AS eval_by_end_date_aggregator", $fmt)); | ||||
|         $qb->addGroupBy(' eval_by_end_date_aggregator'); | ||||
|         $qb->addOrderBy(' eval_by_end_date_aggregator', 'ASC'); | ||||
|     } | ||||
|  | ||||
|     public function applyOn(): string | ||||
| @@ -36,15 +70,27 @@ class ByEndDateAggregator implements AggregatorInterface | ||||
|  | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
|     { | ||||
|         // No form needed | ||||
|         $builder->add('frequency', ChoiceType::class, [ | ||||
|             'choices' => self::CHOICES, | ||||
|             'multiple' => false, | ||||
|             'expanded' => true, | ||||
|             'empty_data' => self::DEFAULT_CHOICE, | ||||
|             'data' => self::DEFAULT_CHOICE, | ||||
|         ]); | ||||
|     } | ||||
|  | ||||
|     public function getLabels($key, array $values, $data) | ||||
|     { | ||||
|         return static function ($value): string { | ||||
|             if ('_header' === $value) { | ||||
|                 return 'export.aggregator.eval.by_end_date.End date period'; | ||||
|             } | ||||
|  | ||||
|             if (null === $value) { | ||||
|                 return ''; | ||||
|             } | ||||
|  | ||||
|             return $value; | ||||
|         }; | ||||
|     } | ||||
|  | ||||
| @@ -55,6 +101,6 @@ class ByEndDateAggregator implements AggregatorInterface | ||||
|  | ||||
|     public function getTitle(): string | ||||
|     { | ||||
|         return 'Group by end date evaluations'; | ||||
|         return 'export.aggregator.eval.by_end_date.Group by end date evaluations'; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -14,10 +14,23 @@ namespace Chill\PersonBundle\Export\Aggregator\EvaluationAggregators; | ||||
| use Chill\MainBundle\Export\AggregatorInterface; | ||||
| use Chill\PersonBundle\Export\Declarations; | ||||
| use Doctrine\ORM\QueryBuilder; | ||||
| use LogicException; | ||||
| use Symfony\Component\Form\Extension\Core\Type\ChoiceType; | ||||
| use Symfony\Component\Form\FormBuilderInterface; | ||||
| use Symfony\Contracts\Translation\TranslatorInterface; | ||||
|  | ||||
| class ByMaxDateAggregator implements AggregatorInterface | ||||
| { | ||||
|     private const CHOICES = [ | ||||
|         'by week' => 'week', | ||||
|         'by month' => 'month', | ||||
|         'by year' => 'year', | ||||
|     ]; | ||||
|  | ||||
|     private const DEFAULT_CHOICE = 'year'; | ||||
|  | ||||
|     private TranslatorInterface $translator; | ||||
|  | ||||
|     public function addRole(): ?string | ||||
|     { | ||||
|         return null; | ||||
| @@ -25,8 +38,29 @@ class ByMaxDateAggregator implements AggregatorInterface | ||||
|  | ||||
|     public function alterQuery(QueryBuilder $qb, $data) | ||||
|     { | ||||
|         $qb->addSelect('AS eval_by_max_date_aggregator') | ||||
|             ->addGroupBy('eval_by_max_date_aggregator'); | ||||
|         switch ($data['frequency']) { | ||||
|             case 'week': | ||||
|                 $fmt = 'YYYY-IW'; | ||||
|  | ||||
|                 break; | ||||
|  | ||||
|             case 'month': | ||||
|                 $fmt = 'YYYY-MM'; | ||||
|  | ||||
|                 break; | ||||
|  | ||||
|             case 'year': | ||||
|                 $fmt = 'YYYY'; | ||||
|  | ||||
|                 break; | ||||
|  | ||||
|             default: | ||||
|                 throw new LogicException(sprintf("The frequency data '%s' is invalid.", $data['frequency'])); | ||||
|         } | ||||
|  | ||||
|         $qb->addSelect(sprintf("TO_CHAR(workeval.maxDate, '%s') AS eval_by_max_date_aggregator", $fmt)); | ||||
|         $qb->addGroupBy(' eval_by_max_date_aggregator'); | ||||
|         $qb->addOrderBy(' eval_by_max_date_aggregator', 'ASC'); | ||||
|     } | ||||
|  | ||||
|     public function applyOn(): string | ||||
| @@ -36,15 +70,27 @@ class ByMaxDateAggregator implements AggregatorInterface | ||||
|  | ||||
|     public function buildForm(FormBuilderInterface $builder) | ||||
|     { | ||||
|         // No form needed | ||||
|         $builder->add('frequency', ChoiceType::class, [ | ||||
|             'choices' => self::CHOICES, | ||||
|             'multiple' => false, | ||||
|             'expanded' => true, | ||||
|             'empty_data' => self::DEFAULT_CHOICE, | ||||
|             'data' => self::DEFAULT_CHOICE, | ||||
|         ]); | ||||
|     } | ||||
|  | ||||
|     public function getLabels($key, array $values, $data) | ||||
|     { | ||||
|         return static function ($value): string { | ||||
|             if ('_header' === $value) { | ||||
|                 return 'export.aggregator.eval.by_max_date.Max date'; | ||||
|             } | ||||
|  | ||||
|             if (null === $value) { | ||||
|                 return ''; | ||||
|             } | ||||
|  | ||||
|             return $value; | ||||
|         }; | ||||
|     } | ||||
|  | ||||
| @@ -55,6 +101,6 @@ class ByMaxDateAggregator implements AggregatorInterface | ||||
|  | ||||
|     public function getTitle(): string | ||||
|     { | ||||
|         return 'Group by max date evaluations'; | ||||
|         return 'export.aggregator.eval.by_max_date.Group by max date evaluations'; | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -22,8 +22,8 @@ use Symfony\Contracts\Translation\TranslatorInterface; | ||||
| class ByStartDateAggregator implements AggregatorInterface | ||||
| { | ||||
|     private const CHOICES = [ | ||||
|         'by month' => 'month', | ||||
|         'by week' => 'week', | ||||
|         'by month' => 'month', | ||||
|         'by year' => 'year', | ||||
|     ]; | ||||
|  | ||||
| @@ -39,13 +39,13 @@ class ByStartDateAggregator implements AggregatorInterface | ||||
|     public function alterQuery(QueryBuilder $qb, $data) | ||||
|     { | ||||
|         switch ($data['frequency']) { | ||||
|             case 'month': | ||||
|                 $fmt = 'YYYY-MM'; | ||||
|             case 'week': | ||||
|                 $fmt = 'YYYY-IW'; | ||||
|  | ||||
|                 break; | ||||
|  | ||||
|             case 'week': | ||||
|                 $fmt = 'YYYY-IW'; | ||||
|             case 'month': | ||||
|                 $fmt = 'YYYY-MM'; | ||||
|  | ||||
|                 break; | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user