CotisationPrestataireAdmin.php 4.72 KB
Newer Older
Julien Jorry committed
1 2 3 4
<?php

namespace App\Admin;

5 6
use App\Entity\Prestataire;
use App\Entity\User;
7
use Sonata\AdminBundle\Datagrid\DatagridMapper;
Julien Jorry committed
8 9
use Sonata\AdminBundle\Datagrid\ListMapper;
use Sonata\AdminBundle\Form\FormMapper;
Julien Jorry committed
10
use Sonata\AdminBundle\Route\RouteCollection;
Julien Jorry committed
11
use Sonata\AdminBundle\Show\ShowMapper;
12 13 14
use Symfony\Bridge\Doctrine\Form\Type\EntityType;
use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
use Symfony\Component\Form\Extension\Core\Type\HiddenType;
Julien Jorry committed
15

16 17 18 19 20 21
/**
 * Administration des cotisations des prestataires
 *
 * LOCO : Outil de gestion de Monnaie Locale Complémentaire
 * @author Julien Jorry <julien.jorry@gmail.com>
 */
Julien Jorry committed
22 23
class CotisationPrestataireAdmin extends CotisationAdmin
{
Julien Jorry committed
24 25 26
    protected $baseRouteName = 'cotisation_prestataire';
    protected $baseRoutePattern = 'cotisation_prestataire';

27 28 29 30 31
    public function configure()
    {
        parent::configure();
    }

32 33 34
    /**
    * {@inheritdoc}
    */
Julien Jorry committed
35 36
    public function createQuery($context = 'list')
    {
37
        $user = $this->security->getUser();
Julien Jorry committed
38
        $query = parent::createQuery($context);
39
        $query->leftJoin($query->getRootAliases()[0] . '.operateur', 'u')
40 41
              ->andWhere($query->getRootAliases()[0] .".type='cotisation_prestataire'")
              // ->andWhere('u.prestataire IS NOT NULL')
42
        ;
43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58
        if ($user->isGranted('ROLE_GESTION_GROUPE') || $user->isGranted('ROLE_CONTACT')) {
            if (empty($user->getGroupesgere())) {
                $query->andWhere('false');
            } else {
                $groupe = $user->getGroupesgere();
                $em = $this->getConfigurationPool()->getContainer()->get('doctrine')->getEntityManager();
                $connection = $em->getConnection();
                $statement = $connection->prepare('SELECT f.id FROM flux f INNER JOIN prestataire a ON (a.id = f.prestataire_id OR a.id = f.prestataire_dest_id) WHERE a.groupe_id = '.$groupe->getId());
                $statement->execute();
                $ids = $statement->fetchAll();
                $query
                    ->andWhere($query->expr()->in($query->getRootAliases()[0].'.id', ':ids'))
                    ->setParameter('ids', $ids)
                ;
            }
        }
Julien Jorry committed
59 60 61 62 63 64 65 66 67 68 69
        return $query;
    }

    /**
    * {@inheritdoc}
    */
    protected function configureShowFields(ShowMapper $showMapper)
    {
        parent::configureShowFields($showMapper);
    }

70 71 72 73 74 75
    /**
    * {@inheritdoc}
    */
    protected function configureDatagridFilters(DatagridMapper $datagridMapper): void
    {
        parent::configureDatagridFilters($datagridMapper);
76 77 78
        $datagridMapper
            ->add('expediteur', null, array('label' => 'Prestataire'))
        ;
79 80
    }

81

Julien Jorry committed
82 83 84 85 86
    /**
    * {@inheritdoc}
    */
    protected function configureFormFields(FormMapper $formMapper): void
    {
87 88 89 90 91 92 93 94 95 96 97
        $expediteurInfos = array(
            'label' => 'Expéditeur',
            'class' => Prestataire::class,
            'choices' =>  $this->getConfigurationPool()->getContainer()->get('doctrine')->getRepository(Prestataire::class)->findBy(array('enabled' => true), array('raison'=> 'ASC')),
            'placeholder' => 'Choisir un prestataire',
            'required' => true,
        );
        $exp = $this->getRequest()->get('expediteur');
        if (!empty($exp)) {
            $expediteurInfos['data'] = $this->getConfigurationPool()->getContainer()->get('doctrine')->getRepository(Prestataire::class)->findOneById($exp);
        }
Julien Jorry committed
98 99
        $formMapper
            ->with('Cotisation', ['class' => 'col-md-8'])
100 101 102 103 104 105
                ->add('reference', HiddenType::class, array(
                    'data' => 'cotisation_prestataire'
                ))
                ->add('type', HiddenType::class, array(
                    'data' => 'cotisation_prestataire'
                ))
106
                ->add('expediteur', EntityType::class, $expediteurInfos)
107 108 109 110
                ->add('operateur', HiddenType::class, array(
                    'data' => $this->security->getUser()->getId(),
                    'entity_class' => User::class,
                    'em' => $this->getConfigurationPool()->getContainer()->get('doctrine')->getManager()
111
                ))
Julien Jorry committed
112 113
            ->end()
        ;
Julien Jorry committed
114
        parent::configureFormFields($formMapper);
Julien Jorry committed
115 116 117 118 119 120 121 122
    }

    /**
    * {@inheritdoc}
    */
    protected function configureRoutes(RouteCollection $collection)
    {
        parent::configureRoutes($collection);
Julien Jorry committed
123 124 125 126 127 128 129
    }

    /**
    * {@inheritdoc}
    */
    protected function configureListFields(ListMapper $listMapper): void
    {
130 131
        unset($this->listModes['mosaic']);
        $listMapper
132 133
            ->addIdentifier('expediteur', null, array('label' => 'Prestataire'))
            ->addIdentifier('expediteur.user.email', null, array('label' => 'Email'));
Julien Jorry committed
134 135 136
        parent::configureListFields($listMapper);
    }
}