use Lexik\Bundle\FormFilterBundle\Filter\Form\Type\ChoiceFilterType;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\FormBuilderInterface;
+use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\OptionsResolver\OptionsResolver;
-use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorage;
+use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
class EntryFilterType extends AbstractType
{
/**
* Repository & user are used to get a list of language entries for this user.
*
- * @param EntityRepository $entryRepository
- * @param TokenStorage $token
+ * @param EntityRepository $entryRepository
+ * @param TokenStorageInterface $tokenStorage
*/
- public function __construct(EntityRepository $entryRepository, TokenStorage $token)
+ public function __construct(EntityRepository $entryRepository, TokenStorageInterface $tokenStorage)
{
$this->repository = $entryRepository;
- $this->user = $token->getToken()->getUser();
+
+ $this->user = $tokenStorage->getToken() ? $tokenStorage->getToken()->getUser() : null;
+
+ if (null === $this->user || !is_object($this->user)) {
+ return null;
+ }
}
public function buildForm(FormBuilderInterface $builder, array $options)
$builder
->add('readingTime', NumberRangeFilterType::class, [
'apply_filter' => function (QueryInterface $filterQuery, $field, $values) {
- $value = $values['value'];
+ $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 === $value['left_number'][0] || null === $value['right_number'][0]) {
+ 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);
}
- $min = (int) ($value['left_number'][0] * $this->user->getConfig()->getReadingSpeed());
- $max = (int) ($value['right_number'][0] * $this->user->getConfig()->getReadingSpeed());
-
- $expression = $filterQuery->getExpr()->between($field, $min, $max);
-
return $filterQuery->createCondition($expression);
},
'label' => 'entry.filters.reading_time.label',
if (strlen($value) <= 2 || empty($value)) {
return;
}
- $expression = $filterQuery->getExpr()->like($field, $filterQuery->getExpr()->literal('%'.$value.'%'));
+ $expression = $filterQuery->getExpr()->like($field, $filterQuery->getExpr()->lower($filterQuery->getExpr()->literal('%'.$value.'%')));
return $filterQuery->createCondition($expression);
},
'label' => 'entry.filters.domain_label',
])
+ ->add('httpStatus', TextFilterType::class, [
+ 'apply_filter' => function (QueryInterface $filterQuery, $field, $values) {
+ $value = $values['value'];
+ if (false === array_key_exists($value, Response::$statusTexts)) {
+ return;
+ }
+
+ $paramName = sprintf('%s', str_replace('.', '_', $field));
+ $expression = $filterQuery->getExpr()->eq($field, ':'.$paramName);
+ $parameters = array($paramName => $value);
+
+ return $filterQuery->createCondition($expression, $parameters);
+ },
+ 'label' => 'entry.filters.http_status_label',
+ ])
->add('isArchived', CheckboxFilterType::class, [
'label' => 'entry.filters.archived_label',
])
])
->add('language', ChoiceFilterType::class, [
'choices' => array_flip($this->repository->findDistinctLanguageByUser($this->user->getId())),
- 'choices_as_values' => true,
'label' => 'entry.filters.language_label',
])
;