HEX
Server: Apache
System: Linux vps-3158868-x.dattaweb.com 3.10.0-1160.119.1.el7.x86_64 #1 SMP Tue Jun 4 14:43:51 UTC 2024 x86_64
User: emerlux (1185)
PHP: 8.3.1
Disabled: system, shell, exec, system_exec, shell_exec, mysql_pconnect, passthru, popen, proc_open, proc_close, proc_nice, proc_terminate, proc_get_status, escapeshellarg, escapeshellcmd, eval
Upload Files
File: /home/emerlux/public_html/wp-content/plugins/porto-functionality/elementor/widgets/sticky_nav.php
<?php
if ( ! defined( 'ABSPATH' ) ) {
	exit; // Exit if accessed directly.
}

/**
 * Porto Elementor Sticky Navigation Widget
 *
 * Porto Elementor widget to display sticky navigation
 *
 * @since 2.3.0
 */

use Elementor\Controls_Manager;

class Porto_Elementor_Sticky_Nav_Widget extends \Elementor\Widget_Base {

	public function get_name() {
		return 'porto_sticky_nav';
	}

	public function get_title() {
		return __( 'Porto Sticky Navigation', 'porto-functionality' );
	}

	public function get_categories() {
		return array( 'porto-elements' );
	}

	public function get_keywords() {
		return array( 'sticky', 'navigation', 'menu' );
	}

	public function has_widget_inner_wrapper(): bool {
		return ! Elementor\Plugin::$instance->experiments->is_feature_active( 'e_optimized_markup' );
	}
	
	public function get_icon() {
		return 'eicon-navigation-horizontal porto-elementor-widget-icon';
	}

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

	protected function register_controls() {

		$this->start_controls_section(
			'section_sticky_nav',
			array(
				'label' => __( 'Sticky Navigation', 'porto-functionality' ),
			)
		);

		$this->add_control(
			'description_nav',
			array(
				'type'            => Controls_Manager::RAW_HTML,
				'raw'             => sprintf( esc_html__( 'Please don\'t put this widget on sticky header.', 'porto-functionality' ), '<b>', '</b>' ),
				'content_classes' => 'elementor-panel-alert elementor-panel-alert-info',
			)
		);

		$this->add_control(
			'container',
			array(
				'type'  => Controls_Manager::SWITCHER,
				'label' => __( 'Wrap as Container', 'porto-functionality' ),
			)
		);

		$this->add_control(
			'min_width',
			array(
				'type'        => Controls_Manager::NUMBER,
				'label'       => __( 'Min Width (unit: px)', 'porto-functionality' ),
				'description' => __( 'Wll be disable sticky if window width is smaller than min width', 'porto-functionality' ),
				'min'         => 320,
				'max'         => 1920,
				'default'     => 992,
			)
		);

		$this->add_control(
			'bg_color1',
			array(
				'type'      => Controls_Manager::COLOR,
				'label'     => __( 'Background Color', 'porto-functionality' ),
				'selectors' => array(
					'{{WRAPPER}} .porto-sticky-nav' => 'background-color: {{VALUE}};',
				),
			)
		);

		$this->add_group_control(
			Elementor\Group_Control_Typography::get_type(),
			array(
				'name'     => 'typography',
				'label'    => __( 'Link Typography', 'porto-functionality' ),
				'selector' => '.elementor-element-{{ID}} .nav-pills > li > a, .elementor-element-{{ID}} .nav-pills > li > span, .elementor-element-{{ID}} .nav-pills > li > a i, .elementor-element-{{ID}} .nav-pills > li > span i',
			)
		);

		$this->add_control(
			'skin',
			array(
				'type'      => Controls_Manager::SELECT,
				'label'     => __( 'Skin Color', 'porto-functionality' ),
				'options'   => array_combine( array_values( porto_sh_commons( 'colors' ) ), array_keys( porto_sh_commons( 'colors' ) ) ),
				'default'   => 'custom',
				'separator' => 'before',
			)
		);

		$this->add_responsive_control(
			'link_padding',
			array(
				'label'      => __( 'Link Padding', 'porto-functionality' ),
				'type'       => Controls_Manager::DIMENSIONS,
				'selectors'  => array(
					'.elementor-element-{{ID}} .nav-pills > li > a, .elementor-element-{{ID}} .nav-pills > li > span' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
				),
				'size_units' => array( 'px', 'em', 'rem' ),
			)
		);

		$this->add_control(
			'link_border_width',
			array(
				'type'      => Controls_Manager::SLIDER,
				'label'     => __( 'Border Bottom Width', 'porto-functionality' ),
				'range'     => array(
					'px' => array(
						'step' => 1,
						'min'  => 1,
						'max'  => 100,
					),
				),
				'selectors' => array(
					'.elementor-element-{{ID}} .nav li a, .elementor-element-{{ID}} .nav li span' => 'border-bottom: {{SIZE}}{{UNIT}} solid;',
				),
			)
		);

		$this->add_control(
			'fill_wrap',
			array(
				'type'        => Controls_Manager::SWITCHER,
				'label'       => __( 'Fill the wrap', 'porto-functionality' ),
				'selectors'   => array(
					'.elementor-element-{{ID}} .nav li' => 'flex:1; text-align:center;',
				),
			)
		);

		$repeater = new Elementor\Repeater();

		$repeater->start_controls_tabs(
			'sticky_nav_items'
		);

		$repeater->start_controls_tab(
			'sticky_nav_item',
			array(
				'label' => esc_html__( 'Content', 'porto-functionality' ),
			)
		);

		$repeater->add_control(
			'label',
			array(
				'type'  => Controls_Manager::TEXT,
				'label' => __( 'Label', 'porto-functionality' ),
			)
		);
		$repeater->add_control(
			'link',
			array(
				'type'  => Controls_Manager::URL,
				'label' => __( 'Link', 'porto-functionality' ),
			)
		);
		$repeater->add_control(
			'show_icon',
			array(
				'type'  => Controls_Manager::SWITCHER,
				'label' => __( 'Show Icon', 'porto-functionality' ),
			)
		);
		$repeater->add_control(
			'icon_type',
			array(
				'label'       => __( 'Icon to display', 'porto-functionality' ),
				'type'        => Controls_Manager::SELECT,
				'options'     => array(
					'icon'  => __( 'Icon Fonts', 'porto-functionality' ),
					'image' => __( 'Custom Image Icon', 'porto-functionality' ),
				),
				'default'     => 'icon',
				'description' => __( 'Use an existing font icon or upload a custom image.', 'porto-functionality' ),
				'condition'   => array(
					'show_icon' => 'yes',
				),
			)
		);
		$repeater->add_control(
			'icon_cl',
			array(
				'type'                   => Controls_Manager::ICONS,
				'label'                  => __( 'Icon', 'porto-functionality' ),
				'fa4compatibility'       => 'icon',
				'skin'                   => 'inline',
				'exclude_inline_options' => array( 'svg' ),
				'label_block'            => false,
				'default'                => array(
					'value'   => 'fas fa-star',
					'library' => 'fa-solid',
				),
				'condition'              => array(
					'show_icon' => 'yes',
					'icon_type' => 'icon',
				),
			)
		);
		$repeater->add_control(
			'icon_image',
			array(
				'type'        => Controls_Manager::MEDIA,
				'label'       => __( 'Upload Image Icon:', 'porto-functionality' ),
				'description' => __( 'Upload the custom image icon.', 'porto-functionality' ),
				'dynamic'     => array(
					'active' => true,
				),
				'condition'   => array(
					'show_icon' => 'yes',
					'icon_type' => array( 'image' ),
				),
			)
		);
		$repeater->add_control(
			'skin',
			array(
				'type'    => Controls_Manager::SELECT,
				'label'   => __( 'Skin Color', 'porto-functionality' ),
				'options' => array_combine( array_values( porto_sh_commons( 'colors' ) ), array_keys( porto_sh_commons( 'colors' ) ) ),
				'default' => 'custom',
			)
		);
		$repeater->add_control(
			'link_color1',
			array(
				'type'      => Controls_Manager::COLOR,
				'label'     => __( 'Color', 'porto-functionality' ),
				'selectors' => array(
					'.elementor-element-{{ID}} .nav-pills {{CURRENT_ITEM}} > a, .elementor-element-{{ID}} .nav-pills {{CURRENT_ITEM}} > span' => 'color: {{VALUE}};',
				),
				'condition' => array(
					'skin' => 'custom',
				),
			)
		);
		$repeater->add_control(
			'link_bg_color1',
			array(
				'type'      => Controls_Manager::COLOR,
				'label'     => __( 'Background Color', 'porto-functionality' ),
				'selectors' => array(
					'.elementor-element-{{ID}} .nav-pills {{CURRENT_ITEM}} > a, .elementor-element-{{ID}} .nav-pills {{CURRENT_ITEM}} > span' => 'background-color: {{VALUE}};',
				),
				'condition' => array(
					'skin' => 'custom',
				),
			)
		);

		$repeater->add_control(
			'link_border_color1',
			array(
				'type'      => Controls_Manager::COLOR,
				'label'     => __( 'Border Color', 'porto-functionality' ),
				'selectors' => array(
					'.elementor-element-{{ID}} .nav-pills.nav > {{CURRENT_ITEM}} > a, .elementor-element-{{ID}} .nav-pills.nav > {{CURRENT_ITEM}} > span' => 'border-bottom-color: {{VALUE}};',
				),
			)
		);

		$repeater->add_control(
			'link_acolor1',
			array(
				'type'      => Controls_Manager::COLOR,
				'label'     => __( 'Active Color', 'porto-functionality' ),
				'selectors' => array(
					'.elementor-element-{{ID}} .nav-pills {{CURRENT_ITEM}}.active > a, .elementor-element-{{ID}} .nav-pills {{CURRENT_ITEM}}:hover > a' => 'color: {{VALUE}};',
				),
				'condition' => array(
					'skin' => 'custom',
				),
			)
		);
		$repeater->add_control(
			'link_abg_color1',
			array(
				'type'      => Controls_Manager::COLOR,
				'label'     => __( 'Active Background Color', 'porto-functionality' ),
				'selectors' => array(
					'.elementor-element-{{ID}} .nav-pills {{CURRENT_ITEM}}.active > a, .elementor-element-{{ID}} .nav-pills {{CURRENT_ITEM}}:hover > a' => 'background-color: {{VALUE}};',
				),
				'condition' => array(
					'skin' => 'custom',
				),
			)
		);

		$repeater->add_control(
			'link_aborder_color1',
			array(
				'type'      => Controls_Manager::COLOR,
				'label'     => __( 'Active Border Color', 'porto-functionality' ),
				'selectors' => array(
					'.elementor-element-{{ID}} .nav-pills.nav > {{CURRENT_ITEM}}.active > a, .elementor-element-{{ID}} .nav-pills.nav > {{CURRENT_ITEM}}:hover > a' => 'border-bottom-color: {{VALUE}};',
				),
			)
		);

		$repeater->end_controls_tab();

		$repeater->end_controls_tabs();

		$presets = array(
			array(
				'label' => 'Item 1',
				'link'  => '#',
			),
			array(
				'label' => 'Item 2',
				'link'  => '#',
			),
		);
		$this->add_control(
			'sticky_nav_item_list',
			array(
				'label'   => esc_html__( 'Sticky Nav Items', 'porto-functionality' ),
				'type'    => Controls_Manager::REPEATER,
				'fields'  => $repeater->get_controls(),
				'default' => $presets,
			)
		);

		$this->start_controls_tabs(
			'Link Color'
		);

			$this->start_controls_tab(
				'link_color_normal',
				array(
					'label' => esc_html__( 'Normal', 'porto-functionality' ),
				)
			);
				$this->add_control(
					'link_color1',
					array(
						'type'      => Controls_Manager::COLOR,
						'label'     => __( 'Color', 'porto-functionality' ),
						'selectors' => array(
							'.elementor-element-{{ID}} .nav-pills > li > a, .elementor-element-{{ID}} .nav-pills > li > span' => 'color: {{VALUE}};',
						),
						'condition' => array(
							'skin' => 'custom',
						),
					)
				);

				$this->add_control(
					'link_bg_color1',
					array(
						'type'      => Controls_Manager::COLOR,
						'label'     => __( 'Background Color', 'porto-functionality' ),
						'selectors' => array(
							'.elementor-element-{{ID}} .nav-pills > li > a, .elementor-element-{{ID}} .nav-pills > li > span' => 'background-color: {{VALUE}};',
						),
						'condition' => array(
							'skin' => 'custom',
						),
					)
				);

				$this->add_control(
					'link_border_color1',
					array(
						'type'      => Controls_Manager::COLOR,
						'label'     => __( 'Border Color', 'porto-functionality' ),
						'selectors' => array(
							'.elementor-element-{{ID}} .nav-pills.nav > li > a, .elementor-element-{{ID}} .nav-pills.nav > li > span' => 'border-bottom-color: {{VALUE}};',
						),
						'condition' => array(
							'link_border_width[size]!' => '',
						),
					)
				);

			$this->end_controls_tab();

			$this->start_controls_tab(
				'link_color_active',
				array(
					'label' => esc_html__( 'Active', 'porto-functionality' ),
				)
			);

				$this->add_control(
					'link_acolor1',
					array(
						'type'      => Controls_Manager::COLOR,
						'label'     => __( 'Active Color', 'porto-functionality' ),
						'selectors' => array(
							'.elementor-element-{{ID}} .nav-pills > li.active > a, .elementor-element-{{ID}} .nav-pills > li:hover > a' => 'color: {{VALUE}};',
						),
						'condition' => array(
							'skin' => 'custom',
						),
					)
				);

				$this->add_control(
					'link_abg_color1',
					array(
						'type'      => Controls_Manager::COLOR,
						'label'     => __( 'Active Background Color', 'porto-functionality' ),
						'selectors' => array(
							'.elementor-element-{{ID}} .nav-pills > li.active > a, .elementor-element-{{ID}} .nav-pills > li:hover > a' => 'background-color: {{VALUE}};',
						),
						'condition' => array(
							'skin' => 'custom',
						),
					)
				);

				$this->add_control(
					'link_aborder_color1',
					array(
						'type'      => Controls_Manager::COLOR,
						'label'     => __( 'Active Border Color', 'porto-functionality' ),
						'selectors' => array(
							'.elementor-element-{{ID}} .nav-pills.nav > li.active a, .elementor-element-{{ID}} .nav-pills.nav > li:hover a' => 'border-bottom-color: {{VALUE}};',
						),
						'condition' => array(
							'link_border_width[size]!' => '',
						),
					)
				);

			$this->end_controls_tab();

		$this->end_controls_tabs();

		$this->end_controls_section();
	}

	protected function render() {
		$atts = $this->get_settings_for_display();
		if ( $template = porto_shortcode_template( 'porto_sticky_nav' ) ) {
			include $template;
		}
	}

	protected function content_template() {
		?>
		<#
		view.addRenderAttribute( 'wrapper', 'class', 'porto-sticky-nav nav-secondary' );
		view.addRenderAttribute( 'wrapper', 'data-plugin-options', "{'minWidth': " + Number( settings.min_width ) + "}" );
		view.addRenderAttribute( 'nav', 'class', 'nav nav-pills' );
		if ( 'custom' != settings.skin ) {
			view.addRenderAttribute( 'nav', 'class', 'nav-pills-' + settings.skin );
		}
		#>
		<div class="sticky-nav-wrapper">
			<div {{{ view.getRenderAttributeString( 'wrapper' ) }}}>
			<# if ( settings.container ) { #>
				<div class="container">
			<# } #>
				<ul {{{ view.getRenderAttributeString( 'nav' ) }}}>
				<#
				_.each( settings.sticky_nav_item_list, function( item, index ) {
					if ( item.show_icon ) {
						if ( 'image' == item.icon_type ) {
							view.addRenderAttribute( 'nav-link', 'class', 'icon-image' );
						} else {
							view.addRenderAttribute( 'nav-link', 'class', item.icon_cl.value );
						}
					}
				#><li class="elementor-repeater-item-{{ item._id }}">
					<a href="#"><# if ( item.show_icon ) { #><i {{{ view.getRenderAttributeString( 'nav-link' ) }}}><# if ( 'image' == item.icon_type && item.icon_image.url ) { #><img class="img-icon" src="{{ item.icon_image.url }}" /><# } #></i><# } #>{{{ item.label }}}</a>
					</li><#
				} );
				#>
				</ul>
			<# if ( settings.container ) { #>
				</div>
			<# } #>
			</div>
		</div>
		<?php
	}
}