X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=src%2FWallabag%2FCoreBundle%2FFilter%2FEntryFilterType.php;h=e0a1cb31b487f12f6f5e93e721533bd88845f2bc;hb=619cc45359ead519b64129181a07e14160fbbfcb;hp=d1057fb56f7d9a4a6231fd11e2cdf70a9d6c71e9;hpb=443cecd2d895a7e257a051ea65c6822fdce73b07;p=github%2Fwallabag%2Fwallabag.git diff --git a/src/Wallabag/CoreBundle/Filter/EntryFilterType.php b/src/Wallabag/CoreBundle/Filter/EntryFilterType.php index d1057fb5..e0a1cb31 100644 --- a/src/Wallabag/CoreBundle/Filter/EntryFilterType.php +++ b/src/Wallabag/CoreBundle/Filter/EntryFilterType.php @@ -2,14 +2,30 @@ namespace Wallabag\CoreBundle\Filter; +use Doctrine\ORM\EntityRepository; +use Lexik\Bundle\FormFilterBundle\Filter\Query\QueryInterface; use Symfony\Component\Form\AbstractType; use Symfony\Component\Form\FormBuilderInterface; use Symfony\Component\OptionsResolver\OptionsResolver; -use Lexik\Bundle\FormFilterBundle\Filter\FilterOperands; -use Lexik\Bundle\FormFilterBundle\Filter\Query\QueryInterface; +use Wallabag\UserBundle\Entity\User; class EntryFilterType extends AbstractType { + private $user; + private $repository; + + /** + * Repository & user are used to get a list of language entries for this user. + * + * @param EntityRepository $entryRepository + * @param User $user + */ + public function __construct(EntityRepository $entryRepository, User $user) + { + $this->repository = $entryRepository; + $this->user = $user; + } + public function buildForm(FormBuilderInterface $builder, array $options) { $builder @@ -17,30 +33,51 @@ class EntryFilterType extends AbstractType ->add('createdAt', 'filter_date_range', array( 'left_date_options' => array( 'attr' => array( - 'placeholder' => 'dd/mm/yyyy'), + 'placeholder' => 'dd/mm/yyyy', + ), 'format' => 'dd/MM/yyyy', - 'widget' => 'single_text' + 'widget' => 'single_text', ), 'right_date_options' => array( 'attr' => array( - 'placeholder' => 'dd/mm/yyyy'), + 'placeholder' => 'dd/mm/yyyy', + ), 'format' => 'dd/MM/yyyy', - 'widget' => 'single_text' - ))) + 'widget' => 'single_text', + ), + ) + ) ->add('domainName', 'filter_text', array( - 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) - { + 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) { $value = $values['value']; - if (strlen($value) <= 3 || empty($value)) { - return null; + if (strlen($value) <= 2 || empty($value)) { + return; } $expression = $filterQuery->getExpr()->like($field, $filterQuery->getExpr()->literal('%'.$value.'%')); + return $filterQuery->createCondition($expression); + }, + )) + ->add('isArchived', 'filter_checkbox') + ->add('isStarred', 'filter_checkbox') + ->add('previewPicture', 'filter_checkbox', array( + 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) { + if (false === $values['value']) { + return; } - )); + + $expression = $filterQuery->getExpr()->isNotNull($field); + + return $filterQuery->createCondition($expression); + }, + )) + ->add('language', 'filter_choice', array( + 'choices' => $this->repository->findDistinctLanguageByUser($this->user->getId()), + )) + ; } - public function getName() + public function getBlockPrefix() { return 'entry_filter'; } @@ -48,8 +85,8 @@ class EntryFilterType extends AbstractType public function configureOptions(OptionsResolver $resolver) { $resolver->setDefaults(array( - 'csrf_protection' => false, - 'validation_groups' => array('filtering') + 'csrf_protection' => false, + 'validation_groups' => array('filtering'), )); } }