mirror of
https://github.com/WordPress/WordPress.git
synced 2024-12-30 21:17:57 +01:00
43b86a246c
Welcome to the bundled themes family! Theme development to this point has taken place on GitHub. See: https://github.com/WordPress/twentytwenty/. Props anlino, ianbelanger, audrasjb, nielslange, fabiankaegy, mukesh27, poena, joyously, emiluzelac, williampatton, dingo-d, dkarfa, acosmin, rabmalin, kafleg, jeffpaul, hareesh-pillai, burhandodhy, afercia, juanfra, soean, presskopp, justinahinon, jrf, netweb, garyj, pento, flixos90, vbaimas, zebulan, byalextran, mor10, kjellr, allancole, tdh, karmatosed, mapk, matt, andrewtaylor-1, ismailelkorchi, garrett-eclipse, gsayed786, dianeco, celloexpressions, aristath, nadir, cbravobernal, intimez, hometowntrailers, collet, littlebigthing, tobifjellner, kevinkovadia, jarretc. See #48110. Built from https://develop.svn.wordpress.org/trunk@46271 git-svn-id: http://core.svn.wordpress.org/trunk@46083 1a063a9b-81f0-0310-95a4-ce76da25c4cd
157 lines
5.8 KiB
PHP
157 lines
5.8 KiB
PHP
<?php
|
||
/**
|
||
* Twenty Twenty Custom CSS
|
||
*
|
||
* @package WordPress
|
||
* @subpackage Twenty_Twenty
|
||
* @since 1.0.0
|
||
*/
|
||
|
||
if ( ! function_exists( 'twentytwenty_generate_css' ) ) {
|
||
|
||
/**
|
||
* Generate CSS.
|
||
*
|
||
* @param string $selector The CSS selector.
|
||
* @param string $style The CSS style.
|
||
* @param string $value The CSS value.
|
||
* @param string $prefix The CSS prefix.
|
||
* @param string $suffix The CSS suffix.
|
||
* @param bool $echo Echo the styles.
|
||
*/
|
||
function twentytwenty_generate_css( $selector, $style, $value, $prefix = '', $suffix = '', $echo = true ) {
|
||
|
||
$return = '';
|
||
|
||
if ( ! $value ) {
|
||
|
||
return;
|
||
}
|
||
|
||
$return = sprintf( '%s { %s: %s; }', $selector, $style, $prefix . $value . $suffix );
|
||
|
||
if ( $echo ) {
|
||
|
||
echo $return; //phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- We need to double check this, but for now, we want to pass PHPCS ;)
|
||
|
||
}
|
||
|
||
return $return;
|
||
|
||
}
|
||
}
|
||
|
||
if ( ! function_exists( 'twentytwenty_get_customizer_css' ) ) {
|
||
|
||
/**
|
||
* Get CSS Built from Customizer Options.
|
||
* Build CSS reflecting colors, fonts and other options set in the Customizer, and return them for output.
|
||
*
|
||
* @param string $type Whether to return CSS for the "front-end", "block-editor" or "classic-editor".
|
||
*/
|
||
function twentytwenty_get_customizer_css( $type = 'front-end' ) {
|
||
|
||
// Get variables.
|
||
$body = sanitize_hex_color( twentytwenty_get_color_for_area( 'content', 'text' ) );
|
||
$body_default = '#000000';
|
||
$accent = sanitize_hex_color( twentytwenty_get_color_for_area( 'content', 'accent' ) );
|
||
$accent_default = '#cd2653';
|
||
$buttons_targets = apply_filters( 'twentytwenty_buttons_targets_front_end', 'button, .button, .faux-button, .wp-block-button__link, .wp-block-file__button, input[type=\'button\'], input[type=\'reset\'], input[type=\'submit\']' );
|
||
|
||
// Header.
|
||
$header_footer_text = sanitize_hex_color( twentytwenty_get_color_for_area( 'header-footer', 'text' ) );
|
||
$header_footer_accent = sanitize_hex_color( twentytwenty_get_color_for_area( 'header-footer', 'accent' ) );
|
||
|
||
// Cover.
|
||
$cover = sanitize_hex_color( get_theme_mod( 'cover_template_overlay_text_color' ) );
|
||
$cover_default = '#ffffff';
|
||
|
||
// Background.
|
||
$background = sanitize_hex_color_no_hash( get_theme_mod( 'background_color' ) );
|
||
$background_default = 'f5efe0';
|
||
|
||
ob_start();
|
||
|
||
/**
|
||
* Note – Styles are applied in this order:
|
||
* 1. Element specific
|
||
* 2. Helper classes
|
||
*
|
||
* This enables all helper classes to overwrite base element styles,
|
||
* meaning that any color classes applied in the block editor will
|
||
* have a higher priority than the base element styles.
|
||
*/
|
||
|
||
// Front-End Styles.
|
||
if ( 'front-end' === $type ) {
|
||
|
||
// Auto-calculated colors.
|
||
$elements_definitions = twentytwenty_get_elements_array();
|
||
foreach ( $elements_definitions as $context => $props ) {
|
||
foreach ( $props as $key => $definitions ) {
|
||
foreach ( $definitions as $property => $elements ) {
|
||
$val = twentytwenty_get_color_for_area( $context, $key );
|
||
if ( $val ) {
|
||
twentytwenty_generate_css( implode( ',', $elements ), $property, $val );
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
if ( $cover && $cover !== $cover_default ) {
|
||
twentytwenty_generate_css( '.cover-header .entry-header *', 'color', $cover );
|
||
}
|
||
|
||
// Helper Classes.
|
||
if ( $accent && $accent !== $accent_default ) {
|
||
twentytwenty_generate_css( '.color-accent, .color-accent-hover:hover, .has-accent-color', 'color', $accent );
|
||
twentytwenty_generate_css( '.bg-accent, .bg-accent-hover:hover, .has-accent-background-color', 'background-color', $accent );
|
||
twentytwenty_generate_css( '.border-color-accent, .border-color-accent-hover:hover', 'border-color', $accent );
|
||
twentytwenty_generate_css( '.fill-children-accent, .fill-children-accent *', 'fill', $accent );
|
||
}
|
||
|
||
// Block Editor Styles.
|
||
} elseif ( 'block-editor' === $type ) {
|
||
|
||
// Colors.
|
||
// Accent color.
|
||
if ( $accent && $accent !== $accent_default ) {
|
||
twentytwenty_generate_css( '.editor-styles-wrapper a, .editor-styles-wrapper .has-drop-cap:not(:focus):first-letter', 'color', $accent );
|
||
twentytwenty_generate_css( '.editor-styles-wrapper blockquote, .editor-styles-wrapper .wp-block-quote', 'border-color', $accent, '', ' !important' );
|
||
twentytwenty_generate_css( '.editor-styles-wrapper .wp-block-file .wp-block-file__textlink', 'color', $accent );
|
||
twentytwenty_generate_css( $buttons_targets, 'background', $accent );
|
||
twentytwenty_generate_css( '.editor-styles-wrapper .wp-block-button.is-style-outline .wp-block-button__link', 'border-color', $accent );
|
||
twentytwenty_generate_css( '.editor-styles-wrapper .wp-block-button.is-style-outline .wp-block-button__link', 'color', $accent );
|
||
}
|
||
|
||
// Background color.
|
||
if ( $background && $background !== $background_default ) {
|
||
twentytwenty_generate_css( '.editor-styles-wrapper', 'background', '#' . $background );
|
||
}
|
||
|
||
// Text color.
|
||
if ( $body && $body !== $body_default ) {
|
||
twentytwenty_generate_css( 'body .editor-styles-wrapper, body .editor-post-title__block, body .editor-post-title__input, body textarea, .editor-post-title__block .editor-post-title__input', 'color', $body );
|
||
}
|
||
} elseif ( 'classic-editor' === $type ) {
|
||
|
||
// Colors.
|
||
// Accent color.
|
||
if ( $accent && $accent !== $accent_default ) {
|
||
twentytwenty_generate_css( 'body#tinymce.wp-editor a', 'color', $accent );
|
||
twentytwenty_generate_css( 'body#tinymce.wp-editor blockquote, body#tinymce.wp-editor .wp-block-quote', 'border-color', $accent, '', ' !important' );
|
||
twentytwenty_generate_css( $buttons_targets, 'background-color', $accent );
|
||
}
|
||
|
||
// Background color.
|
||
if ( $background && $background !== $background_default ) {
|
||
twentytwenty_generate_css( 'body#tinymce.wp-editor', 'background', '#' . $background );
|
||
}
|
||
}
|
||
|
||
// Return the results.
|
||
return ob_get_clean();
|
||
|
||
}
|
||
}
|