src/EventSubscriber/DatatableQuerySubscriber.php line 17

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. // use Omines\DataTablesBundle\Event\PreCallbackEvent;
  4. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  5. class DatatableQuerySubscriber implements EventSubscriberInterface
  6. {
  7.     public static function getSubscribedEvents(): array
  8.     {
  9.         return [
  10.             PreCallbackEvent::class => 'onDatatableQuery',
  11.         ];
  12.     }
  13.     public function onDatatableQuery(PreCallbackEvent $event): void
  14.     {
  15.         $datatable $event->getDatatable();
  16.         if ('payment_datatable' !== $datatable->getName()) {
  17.             return;
  18.         }
  19.     
  20.         $queryBuilder $event->getQuery()->getQueryBuilder();
  21.         $request $event->getQuery()->getRequest();
  22.     
  23.         $columnIndex 6// assuming 'createdAt' is column 6
  24.         $dateRange $request->get('columns')[$columnIndex]['search']['value'] ?? null;
  25.     
  26.         if ($dateRange && strpos($dateRange'|') !== false) {
  27.             [$start$end] = explode('|'$dateRange);
  28.     
  29.             if (!empty($start) && !empty($end)) {
  30.                 $queryBuilder
  31.                     ->andWhere('payment.createdAt BETWEEN :start AND :end')
  32.                     ->setParameter('start'$start ' 00:00:00')
  33.                     ->setParameter('end'$end ' 23:59:59');
  34.             }
  35.         }
  36.     }
  37.     
  38. }