proteins/filter

Class trait for permitting users to override data via callback hooks

1.0.3 2019-05-28 14:29 UTC

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