public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
- ->add('readingTime', NumberRangeFilterType::class)
- ->add('createdAt', DateRangeFilterType::class, array(
- 'left_date_options' => array(
- 'attr' => array(
+ ->add('readingTime', NumberRangeFilterType::class, [
+ 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) {
+ $lower = $values['value']['left_number'][0];
+ $upper = $values['value']['right_number'][0];
+
+ $min = (int) ($lower * $this->user->getConfig()->getReadingSpeed());
+ $max = (int) ($upper * $this->user->getConfig()->getReadingSpeed());
+
+ if (null === $lower && null === $upper) {
+ // no value? no filter
+ return;
+ } elseif (null === $lower && null !== $upper) {
+ // only lower value is defined: query all entries with reading LOWER THAN this value
+ $expression = $filterQuery->getExpr()->lte($field, $max);
+ } elseif (null !== $lower && null === $upper) {
+ // only upper value is defined: query all entries with reading GREATER THAN this value
+ $expression = $filterQuery->getExpr()->gte($field, $min);
+ } else {
+ // both value are defined, perform a between
+ $expression = $filterQuery->getExpr()->between($field, $min, $max);
+ }
+
+ return $filterQuery->createCondition($expression);
+ },
+ 'label' => 'entry.filters.reading_time.label',
+ ])
+ ->add('createdAt', DateRangeFilterType::class, [
+ 'left_date_options' => [
+ 'attr' => [
'placeholder' => 'dd/mm/yyyy',
- ),
+ ],
'format' => 'dd/MM/yyyy',
'widget' => 'single_text',
- ),
- 'right_date_options' => array(
- 'attr' => array(
+ ],
+ 'right_date_options' => [
+ 'attr' => [
'placeholder' => 'dd/mm/yyyy',
- ),
+ ],
'format' => 'dd/MM/yyyy',
'widget' => 'single_text',
- ),
- )
+ ],
+ 'label' => 'entry.filters.created_at.label',
+ ]
)
- ->add('domainName', TextFilterType::class, array(
+ ->add('domainName', TextFilterType::class, [
'apply_filter' => function (QueryInterface $filterQuery, $field, $values) {
$value = $values['value'];
if (strlen($value) <= 2 || empty($value)) {
return $filterQuery->createCondition($expression);
},
- ))
- ->add('isArchived', CheckboxFilterType::class)
- ->add('isStarred', CheckboxFilterType::class)
- ->add('previewPicture', CheckboxFilterType::class, array(
+ 'label' => 'entry.filters.domain_label',
+ ])
+ ->add('isArchived', CheckboxFilterType::class, [
+ 'label' => 'entry.filters.archived_label',
+ ])
+ ->add('isStarred', CheckboxFilterType::class, [
+ 'label' => 'entry.filters.starred_label',
+ ])
+ ->add('isUnread', CheckboxFilterType::class, [
+ 'label' => 'entry.filters.unread_label',
+ 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) {
+ if (false === $values['value']) {
+ return;
+ }
+
+ $expression = $filterQuery->getExpr()->eq('e.isArchived', 'false');
+
+ return $filterQuery->createCondition($expression);
+ },
+ ])
+ ->add('previewPicture', CheckboxFilterType::class, [
'apply_filter' => function (QueryInterface $filterQuery, $field, $values) {
if (false === $values['value']) {
return;
return $filterQuery->createCondition($expression);
},
- ))
- ->add('language', ChoiceFilterType::class, array(
+ 'label' => 'entry.filters.preview_picture_label',
+ ])
+ ->add('language', ChoiceFilterType::class, [
'choices' => array_flip($this->repository->findDistinctLanguageByUser($this->user->getId())),
- 'choices_as_values' => true,
- ))
+ 'label' => 'entry.filters.language_label',
+ ])
;
}
public function configureOptions(OptionsResolver $resolver)
{
- $resolver->setDefaults(array(
+ $resolver->setDefaults([
'csrf_protection' => false,
- 'validation_groups' => array('filtering'),
- ));
+ 'validation_groups' => ['filtering'],
+ ]);
}
}