+ ->add('readingTime', NumberRangeFilterType::class, [
+ 'left_number_options' => [
+ 'condition_operator' => FilterOperands::OPERATOR_GREATER_THAN_EQUAL,
+ 'attr' => ['min' => 0],
+ ],
+ 'right_number_options' => [
+ 'condition_operator' => FilterOperands::OPERATOR_LOWER_THAN_EQUAL,
+ 'attr' => ['min' => 0],
+ ],
+ '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' => [