]> git.immae.eu Git - github/wallabag/wallabag.git/blame - src/Wallabag/CoreBundle/Form/Type/EntryFilterType.php
Replaced TokenStorage with TokenStorageInterface
[github/wallabag/wallabag.git] / src / Wallabag / CoreBundle / Form / Type / EntryFilterType.php
CommitLineData
26864574
NL
1<?php
2
b0b893ea 3namespace Wallabag\CoreBundle\Form\Type;
26864574 4
619cc453
JB
5use Doctrine\ORM\EntityRepository;
6use Lexik\Bundle\FormFilterBundle\Filter\Query\QueryInterface;
5c895a7f
JB
7use Lexik\Bundle\FormFilterBundle\Filter\Form\Type\NumberRangeFilterType;
8use Lexik\Bundle\FormFilterBundle\Filter\Form\Type\DateRangeFilterType;
9use Lexik\Bundle\FormFilterBundle\Filter\Form\Type\TextFilterType;
10use Lexik\Bundle\FormFilterBundle\Filter\Form\Type\CheckboxFilterType;
11use Lexik\Bundle\FormFilterBundle\Filter\Form\Type\ChoiceFilterType;
26864574
NL
12use Symfony\Component\Form\AbstractType;
13use Symfony\Component\Form\FormBuilderInterface;
14use Symfony\Component\OptionsResolver\OptionsResolver;
1d76102a 15use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorage;
2fe2e411 16use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
26864574
NL
17
18class EntryFilterType extends AbstractType
19{
d4ebe5c5
JB
20 private $user;
21 private $repository;
22
23 /**
cfb28c9d 24 * Repository & user are used to get a list of language entries for this user.
d4ebe5c5
JB
25 *
26 * @param EntityRepository $entryRepository
1d76102a 27 * @param TokenStorage $token
d4ebe5c5 28 */
2fe2e411 29 public function __construct(EntityRepository $entryRepository, TokenStorageInterface $tokenStorage)
d4ebe5c5
JB
30 {
31 $this->repository = $entryRepository;
2fe2e411
NL
32
33 $this->user = $tokenStorage->getToken() ? $tokenStorage->getToken()->getUser() : null;
34
35 if (null === $this->user || !is_object($this->user)) {
36 return null;
37 }
d4ebe5c5
JB
38 }
39
26864574
NL
40 public function buildForm(FormBuilderInterface $builder, array $options)
41 {
3c5b025a 42 $builder
4094ea47 43 ->add('readingTime', NumberRangeFilterType::class, [
d8f8a590 44 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) {
1bdbc39f
JB
45 $lower = $values['value']['left_number'][0];
46 $upper = $values['value']['right_number'][0];
d8f8a590 47
1bdbc39f
JB
48 $min = (int) ($lower * $this->user->getConfig()->getReadingSpeed());
49 $max = (int) ($upper * $this->user->getConfig()->getReadingSpeed());
50
51 if (null === $lower && null === $upper) {
52 // no value? no filter
d6a9e139 53 return;
2c00dddf 54 } elseif (null === $lower && null !== $upper) {
1bdbc39f
JB
55 // only lower value is defined: query all entries with reading LOWER THAN this value
56 $expression = $filterQuery->getExpr()->lte($field, $max);
2c00dddf 57 } elseif (null !== $lower && null === $upper) {
1bdbc39f
JB
58 // only upper value is defined: query all entries with reading GREATER THAN this value
59 $expression = $filterQuery->getExpr()->gte($field, $min);
60 } else {
61 // both value are defined, perform a between
62 $expression = $filterQuery->getExpr()->between($field, $min, $max);
d6a9e139
NL
63 }
64
d8f8a590
NL
65 return $filterQuery->createCondition($expression);
66 },
0d42217e 67 'label' => 'entry.filters.reading_time.label',
4094ea47
JB
68 ])
69 ->add('createdAt', DateRangeFilterType::class, [
70 'left_date_options' => [
71 'attr' => [
8ce32af6 72 'placeholder' => 'dd/mm/yyyy',
4094ea47 73 ],
3c5b025a 74 'format' => 'dd/MM/yyyy',
8ce32af6 75 'widget' => 'single_text',
4094ea47
JB
76 ],
77 'right_date_options' => [
78 'attr' => [
8ce32af6 79 'placeholder' => 'dd/mm/yyyy',
4094ea47 80 ],
3c5b025a 81 'format' => 'dd/MM/yyyy',
8ce32af6 82 'widget' => 'single_text',
4094ea47 83 ],
0d42217e 84 'label' => 'entry.filters.created_at.label',
4094ea47 85 ]
7d6c3edc 86 )
4094ea47 87 ->add('domainName', TextFilterType::class, [
8ce32af6 88 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) {
1d76102a
JB
89 $value = $values['value'];
90 if (strlen($value) <= 2 || empty($value)) {
91 return;
92 }
93 $expression = $filterQuery->getExpr()->like($field, $filterQuery->getExpr()->literal('%'.$value.'%'));
8ce32af6 94
1d76102a 95 return $filterQuery->createCondition($expression);
a3bcd60a 96 },
0d42217e 97 'label' => 'entry.filters.domain_label',
4094ea47
JB
98 ])
99 ->add('isArchived', CheckboxFilterType::class, [
0d42217e 100 'label' => 'entry.filters.archived_label',
4094ea47
JB
101 ])
102 ->add('isStarred', CheckboxFilterType::class, [
0d42217e 103 'label' => 'entry.filters.starred_label',
4094ea47 104 ])
733b2cf1
DB
105 ->add('isUnread', CheckboxFilterType::class, [
106 'label' => 'entry.filters.unread_label',
107 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) {
108 if (false === $values['value']) {
109 return;
110 }
111
112 $expression = $filterQuery->getExpr()->eq('e.isArchived', 'false');
113
114 return $filterQuery->createCondition($expression);
115 },
116 ])
4094ea47 117 ->add('previewPicture', CheckboxFilterType::class, [
a3bcd60a 118 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) {
497e0cad 119 if (false === $values['value']) {
616f9fea
NL
120 return;
121 }
122
a3bcd60a
NL
123 $expression = $filterQuery->getExpr()->isNotNull($field);
124
125 return $filterQuery->createCondition($expression);
126 },
0d42217e 127 'label' => 'entry.filters.preview_picture_label',
4094ea47
JB
128 ])
129 ->add('language', ChoiceFilterType::class, [
5c895a7f 130 'choices' => array_flip($this->repository->findDistinctLanguageByUser($this->user->getId())),
0d42217e 131 'label' => 'entry.filters.language_label',
4094ea47 132 ])
d4ebe5c5 133 ;
26864574
NL
134 }
135
619cc453 136 public function getBlockPrefix()
26864574
NL
137 {
138 return 'entry_filter';
139 }
140
141 public function configureOptions(OptionsResolver $resolver)
142 {
4094ea47 143 $resolver->setDefaults([
8ce32af6 144 'csrf_protection' => false,
4094ea47
JB
145 'validation_groups' => ['filtering'],
146 ]);
26864574
NL
147 }
148}