3 namespace Wallabag\CoreBundle\Form\Type
;
5 use Doctrine\ORM\EntityRepository
;
6 use Lexik\Bundle\FormFilterBundle\Filter\Query\QueryInterface
;
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
;
12 use Symfony\Component\Form\AbstractType
;
13 use Symfony\Component\Form\FormBuilderInterface
;
14 use Symfony\Component\OptionsResolver\OptionsResolver
;
15 use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorage
;
17 class EntryFilterType
extends AbstractType
23 * Repository & user are used to get a list of language entries for this user.
25 * @param EntityRepository $entryRepository
26 * @param TokenStorage $token
28 public function __construct(EntityRepository
$entryRepository, TokenStorage
$token)
30 $this->repository
= $entryRepository;
31 $this->user
= $token->getToken()->getUser();
34 public function buildForm(FormBuilderInterface
$builder, array $options)
37 ->add('readingTime', NumberRangeFilterType
::class, [
38 'apply_filter' => function (QueryInterface
$filterQuery, $field, $values) {
39 $value = $values['value'];
41 if (null === $value['left_number'][0] || null === $value['right_number'][0]) {
45 $min = (int) ($value['left_number'][0] * $this->user
->getConfig()->getReadingSpeed());
46 $max = (int) ($value['right_number'][0] * $this->user
->getConfig()->getReadingSpeed());
48 $expression = $filterQuery->getExpr()->between($field, $min, $max);
50 return $filterQuery->createCondition($expression);
52 'label' => 'entry.filters.reading_time.label',
54 ->add('createdAt', DateRangeFilterType
::class, [
55 'left_date_options' => [
57 'placeholder' => 'dd/mm/yyyy',
59 'format' => 'dd/MM/yyyy',
60 'widget' => 'single_text',
62 'right_date_options' => [
64 'placeholder' => 'dd/mm/yyyy',
66 'format' => 'dd/MM/yyyy',
67 'widget' => 'single_text',
69 'label' => 'entry.filters.created_at.label',
72 ->add('domainName', TextFilterType
::class, [
73 'apply_filter' => function (QueryInterface
$filterQuery, $field, $values) {
74 $value = $values['value'];
75 if (strlen($value) <= 2 || empty($value)) {
78 $expression = $filterQuery->getExpr()->like($field, $filterQuery->getExpr()->literal('%'.$value.'%'));
80 return $filterQuery->createCondition($expression);
82 'label' => 'entry.filters.domain_label',
84 ->add('isArchived', CheckboxFilterType
::class, [
85 'label' => 'entry.filters.archived_label',
87 ->add('isStarred', CheckboxFilterType
::class, [
88 'label' => 'entry.filters.starred_label',
90 ->add('isUnread', CheckboxFilterType
::class, [
91 'label' => 'entry.filters.unread_label',
92 'apply_filter' => function (QueryInterface
$filterQuery, $field, $values) {
93 if (false === $values['value']) {
97 $expression = $filterQuery->getExpr()->eq('e.isArchived', 'false');
99 return $filterQuery->createCondition($expression);
102 ->add('previewPicture', CheckboxFilterType
::class, [
103 'apply_filter' => function (QueryInterface
$filterQuery, $field, $values) {
104 if (false === $values['value']) {
108 $expression = $filterQuery->getExpr()->isNotNull($field);
110 return $filterQuery->createCondition($expression);
112 'label' => 'entry.filters.preview_picture_label',
114 ->add('language', ChoiceFilterType
::class, [
115 'choices' => array_flip($this->repository
->findDistinctLanguageByUser($this->user
->getId())),
116 'choices_as_values' => true,
117 'label' => 'entry.filters.language_label',
122 public function getBlockPrefix()
124 return 'entry_filter';
127 public function configureOptions(OptionsResolver
$resolver)
129 $resolver->setDefaults([
130 'csrf_protection' => false,
131 'validation_groups' => ['filtering'],