# Hover Animation Control

Elementor Core Basic Hover Animation Control

Elementor hover animation control displays a select box field based on the Hover.css (opens new window) library. The control allows to set an hover animation effect for an item.

The control is defined in Control_Hover_Animation class which extends Base_Data_Control class.

When using this control, the type should be set to \Elementor\Controls_Manager::HOVER_ANIMATION constant.

# Arguments

NameTypeDefaultDescription
typestringhover_animationThe type of the control.
labelstringThe label that appears above of the field.
descriptionstringThe description that appears below the field.
show_labelbooltrueWhether to display the label.
label_blockbooltrueWhether to display the label in a separate line.
separatorstringdefaultSet the position of the control separator. Available values are default, before and after. default will hide the separator, unless the control type has specific separator settings. before / after will position the separator before/after the control.
defaultstringThe field default value.

# Return Value

(string) The selected hover animation class.

# Usage














 
 
 
 
 
 
 








 
 
 
 
 

 
 
 





 
 
 
 
 
 
 
 
 
 









<?php
class Elementor_Test_Widget extends \Elementor\Widget_Base {

	protected function register_controls(): void {

		$this->start_controls_section(
			'style_section',
			[
				'label' => esc_html__( 'Style', 'textdomain' ),
				'tab' => \Elementor\Controls_Manager::TAB_STYLE,
			]
		);

		$this->add_control(
			'hover_animation',
			[
				'label' => esc_html__( 'Hover Animation', 'textdomain' ),
				'type' => \Elementor\Controls_Manager::HOVER_ANIMATION,
			]
		);

		$this->end_controls_section();

	}

	protected function render(): void {
		$settings = $this->get_settings_for_display();

		$elementClass = 'container';

		if ( $settings['hover_animation'] ) {
			$elementClass .= ' elementor-animation-' . $settings['hover_animation'];
		}

		$this->add_render_attribute( 'wrapper', 'class', $elementClass );
		?>
		<div <?php $this->print_render_attribute_string( 'wrapper' ); ?>>
			...
		</div>
		<?php
	}

	protected function content_template(): void {
		?>
		<#
		const elementClass = 'container';

		if ( '' !== settings.hover_animation ) {
			elementClass += ' elementor-animation-' + settings.hover_animation;
		}

		view.addRenderAttribute( 'wrapper', { 'class': elementClass } );
		#>
		<div {{{ view.getRenderAttributeString( 'wrapper' ) }}}>
			...
		</div>
		<?php
	}

}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60