AlkantarClanX12

Your IP : 18.221.90.184


Current Path : /home/thanudqk/128shen.com/wp-content/themes/darcie/inc/customizer/
Upload File :
Current File : /home/thanudqk/128shen.com/wp-content/themes/darcie/inc/customizer/sanitize-functions.php

<?php
/**
 * Darcie Theme Options Sanitization Functions
 *
 * @package Darcie
 */

/**
 * Sanitizes project types
 * @param  $input entered value
 * @return sanitized output
 *
 * @since 1.0
 */
function darcie_sanitize_project_type( $input ) {
    if ( '' != $input ) {
        if ( in_array( 0, $input ) ) {
            return '0';
        }

        $output = array_map( 'absint', $input ); 
    
        return $output;
    }

    return false;
}

/**
 * Select sanitization callback example.
 *
 * - Sanitization: select
 * - Control: select, radio
 *
 * Sanitization callback for 'select' and 'radio' type controls. This callback sanitizes `$input`
 * as a slug, and then validates `$input` against the choices defined for the control.
 *
 * @see sanitize_key()               https://developer.wordpress.org/reference/functions/sanitize_key/
 * @see $wp_customize->get_control() https://developer.wordpress.org/reference/classes/wp_customize_manager/get_control/
 *
 * @param string               $input   Slug to sanitize.
 * @param WP_Customize_Setting $setting Setting instance.
 * @return string Sanitized slug if it is a valid choice; otherwise, the setting default.
 */
function darcie_sanitize_select( $input, $setting ) {
    // Get list of choices from the control associated with the setting.
    $choices = $setting->manager->get_control( $setting->id )->choices;

    // If the input is a valid key, return it; otherwise, return the default.
    return ( array_key_exists( $input, $choices ) ? $input : $setting->default );
}

/**
 * Checkbox sanitization callback example.
 *
 * Sanitization callback for 'checkbox' type controls. This callback sanitizes `$checked`
 * as a boolean value, either TRUE or FALSE.
 *
 * @param bool $checked Whether the checkbox is checked.
 * @return bool Whether the checkbox is checked.
 */
function darcie_sanitize_checkbox( $checked ) {
    // Boolean check.
    return ( ( isset( $checked ) && true == $checked ) ? true : false );
}

/**
 * Sanitizes page/post in slider
 * @param  $input raw page/post id
 * @return sanitized page/post id
 */
function darcie_sanitize_post( $input ) {
    // Ensure $input is an absolute integer.
    $page_id = absint( $input );
    // If $page_id is an ID of a published page, return it; otherwise, return false
    return ( 'publish' == get_post_status( $page_id ) ? $page_id : false );
}

/**
 * Image sanitization callback example.
 *
 * Checks the image's file extension and mime type against a whitelist. If they're allowed,
 * send back the filename, otherwise, return the setting default.
 *
 * - Sanitization: image file extension
 * - Control: text, WP_Customize_Image_Control
 *
 * @see wp_check_filetype() https://developer.wordpress.org/reference/functions/wp_check_filetype/
 *
 * @param string               $image   Image filename.
 * @param WP_Customize_Setting $setting Setting instance.
 * @return string The image filename if the extension is allowed; otherwise, the setting default.
 */
function darcie_sanitize_image( $image, $setting ) {
    /*
     * Array of valid image file types.
     *
     * The array includes image mime types that are included in wp_get_mime_types()
     */
    $mimes = array(
        'jpg|jpeg|jpe' => 'image/jpeg',
        'gif'          => 'image/gif',
        'png'          => 'image/png',
        'bmp'          => 'image/bmp',
        'tif|tiff'     => 'image/tiff',
        'ico'          => 'image/x-icon'
    );
    // Return an array with file extension and mime_type.
    $file = wp_check_filetype( $image, $mimes );
    // If $image has a valid mime_type, return it; otherwise, return the default.
    return ( $file['ext'] ? $image : '' );
}

/**
 * Sanitizes category list in slider
 * @param  $input entered value
 * @return sanitized output
 *
 * @since 1.0
 */
function darcie_sanitize_category_list( $input ) {
    if ( is_array( $input ) && '' != $input ) {
        if ( in_array( 0, $input ) ) {
            return '0';
        }
        $args = array(
                        'type'          => 'post',
                        'child_of'      => 0,
                        'parent'        => '',
                        'orderby'       => 'name',
                        'order'         => 'ASC',
                        'hide_empty'    => 0,
                        'hierarchical'  => 0,
                        'taxonomy'      => 'category',
                    );

        $categories = ( get_categories( $args ) );

        $category_list  =   array();

        foreach ( $categories as $category )
            $category_list  =   array_merge( $category_list, array( $category->term_id ) );

        if ( count( array_intersect( $input, $category_list ) ) == count( $input ) ) {
            return $input;
        }
        else {
            return '';
        }
    }
    else {
        return '';
    }
}


/**
 * Number Range sanitization callback example.
 *
 * - Sanitization: number_range
 * - Control: number, tel
 *
 * Sanitization callback for 'number' or 'tel' type text inputs. This callback sanitizes
 * `$number` as an absolute integer within a defined min-max range.
 *
 * @see absint() https://developer.wordpress.org/reference/functions/absint/
 *
 * @param int                  $number  Number to check within the numeric range defined by the setting.
 * @param WP_Customize_Setting $setting Setting instance.
 * @return int|string The number, if it is zero or greater and falls within the defined range; otherwise,
 *                    the setting default.
 */
function darcie_sanitize_number_range( $number, $setting ) {

    // Ensure input is an absolute integer.
    $number = absint( $number );

    // Get the input attributes associated with the setting.
    $atts = $setting->manager->get_control( $setting->id )->input_attrs;


    // Get minimum number in the range.
    $min = ( isset( $atts['min'] ) ? $atts['min'] : $number );

    // Get maximum number in the range.
    $max = ( isset( $atts['max'] ) ? $atts['max'] : $number );

    // Get step.
    $step = ( isset( $atts['step'] ) ? $atts['step'] : 1 );

    // If the number is within the valid range, return it; otherwise, return the default
    return ( $min <= $number && $number <= $max && is_int( $number / $step ) ? $number : $setting->default );
}

function darcie_sanitize_events_bg_position( $value, $setting ) {
    if ( 'darcie_events_bg_position_x' === $setting->id ) {
        if ( ! in_array( $value, array( 'left', 'center', 'right' ), true ) ) {
            return new WP_Error( 'invalid_value', esc_html__( 'Invalid value for background position X.', 'darcie' ) );
        }
    } elseif ( 'darcie_events_bg_position_y' === $setting->id ) {
        if ( ! in_array( $value, array( 'top', 'center', 'bottom' ), true ) ) {
            return new WP_Error( 'invalid_value', esc_html__( 'Invalid value for background position Y.', 'darcie' ) );
        }
    } else {
        return new WP_Error( 'unrecognized_setting', esc_html__( 'Unrecognized background setting.', 'darcie' ) );
    }
    return $value;
}

function darcie_sanitize_events_fg_position( $value, $setting ) {
    if ( 'darcie_events_fg_position_x' === $setting->id ) {
        if ( ! in_array( $value, array( 'left', 'center', 'right' ), true ) ) {
            return new WP_Error( 'invalid_value', esc_html__( 'Invalid value for background position X.', 'darcie' ) );
        }
    } elseif ( 'darcie_events_fg_position_y' === $setting->id ) {
        if ( ! in_array( $value, array( 'top', 'center', 'bottom' ), true ) ) {
            return new WP_Error( 'invalid_value', esc_html__( 'Invalid value for background position Y.', 'darcie' ) );
        }
    } else {
        return new WP_Error( 'unrecognized_setting', esc_html__( 'Unrecognized background setting.', 'darcie' ) );
    }
    return $value;
}


/**
 * Sanitize date time value
 * @param $input
 * @return string
 */
function darcie_sanitize_date_time( $input ) {
    $date = new DateTime( $input );
    
    return $date->format('Y-m-d H:m:s');
}