[ Index ]

PHP Cross Reference of WordPress

title

Body

[close]

/wp-content/themes/twentysixteen/inc/ -> customizer.php (source)

   1  <?php
   2  /**
   3   * Twenty Sixteen Customizer functionality
   4   *
   5   * @package WordPress
   6   * @subpackage Twenty_Sixteen
   7   * @since Twenty Sixteen 1.0
   8   */
   9  
  10  /**
  11   * Sets up the WordPress core custom header and custom background features.
  12   *
  13   * @since Twenty Sixteen 1.0
  14   *
  15   * @see twentysixteen_header_style()
  16   */
  17  function twentysixteen_custom_header_and_background() {
  18      $color_scheme             = twentysixteen_get_color_scheme();
  19      $default_background_color = trim( $color_scheme[0], '#' );
  20      $default_text_color       = trim( $color_scheme[3], '#' );
  21  
  22      add_theme_support(
  23          'custom-background',
  24          /**
  25           * Filters the arguments used when adding 'custom-background' support in Twenty Sixteen.
  26           *
  27           * @since Twenty Sixteen 1.0
  28           *
  29           * @param array $args {
  30           *     An array of custom-background support arguments.
  31           *
  32           *     @type string $default-color Default color of the background.
  33           * }
  34           */
  35          apply_filters(
  36              'twentysixteen_custom_background_args',
  37              array(
  38                  'default-color' => $default_background_color,
  39              )
  40          )
  41      );
  42  
  43      add_theme_support(
  44          'custom-header',
  45          /**
  46           * Filters the arguments used when adding 'custom-header' support in Twenty Sixteen.
  47           *
  48           * @since Twenty Sixteen 1.0
  49           *
  50           * @param array $args {
  51           *     An array of custom-header support arguments.
  52           *
  53           *     @type string   $default-text-color Default color of the header text.
  54           *     @type int      $width              Width in pixels of the custom header image. Default 1200.
  55           *     @type int      $height             Height in pixels of the custom header image. Default 280.
  56           *     @type bool     $flex-height        Whether to allow flexible-height header images. Default true.
  57           *     @type callable $wp-head-callback   Callback function used to style the header image and text
  58           *                                        displayed on the blog.
  59           * }
  60           */
  61          apply_filters(
  62              'twentysixteen_custom_header_args',
  63              array(
  64                  'default-text-color' => $default_text_color,
  65                  'width'              => 1200,
  66                  'height'             => 280,
  67                  'flex-height'        => true,
  68                  'wp-head-callback'   => 'twentysixteen_header_style',
  69              )
  70          )
  71      );
  72  }
  73  add_action( 'after_setup_theme', 'twentysixteen_custom_header_and_background' );
  74  
  75  if ( ! function_exists( 'twentysixteen_header_style' ) ) :
  76      /**
  77       * Styles the header text displayed on the site.
  78       *
  79       * Create your own twentysixteen_header_style() function to override in a child theme.
  80       *
  81       * @since Twenty Sixteen 1.0
  82       *
  83       * @see twentysixteen_custom_header_and_background().
  84       */
  85  	function twentysixteen_header_style() {
  86          // If the header text option is untouched, let's bail.
  87          if ( display_header_text() ) {
  88              return;
  89          }
  90  
  91          // If the header text has been hidden.
  92          ?>
  93          <style type="text/css" id="twentysixteen-header-css">
  94          .site-branding {
  95              margin: 0 auto 0 0;
  96          }
  97  
  98          .site-branding .site-title,
  99          .site-description {
 100              clip: rect(1px, 1px, 1px, 1px);
 101              position: absolute;
 102          }
 103          </style>
 104          <?php
 105      }
 106  endif; // twentysixteen_header_style()
 107  
 108  /**
 109   * Adds postMessage support for site title and description for the Customizer.
 110   *
 111   * @since Twenty Sixteen 1.0
 112   *
 113   * @param WP_Customize_Manager $wp_customize The Customizer object.
 114   */
 115  function twentysixteen_customize_register( $wp_customize ) {
 116      $color_scheme = twentysixteen_get_color_scheme();
 117  
 118      $wp_customize->get_setting( 'blogname' )->transport        = 'postMessage';
 119      $wp_customize->get_setting( 'blogdescription' )->transport = 'postMessage';
 120  
 121      if ( isset( $wp_customize->selective_refresh ) ) {
 122          $wp_customize->selective_refresh->add_partial(
 123              'blogname',
 124              array(
 125                  'selector'            => '.site-title a',
 126                  'container_inclusive' => false,
 127                  'render_callback'     => 'twentysixteen_customize_partial_blogname',
 128              )
 129          );
 130          $wp_customize->selective_refresh->add_partial(
 131              'blogdescription',
 132              array(
 133                  'selector'            => '.site-description',
 134                  'container_inclusive' => false,
 135                  'render_callback'     => 'twentysixteen_customize_partial_blogdescription',
 136              )
 137          );
 138      }
 139  
 140      // Add color scheme setting and control.
 141      $wp_customize->add_setting(
 142          'color_scheme',
 143          array(
 144              'default'           => 'default',
 145              'sanitize_callback' => 'twentysixteen_sanitize_color_scheme',
 146              'transport'         => 'postMessage',
 147          )
 148      );
 149  
 150      $wp_customize->add_control(
 151          'color_scheme',
 152          array(
 153              'label'    => __( 'Base Color Scheme', 'twentysixteen' ),
 154              'section'  => 'colors',
 155              'type'     => 'select',
 156              'choices'  => twentysixteen_get_color_scheme_choices(),
 157              'priority' => 1,
 158          )
 159      );
 160  
 161      // Add page background color setting and control.
 162      $wp_customize->add_setting(
 163          'page_background_color',
 164          array(
 165              'default'           => $color_scheme[1],
 166              'sanitize_callback' => 'sanitize_hex_color',
 167              'transport'         => 'postMessage',
 168          )
 169      );
 170  
 171      $wp_customize->add_control(
 172          new WP_Customize_Color_Control(
 173              $wp_customize,
 174              'page_background_color',
 175              array(
 176                  'label'   => __( 'Page Background Color', 'twentysixteen' ),
 177                  'section' => 'colors',
 178              )
 179          )
 180      );
 181  
 182      // Remove the core header textcolor control, as it shares the main text color.
 183      $wp_customize->remove_control( 'header_textcolor' );
 184  
 185      // Add link color setting and control.
 186      $wp_customize->add_setting(
 187          'link_color',
 188          array(
 189              'default'           => $color_scheme[2],
 190              'sanitize_callback' => 'sanitize_hex_color',
 191              'transport'         => 'postMessage',
 192          )
 193      );
 194  
 195      $wp_customize->add_control(
 196          new WP_Customize_Color_Control(
 197              $wp_customize,
 198              'link_color',
 199              array(
 200                  'label'   => __( 'Link Color', 'twentysixteen' ),
 201                  'section' => 'colors',
 202              )
 203          )
 204      );
 205  
 206      // Add main text color setting and control.
 207      $wp_customize->add_setting(
 208          'main_text_color',
 209          array(
 210              'default'           => $color_scheme[3],
 211              'sanitize_callback' => 'sanitize_hex_color',
 212              'transport'         => 'postMessage',
 213          )
 214      );
 215  
 216      $wp_customize->add_control(
 217          new WP_Customize_Color_Control(
 218              $wp_customize,
 219              'main_text_color',
 220              array(
 221                  'label'   => __( 'Main Text Color', 'twentysixteen' ),
 222                  'section' => 'colors',
 223              )
 224          )
 225      );
 226  
 227      // Add secondary text color setting and control.
 228      $wp_customize->add_setting(
 229          'secondary_text_color',
 230          array(
 231              'default'           => $color_scheme[4],
 232              'sanitize_callback' => 'sanitize_hex_color',
 233              'transport'         => 'postMessage',
 234          )
 235      );
 236  
 237      $wp_customize->add_control(
 238          new WP_Customize_Color_Control(
 239              $wp_customize,
 240              'secondary_text_color',
 241              array(
 242                  'label'   => __( 'Secondary Text Color', 'twentysixteen' ),
 243                  'section' => 'colors',
 244              )
 245          )
 246      );
 247  }
 248  add_action( 'customize_register', 'twentysixteen_customize_register', 11 );
 249  
 250  /**
 251   * Render the site title for the selective refresh partial.
 252   *
 253   * @since Twenty Sixteen 1.2
 254   *
 255   * @see twentysixteen_customize_register()
 256   *
 257   * @return void
 258   */
 259  function twentysixteen_customize_partial_blogname() {
 260      bloginfo( 'name' );
 261  }
 262  
 263  /**
 264   * Render the site tagline for the selective refresh partial.
 265   *
 266   * @since Twenty Sixteen 1.2
 267   *
 268   * @see twentysixteen_customize_register()
 269   *
 270   * @return void
 271   */
 272  function twentysixteen_customize_partial_blogdescription() {
 273      bloginfo( 'description' );
 274  }
 275  
 276  /**
 277   * Registers color schemes for Twenty Sixteen.
 278   *
 279   * Can be filtered with {@see 'twentysixteen_color_schemes'}.
 280   *
 281   * The order of colors in a colors array:
 282   * 1. Main Background Color.
 283   * 2. Page Background Color.
 284   * 3. Link Color.
 285   * 4. Main Text Color.
 286   * 5. Secondary Text Color.
 287   *
 288   * @since Twenty Sixteen 1.0
 289   *
 290   * @return array An associative array of color scheme options.
 291   */
 292  function twentysixteen_get_color_schemes() {
 293      /**
 294       * Filters the color schemes registered for use with Twenty Sixteen.
 295       *
 296       * The default schemes include 'default', 'dark', 'gray', 'red', and 'yellow'.
 297       *
 298       * @since Twenty Sixteen 1.0
 299       *
 300       * @param array $schemes {
 301       *     Associative array of color schemes data.
 302       *
 303       *     @type array $slug {
 304       *         Associative array of information for setting up the color scheme.
 305       *
 306       *         @type string $label  Color scheme label.
 307       *         @type array  $colors HEX codes for default colors prepended with a hash symbol ('#').
 308       *                              Colors are defined in the following order: Main background, page
 309       *                              background, link, main text, secondary text.
 310       *     }
 311       * }
 312       */
 313      return apply_filters(
 314          'twentysixteen_color_schemes',
 315          array(
 316              'default' => array(
 317                  'label'  => __( 'Default', 'twentysixteen' ),
 318                  'colors' => array(
 319                      '#1a1a1a',
 320                      '#ffffff',
 321                      '#007acc',
 322                      '#1a1a1a',
 323                      '#686868',
 324                  ),
 325              ),
 326              'dark'    => array(
 327                  'label'  => __( 'Dark', 'twentysixteen' ),
 328                  'colors' => array(
 329                      '#262626',
 330                      '#1a1a1a',
 331                      '#9adffd',
 332                      '#e5e5e5',
 333                      '#c1c1c1',
 334                  ),
 335              ),
 336              'gray'    => array(
 337                  'label'  => __( 'Gray', 'twentysixteen' ),
 338                  'colors' => array(
 339                      '#616a73',
 340                      '#4d545c',
 341                      '#c7c7c7',
 342                      '#f2f2f2',
 343                      '#f2f2f2',
 344                  ),
 345              ),
 346              'red'     => array(
 347                  'label'  => __( 'Red', 'twentysixteen' ),
 348                  'colors' => array(
 349                      '#ffffff',
 350                      '#ff675f',
 351                      '#640c1f',
 352                      '#402b30',
 353                      '#402b30',
 354                  ),
 355              ),
 356              'yellow'  => array(
 357                  'label'  => __( 'Yellow', 'twentysixteen' ),
 358                  'colors' => array(
 359                      '#3b3721',
 360                      '#ffef8e',
 361                      '#774e24',
 362                      '#3b3721',
 363                      '#5b4d3e',
 364                  ),
 365              ),
 366          )
 367      );
 368  }
 369  
 370  if ( ! function_exists( 'twentysixteen_get_color_scheme' ) ) :
 371      /**
 372       * Retrieves the current Twenty Sixteen color scheme.
 373       *
 374       * Create your own twentysixteen_get_color_scheme() function to override in a child theme.
 375       *
 376       * @since Twenty Sixteen 1.0
 377       *
 378       * @return array An associative array of either the current or default color scheme HEX values.
 379       */
 380  	function twentysixteen_get_color_scheme() {
 381          $color_scheme_option = get_theme_mod( 'color_scheme', 'default' );
 382          $color_schemes       = twentysixteen_get_color_schemes();
 383  
 384          if ( array_key_exists( $color_scheme_option, $color_schemes ) ) {
 385              return $color_schemes[ $color_scheme_option ]['colors'];
 386          }
 387  
 388          return $color_schemes['default']['colors'];
 389      }
 390  endif; // twentysixteen_get_color_scheme()
 391  
 392  if ( ! function_exists( 'twentysixteen_get_color_scheme_choices' ) ) :
 393      /**
 394       * Retrieves an array of color scheme choices registered for Twenty Sixteen.
 395       *
 396       * Create your own twentysixteen_get_color_scheme_choices() function to override
 397       * in a child theme.
 398       *
 399       * @since Twenty Sixteen 1.0
 400       *
 401       * @return array Array of color schemes.
 402       */
 403  	function twentysixteen_get_color_scheme_choices() {
 404          $color_schemes                = twentysixteen_get_color_schemes();
 405          $color_scheme_control_options = array();
 406  
 407          foreach ( $color_schemes as $color_scheme => $value ) {
 408              $color_scheme_control_options[ $color_scheme ] = $value['label'];
 409          }
 410  
 411          return $color_scheme_control_options;
 412      }
 413  endif; // twentysixteen_get_color_scheme_choices()
 414  
 415  
 416  if ( ! function_exists( 'twentysixteen_sanitize_color_scheme' ) ) :
 417      /**
 418       * Handles sanitization for Twenty Sixteen color schemes.
 419       *
 420       * Create your own twentysixteen_sanitize_color_scheme() function to override
 421       * in a child theme.
 422       *
 423       * @since Twenty Sixteen 1.0
 424       *
 425       * @param string $value Color scheme name value.
 426       * @return string Color scheme name.
 427       */
 428  	function twentysixteen_sanitize_color_scheme( $value ) {
 429          $color_schemes = twentysixteen_get_color_scheme_choices();
 430  
 431          if ( ! array_key_exists( $value, $color_schemes ) ) {
 432              return 'default';
 433          }
 434  
 435          return $value;
 436      }
 437  endif; // twentysixteen_sanitize_color_scheme()
 438  
 439  /**
 440   * Enqueues front-end CSS for color scheme.
 441   *
 442   * @since Twenty Sixteen 1.0
 443   *
 444   * @see wp_add_inline_style()
 445   */
 446  function twentysixteen_color_scheme_css() {
 447      $color_scheme_option = get_theme_mod( 'color_scheme', 'default' );
 448  
 449      // Don't do anything if the default color scheme is selected.
 450      if ( 'default' === $color_scheme_option ) {
 451          return;
 452      }
 453  
 454      $color_scheme = twentysixteen_get_color_scheme();
 455  
 456      // Convert main text hex color to rgba.
 457      $color_textcolor_rgb = twentysixteen_hex2rgb( $color_scheme[3] );
 458  
 459      // If the rgba values are empty return early.
 460      if ( empty( $color_textcolor_rgb ) ) {
 461          return;
 462      }
 463  
 464      // If we get this far, we have a custom color scheme.
 465      $colors = array(
 466          'background_color'      => $color_scheme[0],
 467          'page_background_color' => $color_scheme[1],
 468          'link_color'            => $color_scheme[2],
 469          'main_text_color'       => $color_scheme[3],
 470          'secondary_text_color'  => $color_scheme[4],
 471          'border_color'          => vsprintf( 'rgba( %1$s, %2$s, %3$s, 0.2)', $color_textcolor_rgb ),
 472  
 473      );
 474  
 475      $color_scheme_css = twentysixteen_get_color_scheme_css( $colors );
 476  
 477      wp_add_inline_style( 'twentysixteen-style', $color_scheme_css );
 478  }
 479  add_action( 'wp_enqueue_scripts', 'twentysixteen_color_scheme_css' );
 480  
 481  /**
 482   * Binds the JS listener to make Customizer color_scheme control.
 483   *
 484   * Passes color scheme data as colorScheme global.
 485   *
 486   * @since Twenty Sixteen 1.0
 487   */
 488  function twentysixteen_customize_control_js() {
 489      wp_enqueue_script( 'color-scheme-control', get_template_directory_uri() . '/js/color-scheme-control.js', array( 'customize-controls', 'iris', 'underscore', 'wp-util' ), '20170530', true );
 490      wp_localize_script( 'color-scheme-control', 'colorScheme', twentysixteen_get_color_schemes() );
 491  }
 492  add_action( 'customize_controls_enqueue_scripts', 'twentysixteen_customize_control_js' );
 493  
 494  /**
 495   * Binds JS handlers to make the Customizer preview reload changes asynchronously.
 496   *
 497   * @since Twenty Sixteen 1.0
 498   */
 499  function twentysixteen_customize_preview_js() {
 500      wp_enqueue_script( 'twentysixteen-customize-preview', get_template_directory_uri() . '/js/customize-preview.js', array( 'customize-preview' ), '20170530', true );
 501  }
 502  add_action( 'customize_preview_init', 'twentysixteen_customize_preview_js' );
 503  
 504  /**
 505   * Returns CSS for the color schemes.
 506   *
 507   * @since Twenty Sixteen 1.0
 508   *
 509   * @param array $colors Color scheme colors.
 510   * @return string Color scheme CSS.
 511   */
 512  function twentysixteen_get_color_scheme_css( $colors ) {
 513      $colors = wp_parse_args(
 514          $colors,
 515          array(
 516              'background_color'      => '',
 517              'page_background_color' => '',
 518              'link_color'            => '',
 519              'main_text_color'       => '',
 520              'secondary_text_color'  => '',
 521              'border_color'          => '',
 522          )
 523      );
 524  
 525      return <<<CSS
 526      /* Color Scheme */
 527  
 528      /* Background Color */
 529      body {
 530          background-color: {$colors['background_color']};
 531      }
 532  
 533      /* Page Background Color */
 534      .site {
 535          background-color: {$colors['page_background_color']};
 536      }
 537  
 538      mark,
 539      ins,
 540      button,
 541      button[disabled]:hover,
 542      button[disabled]:focus,
 543      input[type="button"],
 544      input[type="button"][disabled]:hover,
 545      input[type="button"][disabled]:focus,
 546      input[type="reset"],
 547      input[type="reset"][disabled]:hover,
 548      input[type="reset"][disabled]:focus,
 549      input[type="submit"],
 550      input[type="submit"][disabled]:hover,
 551      input[type="submit"][disabled]:focus,
 552      .menu-toggle.toggled-on,
 553      .menu-toggle.toggled-on:hover,
 554      .menu-toggle.toggled-on:focus,
 555      .pagination .prev,
 556      .pagination .next,
 557      .pagination .prev:hover,
 558      .pagination .prev:focus,
 559      .pagination .next:hover,
 560      .pagination .next:focus,
 561      .pagination .nav-links:before,
 562      .pagination .nav-links:after,
 563      .widget_calendar tbody a,
 564      .widget_calendar tbody a:hover,
 565      .widget_calendar tbody a:focus,
 566      .page-links a,
 567      .page-links a:hover,
 568      .page-links a:focus {
 569          color: {$colors['page_background_color']};
 570      }
 571  
 572      /* Link Color */
 573      .menu-toggle:hover,
 574      .menu-toggle:focus,
 575      a,
 576      .main-navigation a:hover,
 577      .main-navigation a:focus,
 578      .dropdown-toggle:hover,
 579      .dropdown-toggle:focus,
 580      .social-navigation a:hover:before,
 581      .social-navigation a:focus:before,
 582      .post-navigation a:hover .post-title,
 583      .post-navigation a:focus .post-title,
 584      .tagcloud a:hover,
 585      .tagcloud a:focus,
 586      .site-branding .site-title a:hover,
 587      .site-branding .site-title a:focus,
 588      .entry-title a:hover,
 589      .entry-title a:focus,
 590      .entry-footer a:hover,
 591      .entry-footer a:focus,
 592      .comment-metadata a:hover,
 593      .comment-metadata a:focus,
 594      .pingback .comment-edit-link:hover,
 595      .pingback .comment-edit-link:focus,
 596      .comment-reply-link,
 597      .comment-reply-link:hover,
 598      .comment-reply-link:focus,
 599      .required,
 600      .site-info a:hover,
 601      .site-info a:focus {
 602          color: {$colors['link_color']};
 603      }
 604  
 605      mark,
 606      ins,
 607      button:hover,
 608      button:focus,
 609      input[type="button"]:hover,
 610      input[type="button"]:focus,
 611      input[type="reset"]:hover,
 612      input[type="reset"]:focus,
 613      input[type="submit"]:hover,
 614      input[type="submit"]:focus,
 615      .pagination .prev:hover,
 616      .pagination .prev:focus,
 617      .pagination .next:hover,
 618      .pagination .next:focus,
 619      .widget_calendar tbody a,
 620      .page-links a:hover,
 621      .page-links a:focus {
 622          background-color: {$colors['link_color']};
 623      }
 624  
 625      input[type="date"]:focus,
 626      input[type="time"]:focus,
 627      input[type="datetime-local"]:focus,
 628      input[type="week"]:focus,
 629      input[type="month"]:focus,
 630      input[type="text"]:focus,
 631      input[type="email"]:focus,
 632      input[type="url"]:focus,
 633      input[type="password"]:focus,
 634      input[type="search"]:focus,
 635      input[type="tel"]:focus,
 636      input[type="number"]:focus,
 637      textarea:focus,
 638      .tagcloud a:hover,
 639      .tagcloud a:focus,
 640      .menu-toggle:hover,
 641      .menu-toggle:focus {
 642          border-color: {$colors['link_color']};
 643      }
 644  
 645      /* Main Text Color */
 646      body,
 647      blockquote cite,
 648      blockquote small,
 649      .main-navigation a,
 650      .menu-toggle,
 651      .dropdown-toggle,
 652      .social-navigation a,
 653      .post-navigation a,
 654      .pagination a:hover,
 655      .pagination a:focus,
 656      .widget-title a,
 657      .site-branding .site-title a,
 658      .entry-title a,
 659      .page-links > .page-links-title,
 660      .comment-author,
 661      .comment-reply-title small a:hover,
 662      .comment-reply-title small a:focus {
 663          color: {$colors['main_text_color']};
 664      }
 665  
 666      blockquote,
 667      .menu-toggle.toggled-on,
 668      .menu-toggle.toggled-on:hover,
 669      .menu-toggle.toggled-on:focus,
 670      .post-navigation,
 671      .post-navigation div + div,
 672      .pagination,
 673      .widget,
 674      .page-header,
 675      .page-links a,
 676      .comments-title,
 677      .comment-reply-title {
 678          border-color: {$colors['main_text_color']};
 679      }
 680  
 681      button,
 682      button[disabled]:hover,
 683      button[disabled]:focus,
 684      input[type="button"],
 685      input[type="button"][disabled]:hover,
 686      input[type="button"][disabled]:focus,
 687      input[type="reset"],
 688      input[type="reset"][disabled]:hover,
 689      input[type="reset"][disabled]:focus,
 690      input[type="submit"],
 691      input[type="submit"][disabled]:hover,
 692      input[type="submit"][disabled]:focus,
 693      .menu-toggle.toggled-on,
 694      .menu-toggle.toggled-on:hover,
 695      .menu-toggle.toggled-on:focus,
 696      .pagination:before,
 697      .pagination:after,
 698      .pagination .prev,
 699      .pagination .next,
 700      .page-links a {
 701          background-color: {$colors['main_text_color']};
 702      }
 703  
 704      /* Secondary Text Color */
 705  
 706      /**
 707       * IE8 and earlier will drop any block with CSS3 selectors.
 708       * Do not combine these styles with the next block.
 709       */
 710      body:not(.search-results) .entry-summary {
 711          color: {$colors['secondary_text_color']};
 712      }
 713  
 714      blockquote,
 715      .post-password-form label,
 716      a:hover,
 717      a:focus,
 718      a:active,
 719      .post-navigation .meta-nav,
 720      .image-navigation,
 721      .comment-navigation,
 722      .widget_recent_entries .post-date,
 723      .widget_rss .rss-date,
 724      .widget_rss cite,
 725      .site-description,
 726      .author-bio,
 727      .entry-footer,
 728      .entry-footer a,
 729      .sticky-post,
 730      .taxonomy-description,
 731      .entry-caption,
 732      .comment-metadata,
 733      .pingback .edit-link,
 734      .comment-metadata a,
 735      .pingback .comment-edit-link,
 736      .comment-form label,
 737      .comment-notes,
 738      .comment-awaiting-moderation,
 739      .logged-in-as,
 740      .form-allowed-tags,
 741      .site-info,
 742      .site-info a,
 743      .wp-caption .wp-caption-text,
 744      .gallery-caption,
 745      .widecolumn label,
 746      .widecolumn .mu_register label {
 747          color: {$colors['secondary_text_color']};
 748      }
 749  
 750      .widget_calendar tbody a:hover,
 751      .widget_calendar tbody a:focus {
 752          background-color: {$colors['secondary_text_color']};
 753      }
 754  
 755      /* Border Color */
 756      fieldset,
 757      pre,
 758      abbr,
 759      acronym,
 760      table,
 761      th,
 762      td,
 763      input[type="date"],
 764      input[type="time"],
 765      input[type="datetime-local"],
 766      input[type="week"],
 767      input[type="month"],
 768      input[type="text"],
 769      input[type="email"],
 770      input[type="url"],
 771      input[type="password"],
 772      input[type="search"],
 773      input[type="tel"],
 774      input[type="number"],
 775      textarea,
 776      .main-navigation li,
 777      .main-navigation .primary-menu,
 778      .menu-toggle,
 779      .dropdown-toggle:after,
 780      .social-navigation a,
 781      .image-navigation,
 782      .comment-navigation,
 783      .tagcloud a,
 784      .entry-content,
 785      .entry-summary,
 786      .page-links a,
 787      .page-links > span,
 788      .comment-list article,
 789      .comment-list .pingback,
 790      .comment-list .trackback,
 791      .comment-reply-link,
 792      .no-comments,
 793      .widecolumn .mu_register .mu_alert {
 794          border-color: {$colors['main_text_color']}; /* Fallback for IE7 and IE8 */
 795          border-color: {$colors['border_color']};
 796      }
 797  
 798      hr,
 799      code {
 800          background-color: {$colors['main_text_color']}; /* Fallback for IE7 and IE8 */
 801          background-color: {$colors['border_color']};
 802      }
 803  
 804      @media screen and (min-width: 56.875em) {
 805          .main-navigation li:hover > a,
 806          .main-navigation li.focus > a {
 807              color: {$colors['link_color']};
 808          }
 809  
 810          .main-navigation ul ul,
 811          .main-navigation ul ul li {
 812              border-color: {$colors['border_color']};
 813          }
 814  
 815          .main-navigation ul ul:before {
 816              border-top-color: {$colors['border_color']};
 817              border-bottom-color: {$colors['border_color']};
 818          }
 819  
 820          .main-navigation ul ul li {
 821              background-color: {$colors['page_background_color']};
 822          }
 823  
 824          .main-navigation ul ul:after {
 825              border-top-color: {$colors['page_background_color']};
 826              border-bottom-color: {$colors['page_background_color']};
 827          }
 828      }
 829  
 830  CSS;
 831  }
 832  
 833  
 834  /**
 835   * Outputs an Underscore template for generating CSS for the color scheme.
 836   *
 837   * The template generates the css dynamically for instant display in the
 838   * Customizer preview.
 839   *
 840   * @since Twenty Sixteen 1.0
 841   */
 842  function twentysixteen_color_scheme_css_template() {
 843      $colors = array(
 844          'background_color'      => '{{ data.background_color }}',
 845          'page_background_color' => '{{ data.page_background_color }}',
 846          'link_color'            => '{{ data.link_color }}',
 847          'main_text_color'       => '{{ data.main_text_color }}',
 848          'secondary_text_color'  => '{{ data.secondary_text_color }}',
 849          'border_color'          => '{{ data.border_color }}',
 850      );
 851      ?>
 852      <script type="text/html" id="tmpl-twentysixteen-color-scheme">
 853          <?php echo twentysixteen_get_color_scheme_css( $colors ); ?>
 854      </script>
 855      <?php
 856  }
 857  add_action( 'customize_controls_print_footer_scripts', 'twentysixteen_color_scheme_css_template' );
 858  
 859  /**
 860   * Enqueues front-end CSS for the page background color.
 861   *
 862   * @since Twenty Sixteen 1.0
 863   *
 864   * @see wp_add_inline_style()
 865   */
 866  function twentysixteen_page_background_color_css() {
 867      $color_scheme          = twentysixteen_get_color_scheme();
 868      $default_color         = $color_scheme[1];
 869      $page_background_color = get_theme_mod( 'page_background_color', $default_color );
 870  
 871      // Don't do anything if the current color is the default.
 872      if ( $page_background_color === $default_color ) {
 873          return;
 874      }
 875  
 876      $css = '
 877          /* Custom Page Background Color */
 878          .site {
 879              background-color: %1$s;
 880          }
 881  
 882          mark,
 883          ins,
 884          button,
 885          button[disabled]:hover,
 886          button[disabled]:focus,
 887          input[type="button"],
 888          input[type="button"][disabled]:hover,
 889          input[type="button"][disabled]:focus,
 890          input[type="reset"],
 891          input[type="reset"][disabled]:hover,
 892          input[type="reset"][disabled]:focus,
 893          input[type="submit"],
 894          input[type="submit"][disabled]:hover,
 895          input[type="submit"][disabled]:focus,
 896          .menu-toggle.toggled-on,
 897          .menu-toggle.toggled-on:hover,
 898          .menu-toggle.toggled-on:focus,
 899          .pagination .prev,
 900          .pagination .next,
 901          .pagination .prev:hover,
 902          .pagination .prev:focus,
 903          .pagination .next:hover,
 904          .pagination .next:focus,
 905          .pagination .nav-links:before,
 906          .pagination .nav-links:after,
 907          .widget_calendar tbody a,
 908          .widget_calendar tbody a:hover,
 909          .widget_calendar tbody a:focus,
 910          .page-links a,
 911          .page-links a:hover,
 912          .page-links a:focus {
 913              color: %1$s;
 914          }
 915  
 916          @media screen and (min-width: 56.875em) {
 917              .main-navigation ul ul li {
 918                  background-color: %1$s;
 919              }
 920  
 921              .main-navigation ul ul:after {
 922                  border-top-color: %1$s;
 923                  border-bottom-color: %1$s;
 924              }
 925          }
 926      ';
 927  
 928      wp_add_inline_style( 'twentysixteen-style', sprintf( $css, $page_background_color ) );
 929  }
 930  add_action( 'wp_enqueue_scripts', 'twentysixteen_page_background_color_css', 11 );
 931  
 932  /**
 933   * Enqueues front-end CSS for the link color.
 934   *
 935   * @since Twenty Sixteen 1.0
 936   *
 937   * @see wp_add_inline_style()
 938   */
 939  function twentysixteen_link_color_css() {
 940      $color_scheme  = twentysixteen_get_color_scheme();
 941      $default_color = $color_scheme[2];
 942      $link_color    = get_theme_mod( 'link_color', $default_color );
 943  
 944      // Don't do anything if the current color is the default.
 945      if ( $link_color === $default_color ) {
 946          return;
 947      }
 948  
 949      $css = '
 950          /* Custom Link Color */
 951          .menu-toggle:hover,
 952          .menu-toggle:focus,
 953          a,
 954          .main-navigation a:hover,
 955          .main-navigation a:focus,
 956          .dropdown-toggle:hover,
 957          .dropdown-toggle:focus,
 958          .social-navigation a:hover:before,
 959          .social-navigation a:focus:before,
 960          .post-navigation a:hover .post-title,
 961          .post-navigation a:focus .post-title,
 962          .tagcloud a:hover,
 963          .tagcloud a:focus,
 964          .site-branding .site-title a:hover,
 965          .site-branding .site-title a:focus,
 966          .entry-title a:hover,
 967          .entry-title a:focus,
 968          .entry-footer a:hover,
 969          .entry-footer a:focus,
 970          .comment-metadata a:hover,
 971          .comment-metadata a:focus,
 972          .pingback .comment-edit-link:hover,
 973          .pingback .comment-edit-link:focus,
 974          .comment-reply-link,
 975          .comment-reply-link:hover,
 976          .comment-reply-link:focus,
 977          .required,
 978          .site-info a:hover,
 979          .site-info a:focus {
 980              color: %1$s;
 981          }
 982  
 983          mark,
 984          ins,
 985          button:hover,
 986          button:focus,
 987          input[type="button"]:hover,
 988          input[type="button"]:focus,
 989          input[type="reset"]:hover,
 990          input[type="reset"]:focus,
 991          input[type="submit"]:hover,
 992          input[type="submit"]:focus,
 993          .pagination .prev:hover,
 994          .pagination .prev:focus,
 995          .pagination .next:hover,
 996          .pagination .next:focus,
 997          .widget_calendar tbody a,
 998          .page-links a:hover,
 999          .page-links a:focus {
1000              background-color: %1$s;
1001          }
1002  
1003          input[type="date"]:focus,
1004          input[type="time"]:focus,
1005          input[type="datetime-local"]:focus,
1006          input[type="week"]:focus,
1007          input[type="month"]:focus,
1008          input[type="text"]:focus,
1009          input[type="email"]:focus,
1010          input[type="url"]:focus,
1011          input[type="password"]:focus,
1012          input[type="search"]:focus,
1013          input[type="tel"]:focus,
1014          input[type="number"]:focus,
1015          textarea:focus,
1016          .tagcloud a:hover,
1017          .tagcloud a:focus,
1018          .menu-toggle:hover,
1019          .menu-toggle:focus {
1020              border-color: %1$s;
1021          }
1022  
1023          @media screen and (min-width: 56.875em) {
1024              .main-navigation li:hover > a,
1025              .main-navigation li.focus > a {
1026                  color: %1$s;
1027              }
1028          }
1029      ';
1030  
1031      wp_add_inline_style( 'twentysixteen-style', sprintf( $css, $link_color ) );
1032  }
1033  add_action( 'wp_enqueue_scripts', 'twentysixteen_link_color_css', 11 );
1034  
1035  /**
1036   * Enqueues front-end CSS for the main text color.
1037   *
1038   * @since Twenty Sixteen 1.0
1039   *
1040   * @see wp_add_inline_style()
1041   */
1042  function twentysixteen_main_text_color_css() {
1043      $color_scheme    = twentysixteen_get_color_scheme();
1044      $default_color   = $color_scheme[3];
1045      $main_text_color = get_theme_mod( 'main_text_color', $default_color );
1046  
1047      // Don't do anything if the current color is the default.
1048      if ( $main_text_color === $default_color ) {
1049          return;
1050      }
1051  
1052      // Convert main text hex color to rgba.
1053      $main_text_color_rgb = twentysixteen_hex2rgb( $main_text_color );
1054  
1055      // If the rgba values are empty return early.
1056      if ( empty( $main_text_color_rgb ) ) {
1057          return;
1058      }
1059  
1060      // If we get this far, we have a custom color scheme.
1061      $border_color = vsprintf( 'rgba( %1$s, %2$s, %3$s, 0.2)', $main_text_color_rgb );
1062  
1063      $css = '
1064          /* Custom Main Text Color */
1065          body,
1066          blockquote cite,
1067          blockquote small,
1068          .main-navigation a,
1069          .menu-toggle,
1070          .dropdown-toggle,
1071          .social-navigation a,
1072          .post-navigation a,
1073          .pagination a:hover,
1074          .pagination a:focus,
1075          .widget-title a,
1076          .site-branding .site-title a,
1077          .entry-title a,
1078          .page-links > .page-links-title,
1079          .comment-author,
1080          .comment-reply-title small a:hover,
1081          .comment-reply-title small a:focus {
1082              color: %1$s
1083          }
1084  
1085          blockquote,
1086          .menu-toggle.toggled-on,
1087          .menu-toggle.toggled-on:hover,
1088          .menu-toggle.toggled-on:focus,
1089          .post-navigation,
1090          .post-navigation div + div,
1091          .pagination,
1092          .widget,
1093          .page-header,
1094          .page-links a,
1095          .comments-title,
1096          .comment-reply-title {
1097              border-color: %1$s;
1098          }
1099  
1100          button,
1101          button[disabled]:hover,
1102          button[disabled]:focus,
1103          input[type="button"],
1104          input[type="button"][disabled]:hover,
1105          input[type="button"][disabled]:focus,
1106          input[type="reset"],
1107          input[type="reset"][disabled]:hover,
1108          input[type="reset"][disabled]:focus,
1109          input[type="submit"],
1110          input[type="submit"][disabled]:hover,
1111          input[type="submit"][disabled]:focus,
1112          .menu-toggle.toggled-on,
1113          .menu-toggle.toggled-on:hover,
1114          .menu-toggle.toggled-on:focus,
1115          .pagination:before,
1116          .pagination:after,
1117          .pagination .prev,
1118          .pagination .next,
1119          .page-links a {
1120              background-color: %1$s;
1121          }
1122  
1123          /* Border Color */
1124          fieldset,
1125          pre,
1126          abbr,
1127          acronym,
1128          table,
1129          th,
1130          td,
1131          input[type="date"],
1132          input[type="time"],
1133          input[type="datetime-local"],
1134          input[type="week"],
1135          input[type="month"],
1136          input[type="text"],
1137          input[type="email"],
1138          input[type="url"],
1139          input[type="password"],
1140          input[type="search"],
1141          input[type="tel"],
1142          input[type="number"],
1143          textarea,
1144          .main-navigation li,
1145          .main-navigation .primary-menu,
1146          .menu-toggle,
1147          .dropdown-toggle:after,
1148          .social-navigation a,
1149          .image-navigation,
1150          .comment-navigation,
1151          .tagcloud a,
1152          .entry-content,
1153          .entry-summary,
1154          .page-links a,
1155          .page-links > span,
1156          .comment-list article,
1157          .comment-list .pingback,
1158          .comment-list .trackback,
1159          .comment-reply-link,
1160          .no-comments,
1161          .widecolumn .mu_register .mu_alert {
1162              border-color: %1$s; /* Fallback for IE7 and IE8 */
1163              border-color: %2$s;
1164          }
1165  
1166          hr,
1167          code {
1168              background-color: %1$s; /* Fallback for IE7 and IE8 */
1169              background-color: %2$s;
1170          }
1171  
1172          @media screen and (min-width: 56.875em) {
1173              .main-navigation ul ul,
1174              .main-navigation ul ul li {
1175                  border-color: %2$s;
1176              }
1177  
1178              .main-navigation ul ul:before {
1179                  border-top-color: %2$s;
1180                  border-bottom-color: %2$s;
1181              }
1182          }
1183      ';
1184  
1185      wp_add_inline_style( 'twentysixteen-style', sprintf( $css, $main_text_color, $border_color ) );
1186  }
1187  add_action( 'wp_enqueue_scripts', 'twentysixteen_main_text_color_css', 11 );
1188  
1189  /**
1190   * Enqueues front-end CSS for the secondary text color.
1191   *
1192   * @since Twenty Sixteen 1.0
1193   *
1194   * @see wp_add_inline_style()
1195   */
1196  function twentysixteen_secondary_text_color_css() {
1197      $color_scheme         = twentysixteen_get_color_scheme();
1198      $default_color        = $color_scheme[4];
1199      $secondary_text_color = get_theme_mod( 'secondary_text_color', $default_color );
1200  
1201      // Don't do anything if the current color is the default.
1202      if ( $secondary_text_color === $default_color ) {
1203          return;
1204      }
1205  
1206      $css = '
1207          /* Custom Secondary Text Color */
1208  
1209          /**
1210           * IE8 and earlier will drop any block with CSS3 selectors.
1211           * Do not combine these styles with the next block.
1212           */
1213          body:not(.search-results) .entry-summary {
1214              color: %1$s;
1215          }
1216  
1217          blockquote,
1218          .post-password-form label,
1219          a:hover,
1220          a:focus,
1221          a:active,
1222          .post-navigation .meta-nav,
1223          .image-navigation,
1224          .comment-navigation,
1225          .widget_recent_entries .post-date,
1226          .widget_rss .rss-date,
1227          .widget_rss cite,
1228          .site-description,
1229          .author-bio,
1230          .entry-footer,
1231          .entry-footer a,
1232          .sticky-post,
1233          .taxonomy-description,
1234          .entry-caption,
1235          .comment-metadata,
1236          .pingback .edit-link,
1237          .comment-metadata a,
1238          .pingback .comment-edit-link,
1239          .comment-form label,
1240          .comment-notes,
1241          .comment-awaiting-moderation,
1242          .logged-in-as,
1243          .form-allowed-tags,
1244          .site-info,
1245          .site-info a,
1246          .wp-caption .wp-caption-text,
1247          .gallery-caption,
1248          .widecolumn label,
1249          .widecolumn .mu_register label {
1250              color: %1$s;
1251          }
1252  
1253          .widget_calendar tbody a:hover,
1254          .widget_calendar tbody a:focus {
1255              background-color: %1$s;
1256          }
1257      ';
1258  
1259      wp_add_inline_style( 'twentysixteen-style', sprintf( $css, $secondary_text_color ) );
1260  }
1261  add_action( 'wp_enqueue_scripts', 'twentysixteen_secondary_text_color_css', 11 );


Generated: Fri Oct 4 01:00:02 2024 Cross-referenced by PHPXref 0.7.1