2014-12-10 11:36:38 +00:00
|
|
|
<?php
|
|
|
|
/**
|
2016-11-21 16:25:56 +00:00
|
|
|
* Understrap Theme Customizer
|
2014-12-10 11:36:38 +00:00
|
|
|
*
|
|
|
|
* @package understrap
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add postMessage support for site title and description for the Theme Customizer.
|
|
|
|
*
|
|
|
|
* @param WP_Customize_Manager $wp_customize Theme Customizer object.
|
|
|
|
*/
|
2016-11-05 12:35:57 +00:00
|
|
|
if ( ! function_exists( 'understrap_customize_register' ) ) {
|
2016-11-21 16:25:56 +00:00
|
|
|
/**
|
|
|
|
* Register basic customizer support.
|
|
|
|
*
|
|
|
|
* @param object $wp_customize Customizer reference.
|
|
|
|
*/
|
2016-11-05 12:35:57 +00:00
|
|
|
function understrap_customize_register( $wp_customize ) {
|
|
|
|
$wp_customize->get_setting( 'blogname' )->transport = 'postMessage';
|
|
|
|
$wp_customize->get_setting( 'blogdescription' )->transport = 'postMessage';
|
|
|
|
$wp_customize->get_setting( 'header_textcolor' )->transport = 'postMessage';
|
|
|
|
}
|
2014-12-10 11:36:38 +00:00
|
|
|
}
|
|
|
|
add_action( 'customize_register', 'understrap_customize_register' );
|
|
|
|
|
2016-11-05 12:35:57 +00:00
|
|
|
if ( ! function_exists( 'understrap_theme_customize_register' ) ) {
|
2016-11-21 16:25:56 +00:00
|
|
|
/**
|
|
|
|
* Register individual settings through customizer's API.
|
|
|
|
*
|
2016-11-21 17:47:45 +00:00
|
|
|
* @param WP_Customize_Manager $wp_customize Customizer reference.
|
2016-11-21 16:25:56 +00:00
|
|
|
*/
|
2016-11-05 12:35:57 +00:00
|
|
|
function understrap_theme_customize_register( $wp_customize ) {
|
|
|
|
|
2016-11-21 16:25:56 +00:00
|
|
|
// Theme layout settings.
|
2016-11-05 12:35:57 +00:00
|
|
|
$wp_customize->add_section( 'understrap_theme_layout_options', array(
|
|
|
|
'title' => __( 'Theme Layout Settings', 'understrap' ),
|
|
|
|
'capability' => 'edit_theme_options',
|
|
|
|
'description' => __( 'Container width and sidebar defaults', 'understrap' ),
|
|
|
|
'priority' => 160,
|
|
|
|
) );
|
|
|
|
|
2018-09-02 06:54:36 +00:00
|
|
|
/**
|
|
|
|
* Select sanitization function
|
|
|
|
*
|
|
|
|
* @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 understrap_theme_slug_sanitize_select( $input, $setting ){
|
|
|
|
|
|
|
|
// Ensure input is a slug (lowercase alphanumeric characters, dashes and underscores are allowed only).
|
|
|
|
$input = sanitize_key( $input );
|
|
|
|
|
|
|
|
// Get the list of possible select options.
|
|
|
|
$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 );
|
|
|
|
|
|
|
|
}
|
2017-12-06 09:20:33 +00:00
|
|
|
|
2016-11-05 12:35:57 +00:00
|
|
|
$wp_customize->add_setting( 'understrap_container_type', array(
|
2016-11-21 16:25:56 +00:00
|
|
|
'default' => 'container',
|
|
|
|
'type' => 'theme_mod',
|
2017-12-06 09:20:33 +00:00
|
|
|
'sanitize_callback' => 'understrap_theme_slug_sanitize_select',
|
2016-11-21 16:25:56 +00:00
|
|
|
'capability' => 'edit_theme_options',
|
2016-11-05 12:35:57 +00:00
|
|
|
) );
|
|
|
|
|
|
|
|
$wp_customize->add_control(
|
|
|
|
new WP_Customize_Control(
|
|
|
|
$wp_customize,
|
2017-12-14 12:20:40 +00:00
|
|
|
'understrap_container_type', array(
|
2016-11-05 12:35:57 +00:00
|
|
|
'label' => __( 'Container Width', 'understrap' ),
|
2018-09-02 06:54:36 +00:00
|
|
|
'description' => __( 'Choose between Bootstrap\'s container and container-fluid', 'understrap' ),
|
2016-11-05 12:35:57 +00:00
|
|
|
'section' => 'understrap_theme_layout_options',
|
|
|
|
'settings' => 'understrap_container_type',
|
|
|
|
'type' => 'select',
|
|
|
|
'choices' => array(
|
|
|
|
'container' => __( 'Fixed width container', 'understrap' ),
|
|
|
|
'container-fluid' => __( 'Full width container', 'understrap' ),
|
|
|
|
),
|
2016-11-15 10:48:38 +00:00
|
|
|
'priority' => '10',
|
2016-11-05 12:35:57 +00:00
|
|
|
)
|
|
|
|
) );
|
|
|
|
|
|
|
|
$wp_customize->add_setting( 'understrap_sidebar_position', array(
|
2016-11-21 16:25:56 +00:00
|
|
|
'default' => 'right',
|
|
|
|
'type' => 'theme_mod',
|
2017-12-06 09:20:33 +00:00
|
|
|
'sanitize_callback' => 'sanitize_text_field',
|
2016-11-21 16:25:56 +00:00
|
|
|
'capability' => 'edit_theme_options',
|
2016-11-05 12:35:57 +00:00
|
|
|
) );
|
|
|
|
|
|
|
|
$wp_customize->add_control(
|
|
|
|
new WP_Customize_Control(
|
|
|
|
$wp_customize,
|
|
|
|
'understrap_sidebar_position', array(
|
|
|
|
'label' => __( 'Sidebar Positioning', 'understrap' ),
|
2018-09-02 06:54:36 +00:00
|
|
|
'description' => __( 'Set sidebar\'s default position. Can either be: right, left, both or none. Note: this can be overridden on individual pages.',
|
2016-11-21 17:47:45 +00:00
|
|
|
'understrap' ),
|
2016-11-05 12:35:57 +00:00
|
|
|
'section' => 'understrap_theme_layout_options',
|
|
|
|
'settings' => 'understrap_sidebar_position',
|
|
|
|
'type' => 'select',
|
2017-12-06 09:20:33 +00:00
|
|
|
'sanitize_callback' => 'understrap_theme_slug_sanitize_select',
|
2016-11-05 12:35:57 +00:00
|
|
|
'choices' => array(
|
|
|
|
'right' => __( 'Right sidebar', 'understrap' ),
|
|
|
|
'left' => __( 'Left sidebar', 'understrap' ),
|
|
|
|
'both' => __( 'Left & Right sidebars', 'understrap' ),
|
|
|
|
'none' => __( 'No sidebar', 'understrap' ),
|
|
|
|
),
|
2016-11-15 10:48:38 +00:00
|
|
|
'priority' => '20',
|
2016-11-05 12:35:57 +00:00
|
|
|
)
|
|
|
|
) );
|
|
|
|
}
|
2016-11-21 17:12:36 +00:00
|
|
|
} // endif function_exists( 'understrap_theme_customize_register' ).
|
2015-02-06 08:38:52 +00:00
|
|
|
add_action( 'customize_register', 'understrap_theme_customize_register' );
|
|
|
|
|
2014-12-10 11:36:38 +00:00
|
|
|
/**
|
|
|
|
* Binds JS handlers to make Theme Customizer preview reload changes asynchronously.
|
|
|
|
*/
|
2016-11-05 12:35:57 +00:00
|
|
|
if ( ! function_exists( 'understrap_customize_preview_js' ) ) {
|
2016-11-21 17:12:36 +00:00
|
|
|
/**
|
|
|
|
* Setup JS integration for live previewing.
|
|
|
|
*/
|
2016-11-05 12:35:57 +00:00
|
|
|
function understrap_customize_preview_js() {
|
2016-11-21 16:25:56 +00:00
|
|
|
wp_enqueue_script( 'understrap_customizer', get_template_directory_uri() . '/js/customizer.js',
|
2018-09-02 06:54:36 +00:00
|
|
|
array( 'customize-preview' ), '20130508', true
|
|
|
|
);
|
2016-11-05 12:35:57 +00:00
|
|
|
}
|
2014-12-10 11:36:38 +00:00
|
|
|
}
|
|
|
|
add_action( 'customize_preview_init', 'understrap_customize_preview_js' );
|