/var/www/html_us/wp-content/plugins/elementor/includes/widgets/menu-anchor.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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
<?php
namespace Elementor;

if ( ! 
defined'ABSPATH' ) ) {
    exit; 
// Exit if accessed directly.
}

/**
 * Elementor menu anchor widget.
 *
 * Elementor widget that allows to link and menu to a specific position on the
 * page.
 *
 * @since 1.0.0
 */
class Widget_Menu_Anchor extends Widget_Base {

    
/**
     * Get widget name.
     *
     * Retrieve menu anchor widget name.
     *
     * @since 1.0.0
     * @access public
     *
     * @return string Widget name.
     */
    
public function get_name() {
        return 
'menu-anchor';
    }

    
/**
     * Get widget title.
     *
     * Retrieve menu anchor widget title.
     *
     * @since 1.0.0
     * @access public
     *
     * @return string Widget title.
     */
    
public function get_title() {
        return 
esc_html__'Menu Anchor''elementor' );
    }

    
/**
     * Get widget icon.
     *
     * Retrieve menu anchor widget icon.
     *
     * @since 1.0.0
     * @access public
     *
     * @return string Widget icon.
     */
    
public function get_icon() {
        return 
'eicon-anchor';
    }

    
/**
     * Get widget keywords.
     *
     * Retrieve the list of keywords the widget belongs to.
     *
     * @since 2.1.0
     * @access public
     *
     * @return array Widget keywords.
     */
    
public function get_keywords() {
        return [ 
'menu''anchor''link' ];
    }

    protected function 
is_dynamic_content(): bool {
        return 
false;
    }

    
/**
     * Get style dependencies.
     *
     * Retrieve the list of style dependencies the widget requires.
     *
     * @since 3.24.0
     * @access public
     *
     * @return array Widget style dependencies.
     */
    
public function get_style_depends(): array {
        return [ 
'widget-menu-anchor' ];
    }

    public function 
has_widget_inner_wrapper(): bool {
        return ! 
Plugin::$instance->experiments->is_feature_active'e_optimized_markup' );
    }

    
/**
     * Register menu anchor widget controls.
     *
     * Adds different input fields to allow the user to change and customize the widget settings.
     *
     * @since 3.1.0
     * @access protected
     */
    
protected function register_controls() {
        
$this->start_controls_section(
            
'section_anchor',
            [
                
'label' => esc_html__'Menu Anchor''elementor' ),
            ]
        );

        
$this->add_control(
            
'anchor',
            [
                
'label' => esc_html__'The ID of Menu Anchor.''elementor' ),
                
'type' => Controls_Manager::TEXT,
                
'ai' => [
                    
'active' => false,
                ],
                
'placeholder' => esc_html__'For Example: About''elementor' ),
                
'description' => esc_html__'This ID will be the CSS ID you will have to use in your own page, Without #.''elementor' ),
                
'label_block' => true,
                
'dynamic' => [
                    
'active' => true,
                ],
            ]
        );

        
$this->add_control(
            
'anchor_note',
            [
                
'type' => Controls_Manager::ALERT,
                
'alert_type' => 'warning',
                
'content' => sprintf(
                    
/* translators: %s: Accepted chars. */
                    
esc_html__'Note: The ID link ONLY accepts these chars: %s''elementor' ),
                    
'`A-Z, a-z, 0-9, _ , -`'
                
),
            ]
        );

        
$this->end_controls_section();
    }

    
/**
     * Render menu anchor widget output on the frontend.
     *
     * Written in PHP and used to generate the final HTML.
     *
     * @since 1.0.0
     * @access protected
     */
    
protected function render() {
        
$anchor $this->get_settings_for_display'anchor' );

        if ( empty( 
$anchor ) ) {
            return;
        }

        
$this->add_render_attribute(
            
'inner',
            [
                
'class' => 'elementor-menu-anchor',
                
'id' => sanitize_html_class$anchor ),
            ]
        );
        
?>
        <div <?php $this->print_render_attribute_string'inner' ); ?>></div>
        <?php
    
}

    
/**
     * Render menu anchor widget output in the editor.
     *
     * Written as a Backbone JavaScript template and used to generate the live preview.
     *
     * @since 2.9.0
     * @access protected
     */
    
protected function content_template() {
        
?>
        <#
        if ( '' === settings.anchor ) {
            return;
        }

        view.addRenderAttribute(
            'inner',
            {
                'class': 'elementor-menu-anchor',
                'id': settings.anchor,
            }
        );
        #>
        <div {{{ view.getRenderAttributeString( 'inner' ) }}}></div>
        <?php
    
}

    protected function 
on_save( array $settings ) {
        
$settings['anchor'] = sanitize_html_class$settings['anchor'] );

        return 
$settings;
    }
}