oont-contents/themes/astra/inc/class-astra-global-palette.php
2025-02-08 15:10:23 +01:00

319 lines
11 KiB
PHP

<?php
/**
* Astra Global color palette
*
* @package Astra
* @subpackage Class
* @link https://wpastra.com/
* @since 3.7.0
*/
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
/**
* Global palette class
*/
class Astra_Global_Palette {
/**
* Constructor
*
* @since 3.7.0
*/
public function __construct() {
/**
* Support for overriding theme.json from the child theme
*
* If theme.json is not present in the child theme load Global Color Palette in the editor using add_theme_support( 'editor-color-palette', $editor_palette );.
* This is a known issue in Gutenberg - If theme.json is not present in the child theme, it does fallback to the parent theme's theme.json file.
* This will be fixed in the future updates of WordPress/Gutenberg.
*
* @see https://github.com/WordPress/gutenberg/pull/34354
*/
$get_stylesheet = get_stylesheet_directory();
$is_theme_json = $get_stylesheet . '/theme.json';
if ( ( get_template_directory() !== $get_stylesheet && false === file_exists( $is_theme_json ) ) || astra_wp_version_compare( '5.8', '<' ) ) {
add_action( 'after_setup_theme', array( $this, 'support_editor_color_palette' ) );
}
add_filter( 'astra_theme_customizer_js_localize', array( $this, 'localize_variables' ) );
add_filter( 'astra_before_foreground_color_generation', array( $this, 'get_color_by_palette_variable' ) );
$this->includes();
add_filter( 'astra_dynamic_theme_css', array( $this, 'global_border_compatibility' ) );
}
/**
* Modify color palette from Gutenberg.
*
* @since 3.7.0
* @return void
*/
public function support_editor_color_palette() {
$global_palette = astra_get_option( 'global-color-palette' );
$editor_palette = $this->format_global_palette( $global_palette );
add_theme_support( 'editor-color-palette', $editor_palette );
}
/**
* Format color palette data required to pass for Gutenberg palette.
*
* @since 3.7.0
* @param array $global_palette global palette data.
* @return array
*/
public function format_global_palette( $global_palette ) {
$editor_palette = array();
$labels = self::get_palette_labels();
if ( isset( $global_palette['palette'] ) ) {
foreach ( $global_palette['palette'] as $key => $color ) {
$label = 'Theme ' . $labels[ $key ];
$editor_palette[] = array(
'name' => $label,
'slug' => str_replace( '--', '', self::get_css_variable_prefix() ) . $key,
'color' => 'var(' . self::get_css_variable_prefix() . $key . ')',
);
}
}
return $editor_palette;
}
/**
* Get CSS variable prefix used for styling.
*
* @since 3.7.0
* @return string variable prefix
*/
public static function get_css_variable_prefix() {
return '--ast-global-color-';
}
/**
* Localize variables used in the customizer.
*
* @since 3.7.0
* @param array $object localize object.
* @return array<array-key, mixed> $object localize object.
*/
public function localize_variables( $object ) {
if ( isset( $object['customizer'] ) ) {
$object['customizer']['globalPaletteStylePrefix'] = self::get_css_variable_prefix();
$object['customizer']['isElementorActive'] = astra_is_elemetor_active();
$object['customizer']['isGlobalColorElementorDisabled'] = astra_maybe_disable_global_color_in_elementor();
$object['customizer']['globalPaletteSlugs'] = self::get_palette_slugs();
$object['customizer']['globalPaletteLabels'] = self::get_palette_labels();
}
return $object;
}
/**
* Default global palette options.
*
* @since 3.7.0
* @return array Palette options.
*/
public static function get_default_color_palette() {
$update_colors_for_starter_library = Astra_Dynamic_CSS::astra_4_4_0_compatibility();
$update_color_styles_with_presets = Astra_Dynamic_CSS::astra_4_5_0_compatibility();
$update_color_for_forms_ui = Astra_Dynamic_CSS::astra_4_6_0_compatibility();
$color_palette_reorganize = Astra_Dynamic_CSS::astra_4_8_9_compatibility();
return array(
'currentPalette' => 'palette_1',
'palettes' => $update_color_styles_with_presets ? array(
'palette_1' => array(
'#046bd2',
'#045cb4',
'#1e293b',
'#334155',
$color_palette_reorganize ? '#FFFFFF' : '#F0F5FA',
$color_palette_reorganize ? '#F0F5FA' : '#FFFFFF',
$color_palette_reorganize ? '#111111' : ( $update_color_for_forms_ui ? '#D1D5DB' : '#ADB6BE' ),
$color_palette_reorganize ? ( $update_color_for_forms_ui ? '#D1D5DB' : '#ADB6BE' ) : '#111111',
'#111111',
),
'palette_2' => array(
'#0067FF',
'#005EE9',
'#0F172A',
'#364151',
$color_palette_reorganize ? '#FFFFFF' : '#E7F6FF',
$color_palette_reorganize ? '#E7F6FF' : '#FFFFFF',
$color_palette_reorganize ? '#070614' : '#D1DAE5',
$color_palette_reorganize ? '#D1DAE5' : '#070614',
'#222222',
),
'palette_3' => array(
'#6528F7',
'#5511F8',
'#0F172A',
'#454F5E',
$color_palette_reorganize ? '#FFFFFF' : '#F2F0FE',
$color_palette_reorganize ? '#F2F0FE' : '#FFFFFF',
$color_palette_reorganize ? '#0D0614' : '#D8D8F5',
$color_palette_reorganize ? '#D8D8F5' : '#0D0614',
'#222222',
),
) : array(
'palette_1' => array(
'#046bd2',
'#045cb4',
'#1e293b',
'#334155',
$color_palette_reorganize ? '#FFFFFF' : ( $update_colors_for_starter_library ? '#F0F5FA' : '#f9fafb' ),
$color_palette_reorganize ? ( $update_colors_for_starter_library ? '#F0F5FA' : '#f9fafb' ) : '#FFFFFF',
$color_palette_reorganize ? ( $update_colors_for_starter_library ? '#111111' : '#cbd5e1' ) : ( $update_colors_for_starter_library ? '#ADB6BE' : '#e2e8f0' ),
$color_palette_reorganize ? ( $update_colors_for_starter_library ? '#ADB6BE' : '#e2e8f0' ) : ( $update_colors_for_starter_library ? '#111111' : '#cbd5e1' ),
$update_colors_for_starter_library ? '#111111' : '#94a3b8',
),
'palette_2' => array(
'#0170B9',
$update_colors_for_starter_library ? '#045cb4' : '#3a3a3a',
'#3a3a3a',
'#4B4F58',
$color_palette_reorganize ? '#FFFFFF' : ( $update_colors_for_starter_library ? '#F0F5FA' : '#F5F5F5' ),
$color_palette_reorganize ? ( $update_colors_for_starter_library ? '#F0F5FA' : '#F5F5F5' ) : '#FFFFFF',
$color_palette_reorganize ? ( $update_colors_for_starter_library ? '#111111' : '#424242' ) : ( $update_colors_for_starter_library ? '#ADB6BE' : '#F2F5F7' ),
$color_palette_reorganize ? ( $update_colors_for_starter_library ? '#ADB6BE' : '#F2F5F7' ) : ( $update_colors_for_starter_library ? '#111111' : '#424242' ),
$update_colors_for_starter_library ? '#111111' : '#000000',
),
'palette_3' => array(
'#0170B9',
$update_colors_for_starter_library ? '#045cb4' : '#3a3a3a',
'#3a3a3a',
'#4B4F58',
$color_palette_reorganize ? '#FFFFFF' : ( $update_colors_for_starter_library ? '#F0F5FA' : '#F5F5F5' ),
$color_palette_reorganize ? ( $update_colors_for_starter_library ? '#F0F5FA' : '#F5F5F5' ) : '#FFFFFF',
$color_palette_reorganize ? ( $update_colors_for_starter_library ? '#111111' : '#424242' ) : ( $update_colors_for_starter_library ? '#ADB6BE' : '#F2F5F7' ),
$color_palette_reorganize ? ( $update_colors_for_starter_library ? '#ADB6BE' : '#F2F5F7' ) : ( $update_colors_for_starter_library ? '#111111' : '#424242' ),
$update_colors_for_starter_library ? '#111111' : '#000000',
),
),
'presets' => astra_get_palette_presets(),
);
}
/**
* Get labels for palette colors.
*
* @since 3.7.0
* @return array Palette labels.
*/
public static function get_palette_labels() {
$astra_settings = Astra_Theme_Options::get_options();
$new_color_palette_labels = apply_filters( 'astra_new_color_labels', Astra_Dynamic_CSS::astra_4_8_9_compatibility() || isset( $astra_settings['new-color-labels'] ) );
return array(
$new_color_palette_labels ? __( 'Brand', 'astra' ) : __( 'Color 1', 'astra' ),
$new_color_palette_labels ? __( 'Alternate Brand', 'astra' ) : __( 'Color 2', 'astra' ),
$new_color_palette_labels ? __( 'Headings', 'astra' ) : __( 'Color 3', 'astra' ),
$new_color_palette_labels ? __( 'Text', 'astra' ) : __( 'Color 4', 'astra' ),
$new_color_palette_labels ? __( 'Primary Background', 'astra' ) : __( 'Color 5', 'astra' ),
$new_color_palette_labels ? __( 'Secondary Background', 'astra' ) : __( 'Color 6', 'astra' ),
$new_color_palette_labels ? __( 'Alternate Background', 'astra' ) : __( 'Color 7', 'astra' ),
$new_color_palette_labels ? __( 'Subtle Background', 'astra' ) : __( 'Color 8', 'astra' ),
$new_color_palette_labels ? __( 'Other Supporting', 'astra' ) : __( 'Color 9', 'astra' ),
);
}
/**
* Get slugs for palette colors.
*
* @since 3.7.0
* @return array Palette slugs.
*/
public static function get_palette_slugs() {
return array(
'ast-global-color-0',
'ast-global-color-1',
'ast-global-color-2',
'ast-global-color-3',
'ast-global-color-4',
'ast-global-color-5',
'ast-global-color-6',
'ast-global-color-7',
'ast-global-color-8',
);
}
/**
* Include required files.
*
* @since 3.7.0
*/
public function includes() {
require_once ASTRA_THEME_DIR . 'inc/dynamic-css/global-color-palette.php';// PHPCS:ignore WPThemeReview.CoreFunctionality.FileInclude.FileIncludeFound
}
/**
* Generate palette CSS required to display on front end.
*
* @since 3.7.0
* @return array palette style array.
*/
public static function generate_global_palette_style() {
$palette_data = astra_get_option( 'global-color-palette' );
$palette_style = array();
if ( isset( $palette_data['palette'] ) ) {
foreach ( $palette_data['palette'] as $key => $color ) {
$palette_key = self::get_css_variable_prefix() . $key;
$palette_style[ $palette_key ] = $color;
}
}
return $palette_style;
}
/**
* Pass hex value for global palette to process forground color.
*
* @since 3.7.0
* @param string $color hex color / css variable.
* @return string
*/
public function get_color_by_palette_variable( $color ) {
// Check if color is CSS variable.
if ( 0 === strpos( $color, 'var(--' ) ) {
$global_palette = astra_get_option( 'global-color-palette' );
foreach ( $global_palette['palette'] as $palette_index => $value ) {
if ( 'var(' . self::get_css_variable_prefix() . $palette_index . ')' === $color ) {
return $value;
}
}
}
return $color;
}
/**
* Add dynamic CSS for the global border color.
*
* @since 3.9.0
*
* @param string $dynamic_css Astra Dynamic CSS.
*
* @return String Generated dynamic CSS for global border.
*/
public function global_border_compatibility( $dynamic_css ) {
$global_border_color = astra_get_option( 'border-color', '#dddddd' );
$global_border = '
:root {
--ast-border-color : ' . $global_border_color . ';
}
';
return $dynamic_css .= Astra_Enqueue_Scripts::trim_css( $global_border );
}
}
new Astra_Global_Palette();