/data-filter

Easily filter data with an encoded filter param in the uri

Primary LanguagePHPMIT LicenseMIT

Data-filter

Easily filter data with an encoded filter param in the uri.

Requirements

This package requires PHP 5.6+.

Installation

This package can be used in any PHP project or with any framework. The package is tested in PHP 5.6 and PHP 7.0.

You can install the package via composer:

composer require vdhicts/data-filter

Usage

Filter Field

Creating field is based on a key and a value:

$fieldKey = 'manufacturer';
$fieldValue = 1;

$field = new Field($fieldKey, $fieldValue);

A field has the ability to accept, reject or see the value as part of a range with a third optional parameter. These parameters are constants of the field APPROVAL_ACCEPT, APPROVAL_REJECT, APPROVAL_START_OF_RANGE, APPROVAL_END_OF_RANGE, APPROVAL_IN, APPROVAL_NOT_IN, APPROVAL_LIKE and APPROVAL_ILIKE (which can only be used if your Database supports it, like Postgres).

Filter Group

The field is a member of a group. The group has a conjunction, which are constants of the group called CONJUNCTION_AND and CONJUCTION_OR.

$group = new Group('manufacturers', $field, Group::CONJUNCTION_OR);

One or more groups are provided to the filter:

$filter = new Filter([$group]);

Order

The sort order can be defined by OrderField objects:

$orderField = new Orderfield('myField', 'ASC');

These objects are added to the order:

$order = new Order([$orderField2]);

Pagination

The pagination is handled by the Pagination object:

$limit = 50;
$offset = 10;
$pagination = new Pagination($limit, $offset);

The remove the limit, use the NO_LIMIT constant from the Pagination class. By default no limit is used and the offset is zero.

Manager

The manager can encode and decode the filter so it can be used in the url or session. The actual encoding or decoding is performed by a Codec which implements the Codec contract. By default a Base64 codec is provided.

$manager = new Manager(new Base64());
$encodedFilter = $manager->encode($filter);

The manager can decode the filter and will return a new filter instance:

$decodedFilter = $manager->decode($encodedFilter);

A group can be retrieved by it's name from the filter:

$decodedFilter->getGroup('manufacturers');

Which will return a Group object.

Fields can also be retrieved by their key from the group:

$group->getFields('manufacturer');

Which will return an array of groups.

Adapter

A query builder is provided to easily query your database with the filter configuration for the illuminate query builder:

$filterAdapter = new QueryBuilder();

$queryBuilder = $filterAdapter->getFilterQuery($queryBuilder, $decodedFilter);
return $queryBuilder->get();

You are free to implement your own adapter, as long as it implements the FilterAdapter contract.

Tests

Full code coverage unit tests are available in the tests folder. Run via phpunit:

vendor\bin\phpunit

By default a coverage report will be generated in the build/coverage folder.

Contribution

Any contribution is welcome, but it should be fully tested, meet the PSR-2 standard and please create one pull request per feature. In exchange you will be credited as contributor on this page.

Security

If you discover any security related issues in this or other packages of Vdhicts, please email info@vdhicts.nl instead of using the issue tracker.

License

This package is open-sourced software licensed under the MIT license

About vdhicts

Van der Heiden ICT services is the name of my personal company for which I work as freelancer. Van der Heiden ICT services develops and implements IT solutions for businesses and educational institutions.