-
Notifications
You must be signed in to change notification settings - Fork 10
Filter
The Filter module allow you to permit user overrides to certain values.
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; });
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');
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
Core is maintained by using the Semantic Versioning Specification (SemVer).
Copyright 2014-2016 Caffeina srl under the MIT license.
http://caffeina.com