HOME


Mini Shell 1.0
DIR: /var/www/yme/wp-content/plugins/ocean-extra/includes/metabox/butterbean/inc/
Upload File :
Current File : /var/www/yme/wp-content/plugins/ocean-extra/includes/metabox/butterbean/inc/functions-core.php
<?php
/**
 * Helper functions.
 *
 * @package    ButterBean
 * @subpackage Admin
 * @author     Justin Tadlock <justin@justintadlock.com>
 * @copyright  Copyright (c) 2015-2016, Justin Tadlock
 * @link       https://github.com/justintadlock/butterbean
 * @license    http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
 */

/**
 * Function for validating booleans before saving them as metadata. If the value is
 * `true`, we'll return a `1` to be stored as the meta value.  Else, we return `false`.
 *
 * @since  1.0.0
 * @access public
 * @param  mixed
 * @return bool|int
 */
function butterbean_validate_boolean( $value ) {

	return wp_validate_boolean( $value ) ? 1 : false;
}

/**
 * Pre-WP 4.6 function for sanitizing hex colors.
 *
 * @since  1.0.0
 * @access public
 * @param  string  $color
 * @return string
 */
function butterbean_sanitize_hex_color( $color ) {

	if ( function_exists( 'sanitize_hex_color' ) )
		return sanitize_hex_color( $color );

	return $color && preg_match('|^#([A-Fa-f0-9]{3}){1,2}$|', $color ) ? $color : '';
}

/**
 * Pre-WP 4.6 function for sanitizing hex colors without a hash.
 *
 * @since  1.0.0
 * @access public
 * @param  string  $color
 * @return string
 */
function butterbean_sanitize_hex_color_no_hash( $color ) {

	if ( function_exists( 'sanitize_hex_color_no_hash' ) )
		return sanitize_hex_color_no_hash( $color );

	$color = ltrim( $color, '#' );

	if ( '' === $color )
		return '';

	return butterbean_sanitize_hex_color( '#' . $color ) ? $color : null;
}

/**
 * Pre-WP 4.6 function for sanitizing a color and adding a hash.
 *
 * @since  1.0.0
 * @access public
 * @param  string  $color
 * @return string
 */
function butterbean_maybe_hash_hex_color( $color ) {

	if ( function_exists( 'maybe_hash_hex_color' ) )
		return maybe_hash_hex_color( $color );

	if ( $unhashed = butterbean_sanitize_hex_color_no_hash( $color ) )
		return '#' . $unhashed;

	return $color;
}

/**
 * Gets Underscore.js templates for managers.
 *
 * @since  1.0.0
 * @param  string  $slug
 * @return void
 */
function butterbean_get_manager_template( $slug = '' ) {
	butterbean_get_template( 'manager', $slug );
}

/**
 * Gets Underscore.js templates for navs.
 *
 * @since  1.0.0
 * @param  string  $slug
 * @return void
 */
function butterbean_get_nav_template( $slug = '' ) {
	butterbean_get_template( 'nav', $slug );
}

/**
 * Gets Underscore.js templates for sections.
 *
 * @since  1.0.0
 * @param  string  $slug
 * @return void
 */
function butterbean_get_section_template( $slug = '' ) {
	butterbean_get_template( 'section', $slug );
}

/**
 * Gets Underscore.js templates for controls.
 *
 * @since  1.0.0
 * @param  string  $slug
 * @return void
 */
function butterbean_get_control_template( $slug = '' ) {
	butterbean_get_template( 'control', $slug );
}

/**
 * Helper function for getting Underscore.js templates.
 *
 * @since  1.0.0
 * @param  string  $name
 * @param  string  $slug
 * @return void
 */
function butterbean_get_template( $name, $slug = '' ) {

	// Allow devs to hook in early to bypass template checking.
	$located = apply_filters( "butterbean_pre_{$name}_template", '', $slug );

	// If there's no template, let's try to find one.
	if ( ! $located ) {

		$templates = array();

		if ( $slug )
			$templates[] = "{$name}-{$slug}.php";

		$templates[] = "{$name}.php";

		// Allow devs to filter the template hierarchy.
		$templates = apply_filters( "butterbean_{$name}_template_hierarchy", $templates, $slug );

		// Loop through the templates and locate one.
		foreach ( $templates as $template ) {

			if ( file_exists( butterbean()->tmpl_path . $template ) ) {
				$located = butterbean()->tmpl_path . $template;
				break;
			}
		}
	}

	// Allow devs to filter the final template.
	$located = apply_filters( "butterbean_{$name}_template", $located, $slug );

	// Load the template.
	if ( $located )
		require( $located );
}