]>
Commit | Line | Data |
---|---|---|
26864574 NL |
1 | <?php |
2 | ||
b0b893ea | 3 | namespace Wallabag\CoreBundle\Form\Type; |
26864574 | 4 | |
619cc453 JB |
5 | use Doctrine\ORM\EntityRepository; |
6 | use Lexik\Bundle\FormFilterBundle\Filter\Query\QueryInterface; | |
5c895a7f JB |
7 | use Lexik\Bundle\FormFilterBundle\Filter\Form\Type\NumberRangeFilterType; |
8 | use Lexik\Bundle\FormFilterBundle\Filter\Form\Type\DateRangeFilterType; | |
9 | use Lexik\Bundle\FormFilterBundle\Filter\Form\Type\TextFilterType; | |
10 | use Lexik\Bundle\FormFilterBundle\Filter\Form\Type\CheckboxFilterType; | |
11 | use Lexik\Bundle\FormFilterBundle\Filter\Form\Type\ChoiceFilterType; | |
26864574 NL |
12 | use Symfony\Component\Form\AbstractType; |
13 | use Symfony\Component\Form\FormBuilderInterface; | |
14 | use Symfony\Component\OptionsResolver\OptionsResolver; | |
1d76102a | 15 | use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorage; |
26864574 NL |
16 | |
17 | class EntryFilterType extends AbstractType | |
18 | { | |
d4ebe5c5 JB |
19 | private $user; |
20 | private $repository; | |
21 | ||
22 | /** | |
cfb28c9d | 23 | * Repository & user are used to get a list of language entries for this user. |
d4ebe5c5 JB |
24 | * |
25 | * @param EntityRepository $entryRepository | |
1d76102a | 26 | * @param TokenStorage $token |
d4ebe5c5 | 27 | */ |
1d76102a | 28 | public function __construct(EntityRepository $entryRepository, TokenStorage $token) |
d4ebe5c5 JB |
29 | { |
30 | $this->repository = $entryRepository; | |
1d76102a | 31 | $this->user = $token->getToken()->getUser(); |
d4ebe5c5 JB |
32 | } |
33 | ||
26864574 NL |
34 | public function buildForm(FormBuilderInterface $builder, array $options) |
35 | { | |
3c5b025a | 36 | $builder |
4094ea47 | 37 | ->add('readingTime', NumberRangeFilterType::class, [ |
d8f8a590 NL |
38 | 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) { |
39 | $value = $values['value']; | |
40 | ||
41 | $min = (int) ($value['left_number'][0] * $this->user->getConfig()->getReadingSpeed()); | |
42 | $max = (int) ($value['right_number'][0] * $this->user->getConfig()->getReadingSpeed()); | |
43 | ||
44 | $expression = $filterQuery->getExpr()->between($field, $min, $max); | |
45 | ||
46 | return $filterQuery->createCondition($expression); | |
47 | }, | |
0d42217e | 48 | 'label' => 'entry.filters.reading_time.label', |
4094ea47 JB |
49 | ]) |
50 | ->add('createdAt', DateRangeFilterType::class, [ | |
51 | 'left_date_options' => [ | |
52 | 'attr' => [ | |
8ce32af6 | 53 | 'placeholder' => 'dd/mm/yyyy', |
4094ea47 | 54 | ], |
3c5b025a | 55 | 'format' => 'dd/MM/yyyy', |
8ce32af6 | 56 | 'widget' => 'single_text', |
4094ea47 JB |
57 | ], |
58 | 'right_date_options' => [ | |
59 | 'attr' => [ | |
8ce32af6 | 60 | 'placeholder' => 'dd/mm/yyyy', |
4094ea47 | 61 | ], |
3c5b025a | 62 | 'format' => 'dd/MM/yyyy', |
8ce32af6 | 63 | 'widget' => 'single_text', |
4094ea47 | 64 | ], |
0d42217e | 65 | 'label' => 'entry.filters.created_at.label', |
4094ea47 | 66 | ] |
7d6c3edc | 67 | ) |
4094ea47 | 68 | ->add('domainName', TextFilterType::class, [ |
8ce32af6 | 69 | 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) { |
1d76102a JB |
70 | $value = $values['value']; |
71 | if (strlen($value) <= 2 || empty($value)) { | |
72 | return; | |
73 | } | |
74 | $expression = $filterQuery->getExpr()->like($field, $filterQuery->getExpr()->literal('%'.$value.'%')); | |
8ce32af6 | 75 | |
1d76102a | 76 | return $filterQuery->createCondition($expression); |
a3bcd60a | 77 | }, |
0d42217e | 78 | 'label' => 'entry.filters.domain_label', |
4094ea47 JB |
79 | ]) |
80 | ->add('isArchived', CheckboxFilterType::class, [ | |
0d42217e | 81 | 'label' => 'entry.filters.archived_label', |
4094ea47 JB |
82 | ]) |
83 | ->add('isStarred', CheckboxFilterType::class, [ | |
0d42217e | 84 | 'label' => 'entry.filters.starred_label', |
4094ea47 JB |
85 | ]) |
86 | ->add('previewPicture', CheckboxFilterType::class, [ | |
a3bcd60a | 87 | 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) { |
497e0cad | 88 | if (false === $values['value']) { |
616f9fea NL |
89 | return; |
90 | } | |
91 | ||
a3bcd60a NL |
92 | $expression = $filterQuery->getExpr()->isNotNull($field); |
93 | ||
94 | return $filterQuery->createCondition($expression); | |
95 | }, | |
0d42217e | 96 | 'label' => 'entry.filters.preview_picture_label', |
4094ea47 JB |
97 | ]) |
98 | ->add('language', ChoiceFilterType::class, [ | |
5c895a7f JB |
99 | 'choices' => array_flip($this->repository->findDistinctLanguageByUser($this->user->getId())), |
100 | 'choices_as_values' => true, | |
0d42217e | 101 | 'label' => 'entry.filters.language_label', |
4094ea47 | 102 | ]) |
d4ebe5c5 | 103 | ; |
26864574 NL |
104 | } |
105 | ||
619cc453 | 106 | public function getBlockPrefix() |
26864574 NL |
107 | { |
108 | return 'entry_filter'; | |
109 | } | |
110 | ||
111 | public function configureOptions(OptionsResolver $resolver) | |
112 | { | |
4094ea47 | 113 | $resolver->setDefaults([ |
8ce32af6 | 114 | 'csrf_protection' => false, |
4094ea47 JB |
115 | 'validation_groups' => ['filtering'], |
116 | ]); | |
26864574 NL |
117 | } |
118 | } |