211 lines
		
	
	
	
		
			6.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			211 lines
		
	
	
	
		
			6.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
|  | <?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 is 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' ), '1.0', 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(), '1.0', true ); | ||
|  | } | ||
|  | add_action( 'customize_controls_enqueue_scripts', 'twentyseventeen_panels_js' ); |