Filter
Overview:
Filter is a global filter registry built on the Filters trait. It provides class-level methods aliased to filter, filterSingle, and filterWith.
Use Filter to let application or plugin code override calculated values through named transformation chains.
Public API:
Filter::add($name, callable $modder)adds a filter.Filter::single($name, callable $modder)replaces filters.Filter::remove($name, callable $modder = null)removes filters.Filter::with($name, $default, ...$args)applies filters.
The Filter module allow you to permit user overrides to certain values.
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 :
```php
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 :
```php
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