2017 © Pedro Peláez
 

library doctrine-orm-searchable-repository

Make your Doctrine's EntityRepository Searchable

image

saf/doctrine-orm-searchable-repository

Make your Doctrine's EntityRepository Searchable

  • Wednesday, February 22, 2017
  • by vincenttouzet
  • Repository
  • 1 Watchers
  • 0 Stars
  • 5 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 3 Versions
  • 67 % Grown

The README.md

doctrine-orm-searchable-repository

This library extends the EntityRepository to add search functionality with a lot of filters., (*1)

$filters = [
    'name'        => ['neq' => 'My name'],
    'author.name' => ['in' => ['Foo', 'Bar']],
    'rating'      => ['gte' => 4],
];

$orders = [
    'author.name' => 'ASC',
    'name'        => 'DESC',
];

$entities = $repository->search($filters, $orders);

You can even perform search of a value on multiple columns:, (*2)

$filters = [
    'name' => [
        'field'     => ['firstName', 'lastName],
        'condition' => 'like',
        'value'     => '%Lewis%',
    ],
];

$orders = [
    'author.name' => 'ASC',
    'name'        => 'DESC',
];

$entities = $repository->search($filters, $orders);

This will result in the following condition :, (*3)

firstName like '%Lewis%' OR lastName like '%Lewis%'

How to use

Install using composer, (*4)

composer require saf/doctrine-orm-searchable-repository

And just make your repository class extends SAF\SearchableRepository\SearchableRepository., (*5)


use SAF\SearchableRepository\SearchableRepository; class MyRepository extends SearchableRepository { // ... }

Then you can access the search method on your repository., (*6)

Filters

This library use filter types to handle how to apply filter condition and ordering. It comes with a GenericType that is the default one but you can add a new filter type., (*7)

// add a new type handler to your search with the setType function
// the first parameter correspond to the doctrine type
// the second parameter is the filter type (that must implements \SAF\SearchableRepository\SearchableRepository\Types\TypeInterface interface)
$repository->setType('string', new MyStringFilterType());

GenericType

Filter Supported value Behavior
eq mixed Filter elements that match the given value
neq mixed Filter elements that not match the given value
lt mixed Filter elements with value less than the given value
lte mixed Filter elements with value less than or equals the given value
gt mixed Filter elements with value greater than the given value
gte mixed Filter elements with value greater than or equals the given value
like string Use a LIKE statement to filter elements
not_like string Use a NOT LIKE statement to filter elements
null boolean true: filter elements with a null value false : filter elements with a non-null value
not_null boolean true: filter elements with a non-null value false: filter elements with a null value
in array Filter elements with value in the given array
not_in array Filter elements with value not in the given array

The Versions

22/02 2017

dev-master

9999999-dev

Make your Doctrine's EntityRepository Searchable

  Sources   Download

MIT

The Requires

 

The Development Requires

by Vincent Touzet

orm database

22/02 2017

0.1.1

0.1.1.0

Make your Doctrine's EntityRepository Searchable

  Sources   Download

MIT

The Requires

 

The Development Requires

by Vincent Touzet

orm database

20/02 2017

0.1.0

0.1.0.0

Make your Doctrine's EntityRepository Searchable

  Sources   Download

MIT

The Requires

 

The Development Requires

by Vincent Touzet

orm database