| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149 |
- <?php
- namespace Elementor;
- if ( ! defined( 'ABSPATH' ) ) {
- exit; // Exit if accessed directly.
- }
- /**
- * Elementor animation control.
- *
- * A base control for creating entrance animation control. Displays a select box
- * with the available entrance animation effects @see Control_Animation::get_animations() .
- *
- * @since 1.0.0
- */
- class Control_Animation extends Base_Data_Control {
- /**
- * List of animations.
- *
- * Holds the list of all the available animations.
- *
- * @access private
- * @static
- *
- * @var array
- */
- private static $_animations;
- /**
- * Get control type.
- *
- * Retrieve the animation control type.
- *
- * @since 1.0.0
- * @access public
- *
- * @return string Control type.
- */
- public function get_type() {
- return 'animation';
- }
- /**
- * Get animations list.
- *
- * Retrieve the list of all the available animations.
- *
- * @since 1.0.0
- * @access public
- * @static
- *
- * @return array Control type.
- */
- public static function get_animations() {
- if ( is_null( self::$_animations ) ) {
- self::$_animations = [
- 'Fading' => [
- 'fadeIn' => 'Fade In',
- 'fadeInDown' => 'Fade In Down',
- 'fadeInLeft' => 'Fade In Left',
- 'fadeInRight' => 'Fade In Right',
- 'fadeInUp' => 'Fade In Up',
- ],
- 'Zooming' => [
- 'zoomIn' => 'Zoom In',
- 'zoomInDown' => 'Zoom In Down',
- 'zoomInLeft' => 'Zoom In Left',
- 'zoomInRight' => 'Zoom In Right',
- 'zoomInUp' => 'Zoom In Up',
- ],
- 'Bouncing' => [
- 'bounceIn' => 'Bounce In',
- 'bounceInDown' => 'Bounce In Down',
- 'bounceInLeft' => 'Bounce In Left',
- 'bounceInRight' => 'Bounce In Right',
- 'bounceInUp' => 'Bounce In Up',
- ],
- 'Sliding' => [
- 'slideInDown' => 'Slide In Down',
- 'slideInLeft' => 'Slide In Left',
- 'slideInRight' => 'Slide In Right',
- 'slideInUp' => 'Slide In Up',
- ],
- 'Rotating' => [
- 'rotateIn' => 'Rotate In',
- 'rotateInDownLeft' => 'Rotate In Down Left',
- 'rotateInDownRight' => 'Rotate In Down Right',
- 'rotateInUpLeft' => 'Rotate In Up Left',
- 'rotateInUpRight' => 'Rotate In Up Right',
- ],
- 'Attention Seekers' => [
- 'bounce' => 'Bounce',
- 'flash' => 'Flash',
- 'pulse' => 'Pulse',
- 'rubberBand' => 'Rubber Band',
- 'shake' => 'Shake',
- 'headShake' => 'Head Shake',
- 'swing' => 'Swing',
- 'tada' => 'Tada',
- 'wobble' => 'Wobble',
- 'jello' => 'Jello',
- ],
- 'Light Speed' => [
- 'lightSpeedIn' => 'Light Speed In',
- ],
- 'Specials' => [
- 'rollIn' => 'Roll In',
- ],
- ];
- }
- return self::$_animations;
- }
- /**
- * Render animations control template.
- *
- * 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.0.0
- * @access public
- */
- public function content_template() {
- $control_uid = $this->get_control_uid();
- ?>
- <div class="elementor-control-field">
- <label for="<?php echo $control_uid; ?>" class="elementor-control-title">{{{ data.label }}}</label>
- <div class="elementor-control-input-wrapper">
- <select id="<?php echo $control_uid; ?>" data-setting="{{ data.name }}">
- <option value=""><?php echo __( 'None', 'elementor' ); ?></option>
- <?php foreach ( self::get_animations() as $animations_group_name => $animations_group ) : ?>
- <optgroup label="<?php echo $animations_group_name; ?>">
- <?php foreach ( $animations_group as $animation_name => $animation_title ) : ?>
- <option value="<?php echo $animation_name; ?>"><?php echo $animation_title; ?></option>
- <?php endforeach; ?>
- </optgroup>
- <?php endforeach; ?>
- </select>
- </div>
- </div>
- <# if ( data.description ) { #>
- <div class="elementor-control-field-description">{{{ data.description }}}</div>
- <# } #>
- <?php
- }
- }
|