<?php
namespace App\Repository;
use App\Entity\OrlOffice;
use Doctrine\Persistence\ManagerRegistry;
/**
* @method OrlOffice|null find($id, $lockMode = null, $lockVersion = null)
* @method OrlOffice|null findOneBy(array $criteria, array $orderBy = null)
* @method OrlOffice[] findAll()
* @method OrlOffice[] findBy(array $criteria, array $orderBy = null, $limit = null, $offset = null)
*/
class OrlOfficeRepository extends AbstractEntityRepository
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, OrlOffice::class);
}
/**
* find all the ORL office around a given point (lat/lon). Return 4 results by default (could be changed with $limit param)
* @param $latitude
* @param $longitude
* @param $distance
* @param int $limit
* @return mixed
*/
public function findActiveOrlOfficesAroundLocation($latitude, $longitude, $distance, $limit=4) {
// only valid ORL offices
$qb = $this->createQueryBuilder('o')
->andWhere('o.state = :state')
->andWhere('o.deletedAt is NULL')
->setParameters(['state' => 'valid']);
$qb = $this->addPositionCriteria($qb, $latitude, $longitude, $distance);
$qb->setMaxResults($limit);
return $qb->getQuery()->getResult();
}
}