181 lines
4.8 KiB
PHP
181 lines
4.8 KiB
PHP
<?php
|
|
/**
|
|
* Customizer settings for this theme.
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Twenty_Twenty_One
|
|
* @since Twenty Twenty-One 1.0
|
|
*/
|
|
|
|
if ( ! class_exists( 'Twenty_Twenty_One_Customize' ) ) {
|
|
/**
|
|
* Customizer Settings.
|
|
*
|
|
* @since Twenty Twenty-One 1.0
|
|
*/
|
|
class Twenty_Twenty_One_Customize {
|
|
|
|
/**
|
|
* Constructor. Instantiate the object.
|
|
*
|
|
* @since Twenty Twenty-One 1.0
|
|
*/
|
|
public function __construct() {
|
|
add_action( 'customize_register', array( $this, 'register' ) );
|
|
}
|
|
|
|
/**
|
|
* Register customizer options.
|
|
*
|
|
* @since Twenty Twenty-One 1.0
|
|
*
|
|
* @param WP_Customize_Manager $wp_customize Theme Customizer object.
|
|
* @return void
|
|
*/
|
|
public function register( $wp_customize ) {
|
|
|
|
// Change site-title & description to postMessage.
|
|
$wp_customize->get_setting( 'blogname' )->transport = 'postMessage'; // @phpstan-ignore-line. Assume that this setting exists.
|
|
$wp_customize->get_setting( 'blogdescription' )->transport = 'postMessage'; // @phpstan-ignore-line. Assume that this setting exists.
|
|
|
|
// Add partial for blogname.
|
|
$wp_customize->selective_refresh->add_partial(
|
|
'blogname',
|
|
array(
|
|
'selector' => '.site-title',
|
|
'render_callback' => array( $this, 'partial_blogname' ),
|
|
)
|
|
);
|
|
|
|
// Add partial for blogdescription.
|
|
$wp_customize->selective_refresh->add_partial(
|
|
'blogdescription',
|
|
array(
|
|
'selector' => '.site-description',
|
|
'render_callback' => array( $this, 'partial_blogdescription' ),
|
|
)
|
|
);
|
|
|
|
// Add "display_title_and_tagline" setting for displaying the site-title & tagline.
|
|
$wp_customize->add_setting(
|
|
'display_title_and_tagline',
|
|
array(
|
|
'capability' => 'edit_theme_options',
|
|
'default' => true,
|
|
'sanitize_callback' => array( __CLASS__, 'sanitize_checkbox' ),
|
|
)
|
|
);
|
|
|
|
// Add control for the "display_title_and_tagline" setting.
|
|
$wp_customize->add_control(
|
|
'display_title_and_tagline',
|
|
array(
|
|
'type' => 'checkbox',
|
|
'section' => 'title_tagline',
|
|
'label' => esc_html__( 'Display Site Title & Tagline', 'twentytwentyone' ),
|
|
)
|
|
);
|
|
|
|
/**
|
|
* Add excerpt or full text selector to customizer
|
|
*/
|
|
$wp_customize->add_section(
|
|
'excerpt_settings',
|
|
array(
|
|
'title' => esc_html__( 'Excerpt Settings', 'twentytwentyone' ),
|
|
'priority' => 120,
|
|
)
|
|
);
|
|
|
|
$wp_customize->add_setting(
|
|
'display_excerpt_or_full_post',
|
|
array(
|
|
'capability' => 'edit_theme_options',
|
|
'default' => 'excerpt',
|
|
'sanitize_callback' => static function( $value ) {
|
|
return 'excerpt' === $value || 'full' === $value ? $value : 'excerpt';
|
|
},
|
|
)
|
|
);
|
|
|
|
$wp_customize->add_control(
|
|
'display_excerpt_or_full_post',
|
|
array(
|
|
'type' => 'radio',
|
|
'section' => 'excerpt_settings',
|
|
'label' => esc_html__( 'On Archive Pages, posts show:', 'twentytwentyone' ),
|
|
'choices' => array(
|
|
'excerpt' => esc_html__( 'Summary', 'twentytwentyone' ),
|
|
'full' => esc_html__( 'Full text', 'twentytwentyone' ),
|
|
),
|
|
)
|
|
);
|
|
|
|
// Background color.
|
|
// Include the custom control class.
|
|
include_once get_theme_file_path( 'classes/class-twenty-twenty-one-customize-color-control.php' ); // phpcs:ignore WPThemeReview.CoreFunctionality.FileInclude.FileIncludeFound
|
|
|
|
// Register the custom control.
|
|
$wp_customize->register_control_type( 'Twenty_Twenty_One_Customize_Color_Control' );
|
|
|
|
// Get the palette from theme-supports.
|
|
$palette = get_theme_support( 'editor-color-palette' );
|
|
|
|
// Build the colors array from theme-support.
|
|
$colors = array();
|
|
if ( isset( $palette[0] ) && is_array( $palette[0] ) ) {
|
|
foreach ( $palette[0] as $palette_color ) {
|
|
$colors[] = $palette_color['color'];
|
|
}
|
|
}
|
|
|
|
// Add the control. Overrides the default background-color control.
|
|
$wp_customize->add_control(
|
|
new Twenty_Twenty_One_Customize_Color_Control(
|
|
$wp_customize,
|
|
'background_color',
|
|
array(
|
|
'label' => esc_html_x( 'Background color', 'Customizer control', 'twentytwentyone' ),
|
|
'section' => 'colors',
|
|
'palette' => $colors,
|
|
)
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Sanitize boolean for checkbox.
|
|
*
|
|
* @since Twenty Twenty-One 1.0
|
|
*
|
|
* @param bool $checked Whether or not a box is checked.
|
|
* @return bool
|
|
*/
|
|
public static function sanitize_checkbox( $checked = null ) {
|
|
return (bool) isset( $checked ) && true === $checked;
|
|
}
|
|
|
|
/**
|
|
* Render the site title for the selective refresh partial.
|
|
*
|
|
* @since Twenty Twenty-One 1.0
|
|
*
|
|
* @return void
|
|
*/
|
|
public function partial_blogname() {
|
|
bloginfo( 'name' );
|
|
}
|
|
|
|
/**
|
|
* Render the site tagline for the selective refresh partial.
|
|
*
|
|
* @since Twenty Twenty-One 1.0
|
|
*
|
|
* @return void
|
|
*/
|
|
public function partial_blogdescription() {
|
|
bloginfo( 'description' );
|
|
}
|
|
}
|
|
}
|