*/ class TextFilter { use FilterTrait; public function buildProperty(FormBuilderInterface $builder, FieldDto $fieldDto, $options = array()) { $builder->add( str_replace('.', '_', $fieldDto->getProperty()), TextType::class, array( 'required' => false, 'attr' => array( 'class' => ' input-sm', 'form' => 'filters-form', ), ) ); } public function applyFilter(QueryBuilder $queryBuilder, string $fieldProperty, string $filteredValue = null) { if ($filteredValue !== null) { if ($this->isRelationField($fieldProperty)) { $aliasRelation = $this->getFieldPropertyRelationAlias($fieldProperty); if (array_search($aliasRelation, $queryBuilder->getAllAliases()) === false) { $queryBuilder->innerJoin('entity.' . $aliasRelation, $aliasRelation); } $queryBuilder->andWhere( $fieldProperty . ' LIKE :' . $this->getFieldPropertySnake($fieldProperty) . '' ); $queryBuilder->setParameter( $this->getFieldPropertySnake($fieldProperty), '%' . $filteredValue . '%' ); } else { $queryBuilder->andWhere( 'entity.' . $fieldProperty . ' LIKE :' . $fieldProperty . '' ); $queryBuilder->setParameter($fieldProperty, '%' . $filteredValue . '%'); } } } }