Control_Text_Shadow()
Elementor text shadow control.
Description
A base control for creating text shadows control. Displays input fields for horizontal shadow, vertical shadow, shadow blur and shadow color.
Changelog
Version | Description |
---|---|
1.6.0 | Introduced. |
Methods
- content_template — Render text shadow control output in the editor.
- get_default_value — Get text shadow control default values.
- get_sliders — Get text shadow control sliders.
- get_type — Get text shadow control type.
Source
includes/controls/text-shadow.php
class Control_Text_Shadow extends Control_Base_Multiple { /** * Retrieve text shadow control type. * * @since 1.6.0 * @access public * * @return string Control type. */ public function get_type() { return 'text_shadow'; } /** * Retrieve text shadow control default values. * * Get the default value of the text shadow control. Used to return the * default values while initializing the text shadow control. * * @since 1.6.0 * @access public * * @return array Control default value. */ public function get_default_value() { return [ 'horizontal' => 0, 'vertical' => 0, 'blur' => 10, 'color' => 'rgba(0,0,0,0.3)', ]; } /** * Retrieve text shadow control sliders. * * Get the sliders of the text shadow control. Sliders are used while * rendering the control output in the editor. * * @since 1.6.0 * @access public * * @return array Control sliders. */ public function get_sliders() { return [ 'blur' => [ 'label' => __( 'Blur', 'elementor' ), 'min' => 0, 'max' => 100, ], 'horizontal' => [ 'label' => __( 'Horizontal', 'elementor' ), 'min' => -100, 'max' => 100, ], 'vertical' => [ 'label' => __( 'Vertical', 'elementor' ), 'min' => -100, 'max' => 100, ], ]; } /** * Render text shadow control output in the editor. * * Used to generate the control HTML in the editor using Underscore JS * template. The variables for the class are available using `data` JS * object. * * @since 1.6.0 * @access public */ public function content_template() { ?> <# var defaultColorValue = ''; if ( data.default.color ) { if ( '#' !== data.default.color.substring( 0, 1 ) ) { defaultColorValue = '#' + data.default.color; } else { defaultColorValue = data.default.color; } defaultColorValue = ' data-default-color=' + defaultColorValue; // Quotes added automatically. } #> <div class="elementor-control-field"> <label class="elementor-control-title"><?php _e( 'Color', 'elementor' ); ?></label> <div class="elementor-control-input-wrapper"> <input data-setting="color" class="elementor-shadow-color-picker" type="text" placeholder="<?php echo esc_attr( 'Hex/rgba', 'elementor' ); ?>" data-alpha="true"{{{ defaultColorValue }}} /> </div> </div> <?php foreach ( $this->get_sliders() as $slider_name => $slider ) : $control_uid = $this->get_control_uid( $slider_name ); ?> <div class="elementor-shadow-slider"> <label for="<?php echo $control_uid; ?>" class="elementor-control-title"><?php echo $slider['label']; ?></label> <div class="elementor-control-input-wrapper"> <div class="elementor-slider" data-input="<?php echo $slider_name; ?>"></div> <div class="elementor-slider-input"> <input id="<?php echo $control_uid; ?>" type="number" min="<?php echo $slider['min']; ?>" max="<?php echo $slider['max']; ?>" data-setting="<?php echo $slider_name; ?>"/> </div> </div> </div> <?php endforeach; ?> <?php } }