wp/wp-includes/class-wp-customize-manager.php
author ymh <ymh.work@gmail.com>
Wed, 06 Nov 2013 03:21:17 +0000
changeset 0 d970ebf37754
child 5 5e2f62d02dcd
permissions -rw-r--r--
first import
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
<?php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
 * Customize Manager.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
 * @package WordPress
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
 * @subpackage Customize
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
final class WP_Customize_Manager {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
	protected $theme;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
	protected $original_stylesheet;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
	protected $previewing = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    14
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
	protected $settings = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
	protected $sections = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
	protected $controls = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
	protected $nonce_tick;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
	protected $customized;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
	private $_post_values;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
	 * Constructor.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
	public function __construct() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
		require( ABSPATH . WPINC . '/class-wp-customize-setting.php' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
		require( ABSPATH . WPINC . '/class-wp-customize-section.php' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
		require( ABSPATH . WPINC . '/class-wp-customize-control.php' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
		add_filter( 'wp_die_handler', array( $this, 'wp_die_handler' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
		add_action( 'setup_theme',  array( $this, 'setup_theme' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
		add_action( 'wp_loaded',    array( $this, 'wp_loaded' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
		// Run wp_redirect_status late to make sure we override the status last.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
		add_action( 'wp_redirect_status', array( $this, 'wp_redirect_status' ), 1000 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
		// Do not spawn cron (especially the alternate cron) while running the customizer.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
		remove_action( 'init', 'wp_cron' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
		// Do not run update checks when rendering the controls.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    47
		remove_action( 'admin_init', '_maybe_update_core' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    48
		remove_action( 'admin_init', '_maybe_update_plugins' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    49
		remove_action( 'admin_init', '_maybe_update_themes' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    50
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
		add_action( 'wp_ajax_customize_save', array( $this, 'save' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
		add_action( 'customize_register',                 array( $this, 'register_controls' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
		add_action( 'customize_controls_init',            array( $this, 'prepare_controls' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
		add_action( 'customize_controls_enqueue_scripts', array( $this, 'enqueue_control_scripts' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
	 * Return true if it's an AJAX request.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    62
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    63
	 * @return bool
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    64
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    65
	public function doing_ajax() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
		return isset( $_POST['customized'] ) || ( defined( 'DOING_AJAX' ) && DOING_AJAX );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    70
	 * Custom wp_die wrapper. Returns either the standard message for UI
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    71
	 * or the AJAX message.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    72
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    73
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    74
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    75
	 * @param mixed $ajax_message AJAX return
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    76
	 * @param mixed $message UI message
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    78
	protected function wp_die( $ajax_message, $message = null ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    79
		if ( $this->doing_ajax() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    80
			wp_die( $ajax_message );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    81
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
		if ( ! $message )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
			$message = __( 'Cheatin&#8217; uh?' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
		wp_die( $message );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    89
	 * Return the AJAX wp_die() handler if it's a customized request.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
	 * @return string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
	public function wp_die_handler() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
		if ( $this->doing_ajax() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
			return '_ajax_wp_die_handler';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
		return '_default_wp_die_handler';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
	 * Start preview and customize theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
	 * Check if customize query variable exist. Init filters to filter the current theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
	public function setup_theme() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
		send_origin_headers();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
		if ( is_admin() && ! $this->doing_ajax() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
		    auth_redirect();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
		elseif ( $this->doing_ajax() && ! is_user_logged_in() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
		    $this->wp_die( 0 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
		show_admin_bar( false );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
		if ( ! current_user_can( 'edit_theme_options' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
			$this->wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
		$this->original_stylesheet = get_stylesheet();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
		$this->theme = wp_get_theme( isset( $_REQUEST['theme'] ) ? $_REQUEST['theme'] : null );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
		if ( $this->is_theme_active() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
			// Once the theme is loaded, we'll validate it.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
			add_action( 'after_setup_theme', array( $this, 'after_setup_theme' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
		} else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
			if ( ! current_user_can( 'switch_themes' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
				$this->wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
			// If the theme isn't active, you can't preview it if it is not allowed or has errors.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
			if ( $this->theme()->errors() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
				$this->wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
			if ( ! $this->theme()->is_allowed() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
				$this->wp_die( -1 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
		$this->start_previewing_theme();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
	 * Callback to validate a theme once it is loaded
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
	function after_setup_theme() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
		if ( ! $this->doing_ajax() && ! validate_current_theme() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
			wp_redirect( 'themes.php?broken=true' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
			exit;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
	 * Start previewing the selected theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
	 * Adds filters to change the current theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
	public function start_previewing_theme() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
		// Bail if we're already previewing.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
		if ( $this->is_preview() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
			return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
		$this->previewing = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
		if ( ! $this->is_theme_active() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
			add_filter( 'template', array( $this, 'get_template' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
			add_filter( 'stylesheet', array( $this, 'get_stylesheet' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
			add_filter( 'pre_option_current_theme', array( $this, 'current_theme' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
			// @link: http://core.trac.wordpress.org/ticket/20027
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
			add_filter( 'pre_option_stylesheet', array( $this, 'get_stylesheet' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
			add_filter( 'pre_option_template', array( $this, 'get_template' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
			// Handle custom theme roots.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
			add_filter( 'pre_option_stylesheet_root', array( $this, 'get_stylesheet_root' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
			add_filter( 'pre_option_template_root', array( $this, 'get_template_root' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
		do_action( 'start_previewing_theme', $this );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
	 * Stop previewing the selected theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
	 * Removes filters to change the current theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
	public function stop_previewing_theme() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
		if ( ! $this->is_preview() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
			return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
		$this->previewing = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
		if ( ! $this->is_theme_active() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
			remove_filter( 'template', array( $this, 'get_template' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
			remove_filter( 'stylesheet', array( $this, 'get_stylesheet' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
			remove_filter( 'pre_option_current_theme', array( $this, 'current_theme' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
			// @link: http://core.trac.wordpress.org/ticket/20027
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
			remove_filter( 'pre_option_stylesheet', array( $this, 'get_stylesheet' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
			remove_filter( 'pre_option_template', array( $this, 'get_template' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
			// Handle custom theme roots.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
			remove_filter( 'pre_option_stylesheet_root', array( $this, 'get_stylesheet_root' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
			remove_filter( 'pre_option_template_root', array( $this, 'get_template_root' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
		do_action( 'stop_previewing_theme', $this );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
	 * Get the theme being customized.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
	 * @return WP_Theme
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
	public function theme() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
		return $this->theme;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
	 * Get the registered settings.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
	 * @return array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
	public function settings() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
		return $this->settings;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
	 * Get the registered controls.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
	 * @return array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
	public function controls() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
		return $this->controls;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
	 * Get the registered sections.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
	 * @return array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
	public function sections() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
		return $this->sections;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
	 * Checks if the current theme is active.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
	 * @return bool
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
	public function is_theme_active() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
		return $this->get_stylesheet() == $this->original_stylesheet;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
	 * Register styles/scripts and initialize the preview of each setting
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
	public function wp_loaded() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
		do_action( 'customize_register', $this );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
		if ( $this->is_preview() && ! is_admin() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
			$this->customize_preview_init();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
	 * Prevents AJAX requests from following redirects when previewing a theme
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
	 * by issuing a 200 response instead of a 30x.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
	 * Instead, the JS will sniff out the location header.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
	 * @param $status
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
	 * @return int
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   295
	public function wp_redirect_status( $status ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   296
		if ( $this->is_preview() && ! is_admin() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
			return 200;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
		return $status;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
	 * Decode the $_POST attribute used to override the WP_Customize_Setting values.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   307
	 * @param mixed $setting A WP_Customize_Setting derived object
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   308
	 * @return string Sanitized attribute
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
	public function post_value( $setting ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
		if ( ! isset( $this->_post_values ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   312
			if ( isset( $_POST['customized'] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   313
				$this->_post_values = json_decode( wp_unslash( $_POST['customized'] ), true );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   314
			else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   315
				$this->_post_values = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   316
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
		if ( isset( $this->_post_values[ $setting->id ] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   319
			return $setting->sanitize( $this->_post_values[ $setting->id ] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   321
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
	 * Print javascript settings.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   324
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   325
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   326
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   327
	public function customize_preview_init() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   328
		$this->nonce_tick = check_ajax_referer( 'preview-customize_' . $this->get_stylesheet(), 'nonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   329
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   330
		$this->prepare_controls();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   331
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   332
		wp_enqueue_script( 'customize-preview' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   333
		add_action( 'wp_head', array( $this, 'customize_preview_base' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   334
		add_action( 'wp_head', array( $this, 'customize_preview_html5' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   335
		add_action( 'wp_footer', array( $this, 'customize_preview_settings' ), 20 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   336
		add_action( 'shutdown', array( $this, 'customize_preview_signature' ), 1000 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   337
		add_filter( 'wp_die_handler', array( $this, 'remove_preview_signature' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   338
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   339
		foreach ( $this->settings as $setting ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   340
			$setting->preview();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   341
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   342
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   343
		do_action( 'customize_preview_init', $this );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   344
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   345
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   346
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   347
	 * Print base element for preview frame.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   348
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   349
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   350
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   351
	public function customize_preview_base() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   352
		?><base href="<?php echo home_url( '/' ); ?>" /><?php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   353
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   354
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   355
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   356
	 * Print a workaround to handle HTML5 tags in IE < 9
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   357
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   358
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   359
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   360
	public function customize_preview_html5() { ?>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   361
		<!--[if lt IE 9]>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   362
		<script type="text/javascript">
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   363
			var e = [ 'abbr', 'article', 'aside', 'audio', 'canvas', 'datalist', 'details',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   364
				'figure', 'footer', 'header', 'hgroup', 'mark', 'menu', 'meter', 'nav',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   365
				'output', 'progress', 'section', 'time', 'video' ];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   366
			for ( var i = 0; i < e.length; i++ ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   367
				document.createElement( e[i] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   368
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   369
		</script>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   370
		<![endif]--><?php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   371
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   372
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   373
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   374
	 * Print javascript settings for preview frame.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   375
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   376
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   377
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   378
	public function customize_preview_settings() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   379
		$settings = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   380
			'values'  => array(),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   381
			'channel' => esc_js( $_POST['customize_messenger_channel'] ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   382
		);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   383
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   384
		if ( 2 == $this->nonce_tick ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   385
			$settings['nonce'] = array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   386
				'save' => wp_create_nonce( 'save-customize_' . $this->get_stylesheet() ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   387
				'preview' => wp_create_nonce( 'preview-customize_' . $this->get_stylesheet() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   388
			);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   389
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   390
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   391
		foreach ( $this->settings as $id => $setting ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   392
			$settings['values'][ $id ] = $setting->js_value();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   393
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   394
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   395
		?>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   396
		<script type="text/javascript">
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   397
			var _wpCustomizeSettings = <?php echo json_encode( $settings ); ?>;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   398
		</script>
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   399
		<?php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   400
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   401
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   402
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   403
	 * Prints a signature so we can ensure the customizer was properly executed.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   404
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   405
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   406
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   407
	public function customize_preview_signature() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   408
		echo 'WP_CUSTOMIZER_SIGNATURE';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   409
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   410
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   411
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   412
	 * Removes the signature in case we experience a case where the customizer was not properly executed.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   413
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   414
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   415
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   416
	public function remove_preview_signature( $return = null ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   417
		remove_action( 'shutdown', array( $this, 'customize_preview_signature' ), 1000 );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   418
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   419
		return $return;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   420
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   421
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   422
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   423
	 * Is it a theme preview?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   424
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   425
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   426
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   427
	 * @return bool True if it's a preview, false if not.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   428
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   429
	public function is_preview() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   430
		return (bool) $this->previewing;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   431
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   432
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   433
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   434
	 * Retrieve the template name of the previewed theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   435
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   436
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   437
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   438
	 * @return string Template name.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   439
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   440
	public function get_template() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   441
		return $this->theme()->get_template();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   442
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   443
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   444
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   445
	 * Retrieve the stylesheet name of the previewed theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   446
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   447
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   448
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   449
	 * @return string Stylesheet name.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   450
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   451
	public function get_stylesheet() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   452
		return $this->theme()->get_stylesheet();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   453
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   454
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   455
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   456
	 * Retrieve the template root of the previewed theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   457
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   458
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   459
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   460
	 * @return string Theme root.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   461
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   462
	public function get_template_root() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   463
		return get_raw_theme_root( $this->get_template(), true );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   464
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   465
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   466
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   467
	 * Retrieve the stylesheet root of the previewed theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   468
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   469
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   470
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   471
	 * @return string Theme root.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   472
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   473
	public function get_stylesheet_root() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   474
		return get_raw_theme_root( $this->get_stylesheet(), true );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   475
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   476
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   477
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   478
	 * Filter the current theme and return the name of the previewed theme.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   479
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   480
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   481
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   482
	 * @param $current_theme {@internal Parameter is not used}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   483
	 * @return string Theme name.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   484
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   485
	public function current_theme( $current_theme ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   486
		return $this->theme()->display('Name');
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   487
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   488
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   489
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   490
	 * Switch the theme and trigger the save action of each setting.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   491
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   492
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   493
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   494
	public function save() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   495
		if ( ! $this->is_preview() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   496
			die;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   497
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   498
		check_ajax_referer( 'save-customize_' . $this->get_stylesheet(), 'nonce' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   499
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   500
		// Do we have to switch themes?
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   501
		if ( ! $this->is_theme_active() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   502
			// Temporarily stop previewing the theme to allow switch_themes()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   503
			// to operate properly.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   504
			$this->stop_previewing_theme();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   505
			switch_theme( $this->get_stylesheet() );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   506
			$this->start_previewing_theme();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   507
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   508
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   509
		do_action( 'customize_save', $this );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   510
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   511
		foreach ( $this->settings as $setting ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   512
			$setting->save();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   513
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   514
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   515
		do_action( 'customize_save_after', $this );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   516
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   517
		die;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   518
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   519
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   520
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   521
	 * Add a customize setting.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   522
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   523
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   524
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   525
	 * @param string $id A specific ID of the setting. Can be a
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   526
	 *                   theme mod or option name.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   527
	 * @param array $args Setting arguments.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   528
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   529
	public function add_setting( $id, $args = array() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   530
		if ( is_a( $id, 'WP_Customize_Setting' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   531
			$setting = $id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   532
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   533
			$setting = new WP_Customize_Setting( $this, $id, $args );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   534
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   535
		$this->settings[ $setting->id ] = $setting;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   536
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   537
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   538
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   539
	 * Retrieve a customize setting.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   540
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   541
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   542
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   543
	 * @param string $id A specific ID of the setting.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   544
	 * @return object The settings object.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   545
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   546
	public function get_setting( $id ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   547
		if ( isset( $this->settings[ $id ] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   548
			return $this->settings[ $id ];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   549
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   550
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   551
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   552
	 * Remove a customize setting.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   553
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   554
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   555
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   556
	 * @param string $id A specific ID of the setting.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   557
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   558
	public function remove_setting( $id ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   559
		unset( $this->settings[ $id ] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   560
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   561
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   562
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   563
	 * Add a customize section.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   564
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   565
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   566
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   567
	 * @param string $id A specific ID of the section.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   568
	 * @param array $args Section arguments.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   569
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   570
	public function add_section( $id, $args = array() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   571
		if ( is_a( $id, 'WP_Customize_Section' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   572
			$section = $id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   573
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   574
			$section = new WP_Customize_Section( $this, $id, $args );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   575
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   576
		$this->sections[ $section->id ] = $section;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   577
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   578
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   579
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   580
	 * Retrieve a customize section.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   581
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   582
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   583
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   584
	 * @param string $id A specific ID of the section.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   585
	 * @return object The section object.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   586
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   587
	public function get_section( $id ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   588
		if ( isset( $this->sections[ $id ] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   589
			return $this->sections[ $id ];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   590
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   591
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   592
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   593
	 * Remove a customize section.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   594
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   595
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   596
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   597
	 * @param string $id A specific ID of the section.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   598
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   599
	public function remove_section( $id ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   600
		unset( $this->sections[ $id ] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   601
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   602
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   603
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   604
	 * Add a customize control.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   605
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   606
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   607
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   608
	 * @param string $id A specific ID of the control.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   609
	 * @param array $args Setting arguments.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   610
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   611
	public function add_control( $id, $args = array() ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   612
		if ( is_a( $id, 'WP_Customize_Control' ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   613
			$control = $id;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   614
		else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   615
			$control = new WP_Customize_Control( $this, $id, $args );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   616
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   617
		$this->controls[ $control->id ] = $control;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   618
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   619
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   620
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   621
	 * Retrieve a customize control.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   622
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   623
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   624
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   625
	 * @param string $id A specific ID of the control.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   626
	 * @return object The settings object.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   627
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   628
	public function get_control( $id ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   629
		if ( isset( $this->controls[ $id ] ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   630
			return $this->controls[ $id ];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   631
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   632
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   633
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   634
	 * Remove a customize setting.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   635
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   636
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   637
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   638
	 * @param string $id A specific ID of the control.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   639
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   640
	public function remove_control( $id ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   641
		unset( $this->controls[ $id ] );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   642
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   643
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   644
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   645
	 * Helper function to compare two objects by priority.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   646
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   647
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   648
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   649
	 * @param object $a Object A.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   650
	 * @param object $b Object B.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   651
	 * @return int
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   652
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   653
	protected final function _cmp_priority( $a, $b ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   654
		$ap = $a->priority;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   655
		$bp = $b->priority;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   656
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   657
		if ( $ap == $bp )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   658
			return 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   659
		return ( $ap > $bp ) ? 1 : -1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   660
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   661
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   662
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   663
	 * Prepare settings and sections.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   664
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   665
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   666
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   667
	public function prepare_controls() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   668
		// Prepare controls
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   669
		// Reversing makes uasort sort by time added when conflicts occur.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   670
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   671
		$this->controls = array_reverse( $this->controls );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   672
		$controls = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   673
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   674
		foreach ( $this->controls as $id => $control ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   675
			if ( ! isset( $this->sections[ $control->section ] ) || ! $control->check_capabilities() )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   676
				continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   677
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   678
			$this->sections[ $control->section ]->controls[] = $control;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   679
			$controls[ $id ] = $control;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   680
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   681
		$this->controls = $controls;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   682
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   683
		// Prepare sections
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   684
		$this->sections = array_reverse( $this->sections );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   685
		uasort( $this->sections, array( $this, '_cmp_priority' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   686
		$sections = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   687
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   688
		foreach ( $this->sections as $section ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   689
			if ( ! $section->check_capabilities() || ! $section->controls )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   690
				continue;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   691
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   692
			usort( $section->controls, array( $this, '_cmp_priority' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   693
			$sections[] = $section;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   694
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   695
		$this->sections = $sections;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   696
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   697
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   698
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   699
	 * Enqueue scripts for customize controls.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   700
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   701
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   702
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   703
	public function enqueue_control_scripts() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   704
		foreach ( $this->controls as $control ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   705
			$control->enqueue();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   706
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   707
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   708
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   709
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   710
	 * Register some default controls.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   711
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   712
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   713
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   714
	public function register_controls() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   715
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   716
		/* Site Title & Tagline */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   717
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   718
		$this->add_section( 'title_tagline', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   719
			'title'    => __( 'Site Title & Tagline' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   720
			'priority' => 20,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   721
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   722
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   723
		$this->add_setting( 'blogname', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   724
			'default'    => get_option( 'blogname' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   725
			'type'       => 'option',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   726
			'capability' => 'manage_options',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   727
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   728
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   729
		$this->add_control( 'blogname', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   730
			'label'      => __( 'Site Title' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   731
			'section'    => 'title_tagline',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   732
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   733
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   734
		$this->add_setting( 'blogdescription', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   735
			'default'    => get_option( 'blogdescription' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   736
			'type'       => 'option',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   737
			'capability' => 'manage_options',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   738
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   739
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   740
		$this->add_control( 'blogdescription', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   741
			'label'      => __( 'Tagline' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   742
			'section'    => 'title_tagline',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   743
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   744
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   745
		/* Colors */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   746
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   747
		$this->add_section( 'colors', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   748
			'title'          => __( 'Colors' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   749
			'priority'       => 40,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   750
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   751
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   752
		$this->add_setting( 'header_textcolor', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   753
			'theme_supports' => array( 'custom-header', 'header-text' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   754
			'default'        => get_theme_support( 'custom-header', 'default-text-color' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   755
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   756
			'sanitize_callback'    => array( $this, '_sanitize_header_textcolor' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   757
			'sanitize_js_callback' => 'maybe_hash_hex_color',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   758
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   759
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   760
		// Input type: checkbox
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   761
		// With custom value
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   762
		$this->add_control( 'display_header_text', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   763
			'settings' => 'header_textcolor',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   764
			'label'    => __( 'Display Header Text' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   765
			'section'  => 'title_tagline',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   766
			'type'     => 'checkbox',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   767
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   768
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   769
		$this->add_control( new WP_Customize_Color_Control( $this, 'header_textcolor', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   770
			'label'   => __( 'Header Text Color' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   771
			'section' => 'colors',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   772
		) ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   773
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   774
		// Input type: Color
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   775
		// With sanitize_callback
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   776
		$this->add_setting( 'background_color', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   777
			'default'        => get_theme_support( 'custom-background', 'default-color' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   778
			'theme_supports' => 'custom-background',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   779
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   780
			'sanitize_callback'    => 'sanitize_hex_color_no_hash',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   781
			'sanitize_js_callback' => 'maybe_hash_hex_color',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   782
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   783
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   784
		$this->add_control( new WP_Customize_Color_Control( $this, 'background_color', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   785
			'label'   => __( 'Background Color' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   786
			'section' => 'colors',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   787
		) ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   788
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   789
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   790
		/* Custom Header */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   791
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   792
		$this->add_section( 'header_image', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   793
			'title'          => __( 'Header Image' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   794
			'theme_supports' => 'custom-header',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   795
			'priority'       => 60,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   796
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   797
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   798
		$this->add_setting( new WP_Customize_Filter_Setting( $this, 'header_image', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   799
			'default'        => get_theme_support( 'custom-header', 'default-image' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   800
			'theme_supports' => 'custom-header',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   801
		) ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   802
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   803
		$this->add_setting( new WP_Customize_Header_Image_Setting( $this, 'header_image_data', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   804
			// 'default'        => get_theme_support( 'custom-header', 'default-image' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   805
			'theme_supports' => 'custom-header',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   806
		) ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   807
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   808
		$this->add_control( new WP_Customize_Header_Image_Control( $this ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   809
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   810
		/* Custom Background */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   811
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   812
		$this->add_section( 'background_image', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   813
			'title'          => __( 'Background Image' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   814
			'theme_supports' => 'custom-background',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   815
			'priority'       => 80,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   816
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   817
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   818
		$this->add_setting( 'background_image', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   819
			'default'        => get_theme_support( 'custom-background', 'default-image' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   820
			'theme_supports' => 'custom-background',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   821
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   822
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   823
		$this->add_setting( new WP_Customize_Background_Image_Setting( $this, 'background_image_thumb', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   824
			'theme_supports' => 'custom-background',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   825
		) ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   826
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   827
		$this->add_control( new WP_Customize_Background_Image_Control( $this ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   828
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   829
		$this->add_setting( 'background_repeat', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   830
			'default'        => 'repeat',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   831
			'theme_supports' => 'custom-background',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   832
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   833
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   834
		$this->add_control( 'background_repeat', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   835
			'label'      => __( 'Background Repeat' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   836
			'section'    => 'background_image',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   837
			'type'       => 'radio',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   838
			'choices'    => array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   839
				'no-repeat'  => __('No Repeat'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   840
				'repeat'     => __('Tile'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   841
				'repeat-x'   => __('Tile Horizontally'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   842
				'repeat-y'   => __('Tile Vertically'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   843
			),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   844
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   845
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   846
		$this->add_setting( 'background_position_x', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   847
			'default'        => 'left',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   848
			'theme_supports' => 'custom-background',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   849
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   850
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   851
		$this->add_control( 'background_position_x', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   852
			'label'      => __( 'Background Position' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   853
			'section'    => 'background_image',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   854
			'type'       => 'radio',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   855
			'choices'    => array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   856
				'left'       => __('Left'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   857
				'center'     => __('Center'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   858
				'right'      => __('Right'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   859
			),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   860
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   861
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   862
		$this->add_setting( 'background_attachment', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   863
			'default'        => 'fixed',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   864
			'theme_supports' => 'custom-background',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   865
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   866
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   867
		$this->add_control( 'background_attachment', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   868
			'label'      => __( 'Background Attachment' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   869
			'section'    => 'background_image',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   870
			'type'       => 'radio',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   871
			'choices'    => array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   872
				'fixed'      => __('Fixed'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   873
				'scroll'     => __('Scroll'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   874
			),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   875
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   876
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   877
		// If the theme is using the default background callback, we can update
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   878
		// the background CSS using postMessage.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   879
		if ( get_theme_support( 'custom-background', 'wp-head-callback' ) === '_custom_background_cb' ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   880
			foreach ( array( 'color', 'image', 'position_x', 'repeat', 'attachment' ) as $prop ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   881
				$this->get_setting( 'background_' . $prop )->transport = 'postMessage';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   882
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   883
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   884
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   885
		/* Nav Menus */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   886
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   887
		$locations      = get_registered_nav_menus();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   888
		$menus          = wp_get_nav_menus();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   889
		$menu_locations = get_nav_menu_locations();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   890
		$num_locations  = count( array_keys( $locations ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   891
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   892
		$this->add_section( 'nav', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   893
			'title'          => __( 'Navigation' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   894
			'theme_supports' => 'menus',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   895
			'priority'       => 100,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   896
			'description'    => sprintf( _n('Your theme supports %s menu. Select which menu you would like to use.', 'Your theme supports %s menus. Select which menu appears in each location.', $num_locations ), number_format_i18n( $num_locations ) ) . "\n\n" . __('You can edit your menu content on the Menus screen in the Appearance section.'),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   897
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   898
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   899
		if ( $menus ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   900
			$choices = array( 0 => __( '&mdash; Select &mdash;' ) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   901
			foreach ( $menus as $menu ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   902
				$choices[ $menu->term_id ] = wp_html_excerpt( $menu->name, 40, '&hellip;' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   903
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   904
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   905
			foreach ( $locations as $location => $description ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   906
				$menu_setting_id = "nav_menu_locations[{$location}]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   907
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   908
				$this->add_setting( $menu_setting_id, array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   909
					'sanitize_callback' => 'absint',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   910
					'theme_supports'    => 'menus',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   911
				) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   912
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   913
				$this->add_control( $menu_setting_id, array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   914
					'label'   => $description,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   915
					'section' => 'nav',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   916
					'type'    => 'select',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   917
					'choices' => $choices,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   918
				) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   919
			}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   920
		}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   921
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   922
		/* Static Front Page */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   923
		// #WP19627
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   924
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   925
		$this->add_section( 'static_front_page', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   926
			'title'          => __( 'Static Front Page' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   927
		//	'theme_supports' => 'static-front-page',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   928
			'priority'       => 120,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   929
			'description'    => __( 'Your theme supports a static front page.' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   930
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   931
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   932
		$this->add_setting( 'show_on_front', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   933
			'default'        => get_option( 'show_on_front' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   934
			'capability'     => 'manage_options',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   935
			'type'           => 'option',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   936
		//	'theme_supports' => 'static-front-page',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   937
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   938
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   939
		$this->add_control( 'show_on_front', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   940
			'label'   => __( 'Front page displays' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   941
			'section' => 'static_front_page',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   942
			'type'    => 'radio',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   943
			'choices' => array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   944
				'posts' => __( 'Your latest posts' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   945
				'page'  => __( 'A static page' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   946
			),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   947
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   948
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   949
		$this->add_setting( 'page_on_front', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   950
			'type'       => 'option',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   951
			'capability' => 'manage_options',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   952
		//	'theme_supports' => 'static-front-page',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   953
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   954
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   955
		$this->add_control( 'page_on_front', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   956
			'label'      => __( 'Front page' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   957
			'section'    => 'static_front_page',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   958
			'type'       => 'dropdown-pages',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   959
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   960
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   961
		$this->add_setting( 'page_for_posts', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   962
			'type'           => 'option',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   963
			'capability'     => 'manage_options',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   964
		//	'theme_supports' => 'static-front-page',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   965
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   966
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   967
		$this->add_control( 'page_for_posts', array(
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   968
			'label'      => __( 'Posts page' ),
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   969
			'section'    => 'static_front_page',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   970
			'type'       => 'dropdown-pages',
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   971
		) );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   972
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   973
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   974
	/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   975
	 * Callback for validating the header_textcolor value.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   976
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   977
	 * Accepts 'blank', and otherwise uses sanitize_hex_color_no_hash().
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   978
	 * Returns default text color if hex color is empty.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   979
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   980
	 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   981
	 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   982
	 * @param string $color
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   983
	 * @return string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   984
	 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   985
	public function _sanitize_header_textcolor( $color ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   986
		if ( 'blank' === $color )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   987
			return 'blank';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   988
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   989
		$color = sanitize_hex_color_no_hash( $color );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   990
		if ( empty( $color ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   991
			$color = get_theme_support( 'custom-header', 'default-text-color' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   992
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   993
		return $color;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   994
	}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   995
};
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   996
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   997
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   998
 * Validates a hex color.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   999
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1000
 * Returns either '', a 3 or 6 digit hex color (with #), or null.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1001
 * For validating values without a #, see sanitize_hex_color_no_hash().
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1002
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1003
 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1004
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1005
 * @param string $color
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1006
 * @return string|null
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1007
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1008
function sanitize_hex_color( $color ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1009
	if ( '' === $color )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1010
		return '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1011
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1012
	// 3 or 6 hex digits, or the empty string.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1013
	if ( preg_match('|^#([A-Fa-f0-9]{3}){1,2}$|', $color ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1014
		return $color;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1015
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1016
	return null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1017
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1018
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1019
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1020
 * Sanitizes a hex color without a hash. Use sanitize_hex_color() when possible.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1021
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1022
 * Saving hex colors without a hash puts the burden of adding the hash on the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1023
 * UI, which makes it difficult to use or upgrade to other color types such as
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1024
 * rgba, hsl, rgb, and html color names.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1025
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1026
 * Returns either '', a 3 or 6 digit hex color (without a #), or null.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1027
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1028
 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1029
 * @uses sanitize_hex_color()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1030
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1031
 * @param string $color
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1032
 * @return string|null
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1033
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1034
function sanitize_hex_color_no_hash( $color ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1035
	$color = ltrim( $color, '#' );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1036
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1037
	if ( '' === $color )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1038
		return '';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1039
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1040
	return sanitize_hex_color( '#' . $color ) ? $color : null;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1041
}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1042
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1043
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1044
 * Ensures that any hex color is properly hashed.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1045
 * Otherwise, returns value untouched.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1046
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1047
 * This method should only be necessary if using sanitize_hex_color_no_hash().
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1048
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1049
 * @since 3.4.0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1050
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1051
 * @param string $color
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1052
 * @return string
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1053
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1054
function maybe_hash_hex_color( $color ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1055
	if ( $unhashed = sanitize_hex_color_no_hash( $color ) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1056
		return '#' . $unhashed;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1057
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1058
	return $color;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
  1059
}