Esempio n. 1
0
 public function test_sanitize_capability()
 {
     $capabilities = array('activate_plugins', 'delete_others_pages', 'delete_others_posts', 'delete_pages', 'delete_posts', 'delete_private_pages', 'delete_private_posts', 'delete_published_pages', 'delete_published_posts', 'edit_dashboard', 'edit_others_pages', 'edit_others_posts', 'edit_pages', 'edit_posts', 'edit_private_pages', 'edit_private_posts', 'edit_published_pages', 'edit_published_posts', 'edit_theme_options', 'export', 'import', 'list_users', 'manage_categories', 'manage_links', 'manage_options', 'moderate_comments', 'promote_users', 'publish_pages', 'publish_posts', 'read_private_pages', 'read_private_posts', 'read');
     foreach ($capabilities as $capability) {
         $this->assertEquals($capability, Kirki_Field::sanitize_capability(array('capability' => $capability)));
     }
     $this->assertEquals('edit_theme_options', Kirki_Field::sanitize_capability(array()));
     add_filter('kirki/config', function () {
         return array('capability' => 'activate_plugins');
     });
     $this->assertEquals('activate_plugins', Kirki_Field::sanitize_capability(array()));
 }
Esempio n. 2
0
 /**
  * Create the settings and controls from the $fields array and register them.
  * @var	object	The WordPress Customizer object
  */
 public function add_fields($wp_customize)
 {
     $control_types = apply_filters('kirki/control_types', array('color' => 'WP_Customize_Color_Control', 'color-alpha' => 'Kirki_Controls_Color_Alpha_Control', 'image' => 'WP_Customize_Image_Control', 'upload' => 'WP_Customize_Upload_Control', 'switch' => 'Kirki_Controls_Switch_Control', 'toggle' => 'Kirki_Controls_Toggle_Control', 'radio-buttonset' => 'Kirki_Controls_Radio_ButtonSet_Control', 'radio-image' => 'Kirki_Controls_Radio_Image_Control', 'sortable' => 'Kirki_Controls_Sortable_Control', 'slider' => 'Kirki_Controls_Slider_Control', 'number' => 'Kirki_Controls_Number_Control', 'multicheck' => 'Kirki_Controls_MultiCheck_Control', 'palette' => 'Kirki_Controls_Palette_Control', 'custom' => 'Kirki_Controls_Custom_Control', 'editor' => 'Kirki_Controls_Editor_Control', 'select2' => 'Kirki_Controls_Select2_Control', 'select2-multiple' => 'Kirki_Controls_Select2_Multiple_Control'));
     foreach (self::$fields as $field) {
         if ('background' == $field['type']) {
             continue;
         }
         $wp_customize->add_setting(Kirki_Field::sanitize_settings($field), array('default' => Kirki_Field::sanitize_default($field), 'type' => Kirki_Field::sanitize_type($field), 'capability' => Kirki_Field::sanitize_capability($field), 'transport' => Kirki_Field::sanitize_transport($field), 'sanitize_callback' => Kirki_Field::sanitize_callback($field)));
         if (array_key_exists($field['type'], $control_types)) {
             $class_name = $control_types[$field['type']];
             $wp_customize->add_control(new $class_name($wp_customize, Kirki_Field::sanitize_id($field), Kirki_Field::sanitize_field($field)));
         } else {
             $wp_customize->add_control(new WP_Customize_Control($wp_customize, Kirki_Field::sanitize_id($field), Kirki_Field::sanitize_field($field)));
         }
     }
 }
Esempio n. 3
0
 /**
  * Create the settings and controls from the $fields array and register them.
  * @var	object	The WordPress Customizer object
  */
 public function add_fields($wp_customize)
 {
     $control_types = apply_filters('kirki/control_types', array('code' => 'Kirki_Controls_Code_Control', 'color' => 'WP_Customize_Color_Control', 'color-alpha' => 'Kirki_Controls_Color_Alpha_Control', 'image' => 'WP_Customize_Image_Control', 'upload' => 'WP_Customize_Upload_Control', 'switch' => 'Kirki_Controls_Switch_Control', 'toggle' => 'Kirki_Controls_Toggle_Control', 'radio-buttonset' => 'Kirki_Controls_Radio_ButtonSet_Control', 'radio-image' => 'Kirki_Controls_Radio_Image_Control', 'sortable' => 'Kirki_Controls_Sortable_Control', 'slider' => 'Kirki_Controls_Slider_Control', 'number' => 'Kirki_Controls_Number_Control', 'multicheck' => 'Kirki_Controls_MultiCheck_Control', 'palette' => 'Kirki_Controls_Palette_Control', 'custom' => 'Kirki_Controls_Custom_Control', 'editor' => 'Kirki_Controls_Editor_Control', 'select2' => 'Kirki_Controls_Select2_Control', 'select2-multiple' => 'Kirki_Controls_Select2_Multiple_Control', 'dimension' => 'Kirki_Controls_Dimension_Control', 'repeater' => 'Kirki_Controls_Repeater_Control'));
     $setting_types = apply_filters('kirki/setting_types', array('repeater' => 'Kirki_Settings_Repeater_Setting'));
     foreach (self::$fields as $field) {
         if ('background' == $field['type']) {
             continue;
         }
         if (isset($field['settings']) && is_array($field['settings'])) {
             $settings = Kirki_Field::sanitize_settings($field);
             $defaults = Kirki_Field::sanitize_default($field);
             foreach ($settings as $setting_key => $setting_value) {
                 $args = array('default' => isset($defaults[$setting_key]) ? $defaults[$setting_key] : '', 'type' => Kirki_Field::sanitize_type($field), 'capability' => Kirki_Field::sanitize_capability($field), 'transport' => Kirki_Field::sanitize_transport($field));
                 if (isset($field['sanitize_callback']) && is_array($field['sanitize_callback'])) {
                     if (isset($field['sanitize_callback'][$setting_key])) {
                         $args['sanitize_callback'] = Kirki_Field::sanitize_callback(array('sanitize_callback' => $field['sanitize_callback'][$setting_key]));
                     } else {
                         $args['sanitize_callback'] = Kirki_Field::sanitize_callback($field);
                     }
                 }
                 $wp_customize->add_setting($setting_value, $args);
             }
         }
         $setting_args = array('default' => Kirki_Field::sanitize_default($field), 'type' => Kirki_Field::sanitize_type($field), 'capability' => Kirki_Field::sanitize_capability($field), 'transport' => Kirki_Field::sanitize_transport($field), 'sanitize_callback' => Kirki_Field::sanitize_callback($field));
         if (isset($field['type']) && array_key_exists($field['type'], $setting_types)) {
             // We must instantiate a custom class for the setting
             $setting_classname = $setting_types[$field['type']];
             $setting = new $setting_classname($wp_customize, Kirki_Field::sanitize_settings($field), $setting_args);
             $wp_customize->add_setting($setting);
         } else {
             $wp_customize->add_setting(Kirki_Field::sanitize_settings($field), $setting_args);
         }
         $class_name = 'WP_Customize_Control';
         if (array_key_exists($field['type'], $control_types)) {
             $class_name = $control_types[$field['type']];
         }
         $wp_customize->add_control(new $class_name($wp_customize, Kirki_Field::sanitize_id($field), Kirki_Field::sanitize_field($field)));
     }
 }
Esempio n. 4
0
 /**
  * Create the settings and controls from the $fields array and register them.
  * @var	object	The WordPress Customizer object
  */
 public function add_fields($wp_customize)
 {
     $control_types = self::$control_types;
     $setting_types = self::$setting_types;
     foreach (self::$fields as $field) {
         if ('background' == $field['type']) {
             continue;
         }
         if (isset($field['settings']) && is_array($field['settings'])) {
             $settings = Kirki_Field::sanitize_settings($field);
             $defaults = Kirki_Field::sanitize_default($field);
             foreach ($settings as $setting_key => $setting_value) {
                 $args = array('default' => isset($defaults[$setting_key]) ? $defaults[$setting_key] : '', 'type' => Kirki_Field::sanitize_type($field), 'capability' => Kirki_Field::sanitize_capability($field), 'transport' => Kirki_Field::sanitize_transport($field));
                 if (isset($field['sanitize_callback']) && is_array($field['sanitize_callback'])) {
                     if (isset($field['sanitize_callback'][$setting_key])) {
                         $args['sanitize_callback'] = Kirki_Field::sanitize_callback(array('sanitize_callback' => $field['sanitize_callback'][$setting_key]));
                     } else {
                         $args['sanitize_callback'] = Kirki_Field::sanitize_callback($field);
                     }
                 }
                 $wp_customize->add_setting($setting_value, $args);
             }
         }
         $setting_args = array('default' => Kirki_Field::sanitize_default($field), 'type' => Kirki_Field::sanitize_type($field), 'capability' => Kirki_Field::sanitize_capability($field), 'transport' => Kirki_Field::sanitize_transport($field), 'sanitize_callback' => Kirki_Field::sanitize_callback($field));
         if (isset($field['type']) && array_key_exists($field['type'], $setting_types)) {
             // We must instantiate a custom class for the setting
             $setting_classname = $setting_types[$field['type']];
             $setting = new $setting_classname($wp_customize, Kirki_Field::sanitize_settings($field), $setting_args);
             $wp_customize->add_setting($setting);
         } else {
             $wp_customize->add_setting(Kirki_Field::sanitize_settings($field), $setting_args);
         }
         $class_name = 'WP_Customize_Control';
         if (array_key_exists($field['type'], $control_types)) {
             $class_name = $control_types[$field['type']];
         }
         $wp_customize->add_control(new $class_name($wp_customize, Kirki_Field::sanitize_id($field), Kirki_Field::sanitize_field($field)));
     }
 }
 /**
  * Test sanitize_capability edge cases
  */
 public function test_sanitize_capability()
 {
     $this->assertEquals('edit_theme_options', Kirki_Field::sanitize_capability());
 }