proteins / filter
Class trait for permitting users to override data via callback hooks
Requires
- php: ^7.2
This package is auto-updated.
Last update: 2024-10-29 05:46:52 UTC
README
Protein | Filter
Class trait for permitting users to override data via callback hooks
Install
composer require proteins/filter
Require the global class via :
use Proteins\Filter;
or the include the trait in your classes via :
use Proteins\Filters; class MyClass { use Filters; }
Adding a filter
You can attach a filter function to a custom named group via the add
method.
Filter::add('title',function($title){ return strtoupper($title); });
Multiple calls to the same group attach multiple filter functions.
// Concatenate effects : Filter::add('title',function($title){ return strtoupper($title); }); Filter::add('title',function($title){ return $title . '!'; });
You can assign a single callback to multiple filters defining them with an array of keys :
Filter::add(['href','src'], function($link){ return BASE_URL . $link; });
This is the same as :
Filter::add('href', function($link){ return BASE_URL . $link; }); Filter::add('src', function($link){ return BASE_URL . $link; });
You can also pass an array map filter => callback :
Filter::add([ 'src' => function($src){ return BASE_URL . $src; }, 'href' => function($href){ return HTTPS . $href; }, ]);
This is the same as :
Filter::add('href', function($href){ return HTTPS . $href; }); Filter::add('src', function($src){ return BASE_URL . $src; });
Removing a filter
You can remove an attached filter function to a custom named group via the remove
method.
$the_filter = function($title){ return strtoupper($title); }; Filter::add('title',$the_filter); ... Filter::remove('title',$the_filter);
You can remove all filters attached to a group by not passing the filter function.
Filter::remove('title');
Applying a filter
You can apply a filter to a value via the with
method.
Filter::with('title','This was a triumph')
Example
Filter::add('title',function($title){ return strtoupper($title); }); Filter::add('title',function($title){ return $title . '!'; }); echo Filter::with('title','This was a triumph'); // THIS WAS A TRIUMPH!
Multiple fallback keys can be passed, the first non-empty queue will be used for the current filter.
Filter::with(["document.title", "title"],'This was a triumph')
Example
Filter::add("title", "strtoupper"); echo Filter::with(["document.title", "title"],'This was a triumph');
The title
filter will be executed instead of the empty document.title
.
THIS WAS A TRIUMPH
Filter::add("title", "strtoupper"); Filter::add("document.title", "str_rot13"); echo Filter::with(["document.title", "title"],'This was a triumph');
Here the document.title
filter will be executed instead of title
.
Guvf jnf n gevhzcu