123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- <?php
- /*
- * This file is part of the Sonata package.
- *
- * (c) Thomas Rabaix <thomas.rabaix@sonata-project.org>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Sonata\DoctrineORMAdminBundle\Filter;
- use Doctrine\Common\Collections\Collection;
- use Doctrine\ORM\Mapping\ClassMetadataInfo;
- use Sonata\AdminBundle\Form\Type\EqualType;
- class ModelFilter extends Filter
- {
- /**
- * @param QueryBuilder $queryBuilder
- * @param string $alias
- * @param string $field
- * @param mixed $data
- * @return
- */
- public function filter($queryBuilder, $alias, $field, $data)
- {
- if (!$data || !is_array($data) || !array_key_exists('value', $data)) {
- return;
- }
- if ($data['value'] instanceof Collection) {
- $this->handleMultiple($queryBuilder, $alias, $field, $data);
- } else {
- $this->handleModel($queryBuilder, $alias, $field, $data);
- }
- }
- protected function handleMultiple($queryBuilder, $alias, $field, $data)
- {
- if ($data['value']->count() == 0) {
- return;
- }
- $parameterName = $this->getNewParameterName();
- if (isset($data['type']) && $data['type'] == EqualType::TYPE_IS_NOT_EQUAL) {
- $this->applyWhere($queryBuilder, $queryBuilder->expr()->notIn($alias, ':'.$parameterName));
- } else {
- $this->applyWhere($queryBuilder, $queryBuilder->expr()->in($alias, ':'.$parameterName));
- }
- $queryBuilder->setParameter($parameterName, $data['value']->toArray());
- }
- protected function handleModel($queryBuilder, $alias, $field, $data)
- {
- if (empty($data['value'])) {
- return;
- }
- $parameterName = $this->getNewParameterName();
- if (isset($data['type']) && $data['type'] == EqualType::TYPE_IS_NOT_EQUAL) {
- $this->applyWhere($queryBuilder, sprintf('%s != :%s', $alias, $parameterName));
- } else {
- $this->applyWhere($queryBuilder, sprintf('%s = :%s', $alias, $parameterName));
- }
- $queryBuilder->setParameter($parameterName, $data['value']);
- }
- protected function association($queryBuilder, $data)
- {
- list($alias, $field) = parent::association($queryBuilder, $data);
- $types = array(
- ClassMetadataInfo::ONE_TO_ONE,
- ClassMetadataInfo::ONE_TO_MANY,
- ClassMetadataInfo::MANY_TO_MANY,
- ClassMetadataInfo::MANY_TO_ONE,
- );
- if (!in_array($this->getOption('mapping_type'), $types)) {
- throw new \RunTimeException('Invalid mapping type');
- }
- $newAlias = $alias.'_'.$field;
- $queryBuilder->leftJoin(sprintf('%s.%s', $alias, $field), $newAlias);
- return array($newAlias, false);
- }
- public function getDefaultOptions()
- {
- return array(
- 'mapping_type' => false,
- 'field_name' => false,
- 'field_type' => 'entity',
- 'field_options' => array(),
- 'operator_type' => 'sonata_type_equal',
- 'operator_options' => array(),
- );
- }
- public function getRenderSettings()
- {
- return array('sonata_type_filter_default', array(
- 'field_type' => $this->getFieldType(),
- 'field_options' => $this->getFieldOptions(),
- 'operator_type' => $this->getOption('operator_type'),
- 'operator_options' => $this->getOption('operator_options'),
- 'label' => $this->getLabel()
- ));
- }
- }
|