function sanitize( $value, $type = null )
{
// Recursive sanitation for arrays and objects
if ( is_array( $value ) || is_object( $value ) ) {
$output = array();
foreach ( (array) $value as $k => $v ) {
$k = sanitize_key( $k );
$output[$k] = sanitize( $v, $type );
}
return $output;
}
// Default to value's actual type
if ( ! $type ) { $type = gettype( $value ); }
switch( strtolower( $type ) )
{
case 'boolean':
return boolval( $value );
case 'integer':
case 'number':
return intval( $value );
case 'double':
case 'float':
return floatval( $value );
case 'null':
return null;
case 'resource':
return $value;
case 'url':
return filter_var( rtrim( $value, '/' ), FILTER_SANITIZE_URL );
case 'email':
return filter_var( substr( $value, 0, 254 ), FILTER_SANITIZE_EMAIL );
default:
// String
return filter_var( $value, FILTER_SANITIZE_STRING );
}
}
Is the Request Made with Ajax ?
function is_ajax_request() {
return ! empty( $_SERVER['HTTP_X_REQUESTED_WITH'] )
&& strtolower( $_SERVER['HTTP_X_REQUESTED_WITH'] ) === 'xmlhttprequest';
}
Is the Browser Older Than Internet Explorer $version ?
function is_lt_ie( $version = 8 )
{
preg_match( '/MSIE (.*?);/', $_SERVER['HTTP_USER_AGENT'], $matches );
if ( ! isset( $matches[1] ) ) {
preg_match( '/Trident/d{1,2}.d{1,2}; rv:([0-9]*)/', $_SERVER['HTTP_USER_AGENT'], $matches );
}
return ( isset( $matches[1] ) && $matches[1] < $version );
}
Open files or folders in Atom from OSX Finder
Mac computers come with the Automator application.
Open it.
Create a new “Service” : File > New > Service.
In the library of actions on the left sidebar, you will find one called Run Shell Script : add it to the workflow.
Set the service to receive selected files or folders, the shell as /bin/zsh, and the input to be passed as arguments.
Then enter /Applications/Atom.app/Contents/MacOS/Atom -n $@
in the text area.
Finally, save the workflow as “Open in Atom”.
And you are done !
Dynamic layout jQuery plugin
A very simple jQuery plugin that will turn your grid columns into tiles. Compatible with Bootstrap 3.
https://gist.github.com/WebMaestroFr/9481254
$('#my-grid-container').wmTiles();
Sass Compiler for WordPress
It uses the scssphp Compiler.
Installation
- Download the latest release
- Unzip it into your wp-content/plugins directory
- Activate the plugin in WordPress
Compiler
This first page allows you to write and compile Sass. The resulting stylesheet is automatically enqueued.
Variables
This second page lists all registered variables, and allows you to edit their values upon compiling.
PHP Configuration
add_filter( 'sass_configuration', 'my_sass_config' );
function my_sass_config( $defaults ) {
return array(
'variables' => array( 'sass/_variables.scss' ),
'imports' => array( 'sass/bootstrap.scss', 'sass/_theme.scss' )
);
}
Configuration of the plugin is optional, but you should at least register your variables if you are using a CSS framework.
Paths to Sass files are relative to the theme directory.
Use the filter 'sass_configuration'
to return your configurations array.
- ‘variables‘ (array)
In order to list and edit your Sass variables on the plugin dedicated page, it is necessary to register their “definition” file(s). It is assumed that those files’ only role is to declare variables and their values. - ‘imports‘ (array)
It will prepend the code to compile with an@import
directive for each listed file. Useful to compile dependencies, and to “hide” them from the Compiler page. It is necessary to hit the “Compile” button once for these imports to be compiled. - ‘cache‘ (string)
Allows you to define the path to your cache directory. This directory has to be writable (0755
). The default cache directory path iswp-content/cache
. - ‘search‘ (boolean)
Wether or not to display the “Search Variables” filter box. It can come handy if you have a lot of variables. Default istrue
.
Once registered, you can access any variables with the function sass_get( 'my-variable' );
, or override its value (upon what has been set on the Variables page) with sass_set( 'my-variable', 'my-value' )
.
It is also possible to use @import
directives, as well as any Sass language features, straight from the Compiler page.
Enqueuing external Sass
Out of the main stylesheet, simply use the WordPress wp_enqueue_style
function to enqueue separated Sass files.
add_action( 'wp_enqueue_scripts', 'my_other_sass_enqueue' );
function my_other_sass_enqueue() {
wp_enqueue_style( 'my-other-handle', get_template_directory_uri() . '/my-other-file.scss', array( 'wm-sass' ) );
}
It will be compared to the cached version, compiled if changes occurred, and the resulting stylesheet will be enqueued.
Don’t forget to set the main Sass stylesheet handle 'wm-sass'
as a dependency (… if it is one).