| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249 |
- <?php
- /**
- * Twenty Seventeen: Customizer
- *
- * @package WordPress
- * @subpackage Twenty_Seventeen
- * @since 1.0
- */
- /**
- * Add postMessage support for site title and description for the Theme Customizer.
- *
- * @param WP_Customize_Manager $wp_customize Theme Customizer object.
- */
- function twentyseventeen_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';
- $wp_customize->selective_refresh->add_partial(
- 'blogname',
- array(
- 'selector' => '.site-title a',
- 'render_callback' => 'twentyseventeen_customize_partial_blogname',
- )
- );
- $wp_customize->selective_refresh->add_partial(
- 'blogdescription',
- array(
- 'selector' => '.site-description',
- 'render_callback' => 'twentyseventeen_customize_partial_blogdescription',
- )
- );
- /**
- * Custom colors.
- */
- $wp_customize->add_setting(
- 'colorscheme',
- array(
- 'default' => 'light',
- 'transport' => 'postMessage',
- 'sanitize_callback' => 'twentyseventeen_sanitize_colorscheme',
- )
- );
- $wp_customize->add_setting(
- 'colorscheme_hue',
- array(
- 'default' => 250,
- 'transport' => 'postMessage',
- 'sanitize_callback' => 'absint', // The hue is stored as a positive integer.
- )
- );
- $wp_customize->add_control(
- 'colorscheme',
- array(
- 'type' => 'radio',
- 'label' => __( 'Color Scheme', 'twentyseventeen' ),
- 'choices' => array(
- 'light' => __( 'Light', 'twentyseventeen' ),
- 'dark' => __( 'Dark', 'twentyseventeen' ),
- 'custom' => __( 'Custom', 'twentyseventeen' ),
- ),
- 'section' => 'colors',
- 'priority' => 5,
- )
- );
- $wp_customize->add_control(
- new WP_Customize_Color_Control(
- $wp_customize,
- 'colorscheme_hue',
- array(
- 'mode' => 'hue',
- 'section' => 'colors',
- 'priority' => 6,
- )
- )
- );
- /**
- * Theme options.
- */
- $wp_customize->add_section(
- 'theme_options',
- array(
- 'title' => __( 'Theme Options', 'twentyseventeen' ),
- 'priority' => 130, // Before Additional CSS.
- )
- );
- $wp_customize->add_setting(
- 'page_layout',
- array(
- 'default' => 'two-column',
- 'sanitize_callback' => 'twentyseventeen_sanitize_page_layout',
- 'transport' => 'postMessage',
- )
- );
- $wp_customize->add_control(
- 'page_layout',
- array(
- 'label' => __( 'Page Layout', 'twentyseventeen' ),
- 'section' => 'theme_options',
- 'type' => 'radio',
- 'description' => __( 'When the two-column layout is assigned, the page title is in one column and content is in the other.', 'twentyseventeen' ),
- 'choices' => array(
- 'one-column' => __( 'One Column', 'twentyseventeen' ),
- 'two-column' => __( 'Two Column', 'twentyseventeen' ),
- ),
- 'active_callback' => 'twentyseventeen_is_view_with_layout_option',
- )
- );
- /**
- * Filter number of front page sections in Twenty Seventeen.
- *
- * @since Twenty Seventeen 1.0
- *
- * @param int $num_sections Number of front page sections.
- */
- $num_sections = apply_filters( 'twentyseventeen_front_page_sections', 4 );
- // Create a setting and control for each of the sections available in the theme.
- for ( $i = 1; $i < ( 1 + $num_sections ); $i++ ) {
- $wp_customize->add_setting(
- 'panel_' . $i,
- array(
- 'default' => false,
- 'sanitize_callback' => 'absint',
- 'transport' => 'postMessage',
- )
- );
- $wp_customize->add_control(
- 'panel_' . $i,
- array(
- /* translators: %d: The front page section number. */
- 'label' => sprintf( __( 'Front Page Section %d Content', 'twentyseventeen' ), $i ),
- 'description' => ( 1 !== $i ? '' : __( 'Select pages to feature in each area from the dropdowns. Add an image to a section by setting a featured image in the page editor. Empty sections will not be displayed.', 'twentyseventeen' ) ),
- 'section' => 'theme_options',
- 'type' => 'dropdown-pages',
- 'allow_addition' => true,
- 'active_callback' => 'twentyseventeen_is_static_front_page',
- )
- );
- $wp_customize->selective_refresh->add_partial(
- 'panel_' . $i,
- array(
- 'selector' => '#panel' . $i,
- 'render_callback' => 'twentyseventeen_front_page_section',
- 'container_inclusive' => true,
- )
- );
- }
- }
- add_action( 'customize_register', 'twentyseventeen_customize_register' );
- /**
- * Sanitize the page layout options.
- *
- * @param string $input Page layout.
- */
- function twentyseventeen_sanitize_page_layout( $input ) {
- $valid = array(
- 'one-column' => __( 'One Column', 'twentyseventeen' ),
- 'two-column' => __( 'Two Column', 'twentyseventeen' ),
- );
- if ( array_key_exists( $input, $valid ) ) {
- return $input;
- }
- return '';
- }
- /**
- * Sanitize the colorscheme.
- *
- * @param string $input Color scheme.
- */
- function twentyseventeen_sanitize_colorscheme( $input ) {
- $valid = array( 'light', 'dark', 'custom' );
- if ( in_array( $input, $valid, true ) ) {
- return $input;
- }
- return 'light';
- }
- /**
- * Render the site title for the selective refresh partial.
- *
- * @since Twenty Seventeen 1.0
- * @see twentyseventeen_customize_register()
- *
- * @return void
- */
- function twentyseventeen_customize_partial_blogname() {
- bloginfo( 'name' );
- }
- /**
- * Render the site tagline for the selective refresh partial.
- *
- * @since Twenty Seventeen 1.0
- * @see twentyseventeen_customize_register()
- *
- * @return void
- */
- function twentyseventeen_customize_partial_blogdescription() {
- bloginfo( 'description' );
- }
- /**
- * Return whether we're previewing the front page and it's a static page.
- */
- function twentyseventeen_is_static_front_page() {
- return ( is_front_page() && ! is_home() );
- }
- /**
- * Return whether we're on a view that supports a one or two column layout.
- */
- function twentyseventeen_is_view_with_layout_option() {
- // This option is available on all pages. It's also available on archives when there isn't a sidebar.
- return ( is_page() || ( is_archive() && ! is_active_sidebar( 'sidebar-1' ) ) );
- }
- /**
- * Bind JS handlers to instantly live-preview changes.
- */
- function twentyseventeen_customize_preview_js() {
- wp_enqueue_script( 'twentyseventeen-customize-preview', get_theme_file_uri( '/assets/js/customize-preview.js' ), array( 'customize-preview' ), '20161002', true );
- }
- add_action( 'customize_preview_init', 'twentyseventeen_customize_preview_js' );
- /**
- * Load dynamic logic for the customizer controls area.
- */
- function twentyseventeen_panels_js() {
- wp_enqueue_script( 'twentyseventeen-customize-controls', get_theme_file_uri( '/assets/js/customize-controls.js' ), array(), '20161020', true );
- }
- add_action( 'customize_controls_enqueue_scripts', 'twentyseventeen_panels_js' );
|