HEX
Server: Apache
System: Linux web15f74.uni5.net 5.4.282-1.el8.elrepo.x86_64 #1 SMP Mon Aug 19 18:33:22 EDT 2024 x86_64
User: lucendi (859622)
PHP: 7.4.33
Disabled: apache_child_terminate,c99_buff_prepare,c99_sess_put,dl,exec,leak,link,myshellexec,openlog,passthru,pclose,pcntl_exec,php_check_syntax,php_strip_whitespace,popen,posix_kill,posix_mkfifo,posix_setpgid,posix_setsid,posix_setuid,proc_close,proc_get_status,proc_nice,proc_open,proc_terminate,shell_exec,show_source,symlink,system,socket_listen,socket_create_listen,putenv
Upload Files
File: /home/lucendi/www/wp-content/themes/mesmerize/customizer/kirki/includes/class-kirki-control.php
<?php
/**
 * Controls handler
 *
 * @package     Kirki
 * @category    Core
 * @author      Aristeides Stathopoulos
 * @copyright   Copyright (c) 2016, Aristeides Stathopoulos
 * @license     http://opensource.org/licenses/https://opensource.org/licenses/MIT
 */

if ( ! class_exists('Kirki_Control')) {

    /**
     * Our main Kirki_Control object
     */
    class Kirki_Control
    {

        /**
         * The $wp_customize WordPress global.
         *
         * @access protected
         * @var WP_Customize_Manager
         */
        protected $wp_customize;

        /**
         * An array of all available control types.
         *
         * @access protected
         * @var array
         */
        protected $control_types = array();

        /**
         * The class constructor.
         * Creates the actual controls in the customizer.
         *
         * @access public
         *
         * @param array $args The field definition as sanitized in Kirki_Field.
         */
        public function __construct($args)
        {

            // Set the $wp_customize property.
            global $wp_customize;
            if ( ! $wp_customize) {
                return;
            }
            $this->wp_customize = $wp_customize;

            // Set the control types.
            $this->set_control_types();
            // Add the control.
            $this->add_control($args);

        }

        /**
         * Get the class name of the class needed to create tis control.
         *
         * @access private
         *
         * @param array $args The field definition as sanitized in Kirki_Field.
         *
         * @return         string   the name of the class that will be used to create this control.
         */
        private function get_control_class_name($args)
        {

            // Set a default class name.
            $class_name = 'WP_Customize_Control';
            // Get the classname from the array of control classnames.
            if (array_key_exists($args['type'], $this->control_types)) {
                $class_name = $this->control_types[$args['type']];
            }

            return $class_name;

        }

        /**
         * Adds the control.
         *
         * @access protected
         *
         * @param array $args The field definition as sanitized in Kirki_Field.
         */
        final protected function add_control($args)
        {

            // Get the name of the class we're going to use.
            $class_name = $this->get_control_class_name($args);
            // Add the control.
            $this->wp_customize->add_control(new $class_name($this->wp_customize, $args['settings'], $args));

        }

        /**
         * Sets the $this->control_types property.
         * Makes sure the kirki/control_types filter is applied
         * and that the defined classes actually exist.
         * If a defined class does not exist, it is removed.
         */
        private function set_control_types()
        {

            $this->control_types = apply_filters('kirki/control_types', array(
                'kirki-checkbox'        => 'Kirki_Controls_Checkbox_Control',
                'kirki-color'           => 'Kirki_Controls_Color_Control',
                'kirki-color-palette'   => 'Kirki_Controls_Color_Palette_Control',
                'kirki-custom'          => 'Kirki_Controls_Custom_Control',
                'kirki-date'            => 'Kirki_Controls_Date_Control',
                'kirki-dashicons'       => 'Kirki_Controls_Dashicons_Control',
                'kirki-dimension'       => 'Kirki_Controls_Dimension_Control',
                'kirki-editor'          => 'Kirki_Controls_Editor_Control',
                'kirki-multicolor'      => 'Kirki_Controls_Multicolor_Control',
                'kirki-multicheck'      => 'Kirki_Controls_MultiCheck_Control',
                'kirki-number'          => 'Kirki_Controls_Number_Control',
                'kirki-palette'         => 'Kirki_Controls_Palette_Control',
                'kirki-preset'          => 'Kirki_Controls_Preset_Control',
                'kirki-radio'           => 'Kirki_Controls_Radio_Control',
                'kirki-radio-buttonset' => 'Kirki_Controls_Radio_ButtonSet_Control',
                'kirki-radio-image'     => 'Kirki_Controls_Radio_Image_Control',
                'repeater'              => 'Kirki_Controls_Repeater_Control',
                'kirki-select'          => 'Kirki_Controls_Select_Control',
                'kirki-slider'          => 'Kirki_Controls_Slider_Control',
                'kirki-sortable'        => 'Kirki_Controls_Sortable_Control',
                'kirki-spacing'         => 'Kirki_Controls_Spacing_Control',
                'kirki-switch'          => 'Kirki_Controls_Switch_Control',
                'kirki-generic'         => 'Kirki_Controls_Generic_Control',
                'kirki-toggle'          => 'Kirki_Controls_Toggle_Control',
                'kirki-typography'      => 'Kirki_Controls_Typography_Control',
                'kirki-dropdown-pages'  => 'Kirki_Controls_Dropdown_Pages_Control',
                'image'                 => 'WP_Customize_Image_Control',
                'cropped_image'         => 'WP_Customize_Cropped_Image_Control',
                'upload'                => 'WP_Customize_Upload_Control',
                'media'                 => 'WP_Customize_Media_Control',
            ));

            // Make sure the defined classes actually exist.
            foreach ($this->control_types as $key => $classname) {

                if ( ! class_exists($classname)) {
                    unset($this->control_types[$key]);
                }
            }
        }
    }
}