File: //home/xfp2mtarcm67/www/wp-content/plugins/addons-for-elementor/includes/widgets/heading.php
<?php
/*
Widget Name: Heading
Description: Display headings in multiple styles.
Author: LiveMesh
Author URI: https://www.livemeshthemes.com
*/
namespace LivemeshAddons\Widgets;
use Elementor\Widget_Base;
use Elementor\Controls_Manager;
use Elementor\Scheme_Color;
use Elementor\Group_Control_Typography;
use Elementor\Scheme_Typography;
if ( !defined( 'ABSPATH' ) ) {
exit;
}
// Exit if accessed directly
/**
* Class for Heading widget that displays headings in multiple styles.
*/
class LAE_Heading_Widget extends LAE_Widget_Base {
/**
* Get the name for the widget
* @return string
*/
public function get_name() {
return 'lae-heading';
}
/**
* Get the widget title
* @return string|void
*/
public function get_title() {
return __( 'Heading', 'livemesh-el-addons' );
}
/**
* Get the widget icon
* @return string
*/
public function get_icon() {
return 'lae-icon-heading';
}
/**
* Retrieve the list of categories the widget belongs to.
*
* Used to determine where to display the widget in the editor.
*
* @return string[]
*/
public function get_categories() {
return array('livemesh-addons');
}
/**
* Get the widget documentation URL
* @return string
*/
public function get_custom_help_url() {
return 'https://livemeshelementor.com/docs/livemesh-addons/core-addons/heading-addon/';
}
/**
* Obtain the scripts required for the widget to function
* @return string[]
*/
public function get_script_depends() {
return ['lae-waypoints', 'lae-frontend-scripts'];
}
/**
* Register the controls for the widget
* Adds fields that help configure and customize the widget
* @return void
*/
protected function register_controls() {
$this->start_controls_section( 'section_heading', [
'label' => __( 'Heading', 'livemesh-el-addons' ),
] );
$this->add_control( 'style', [
'type' => Controls_Manager::SELECT,
'label' => __( 'Choose Style', 'livemesh-el-addons' ),
'default' => 'style1',
'options' => [
'style1' => __( 'Style 1', 'livemesh-el-addons' ),
'style2' => __( 'Style 2', 'livemesh-el-addons' ),
'style3' => __( 'Style 3', 'livemesh-el-addons' ),
],
] );
$this->add_control( 'heading', [
'type' => Controls_Manager::TEXT,
'label' => __( 'Heading Title', 'livemesh-el-addons' ),
'label_block' => true,
'separator' => 'before',
'default' => __( 'Heading Title', 'livemesh-el-addons' ),
'dynamic' => [
'active' => true,
],
] );
$this->add_control( 'subtitle', [
'type' => Controls_Manager::TEXT,
'label' => __( 'Subheading', 'livemesh-el-addons' ),
'label_block' => true,
'description' => __( 'A subtitle displayed above the title heading.', 'livemesh-el-addons' ),
'condition' => [
'style' => 'style2',
],
'dynamic' => [
'active' => true,
],
] );
$this->add_control( 'short_text', [
'type' => 'textarea',
'label' => __( 'Short Text', 'livemesh-el-addons' ),
'description' => __( 'Short text generally displayed below the heading title.', 'livemesh-el-addons' ),
'condition' => [
'style' => ['style1', 'style2'],
],
'dynamic' => [
'active' => true,
],
] );
$this->add_control( 'heading_settings', [
'label' => __( 'Settings', 'livemesh-el-addons' ),
'type' => Controls_Manager::HEADING,
'separator' => 'before',
] );
$this->add_control( 'align', [
'label' => __( 'Alignment', 'livemesh-el-addons' ),
'type' => Controls_Manager::CHOOSE,
'options' => [
'left' => [
'title' => __( 'Left', 'livemesh-el-addons' ),
'icon' => 'fa fa-align-left',
],
'center' => [
'title' => __( 'Center', 'livemesh-el-addons' ),
'icon' => 'fa fa-align-center',
],
'right' => [
'title' => __( 'Right', 'livemesh-el-addons' ),
'icon' => 'fa fa-align-right',
],
'justify' => [
'title' => __( 'Justified', 'livemesh-el-addons' ),
'icon' => 'fa fa-align-justify',
],
],
'default' => 'center',
] );
$this->add_control( 'widget_animation', [
"type" => Controls_Manager::SELECT,
"label" => __( "Animation Type", "livemesh-el-addons" ),
'options' => lae_get_animation_options(),
'default' => 'none',
] );
$this->add_control( 'upgrade_notice', [
'type' => Controls_Manager::RAW_HTML,
'separator' => 'before',
'raw' => '<div style="text-align:center;line-height:1.6;"><p>' . __( 'Unlock new possibilities with premium widgets and styles of <strong>Livemesh Addons for Elementor <i>Premium</i></strong>. ', 'livemesh-el-addons' ) . '</p><p style="padding-top:15px;"><a class="elementor-button elementor-button-default elementor-button-go-pro" href="https://livemeshelementor.com/pricing/#pricing-plans" target="_blank"><i class="fa fa-hand-o-right" aria-hidden="true"></i>' . __( 'Go Pro', 'livemesh-el-addons' ) . '</a></p></div>',
] );
$this->end_controls_section();
$this->start_controls_section( 'section_widget_theme', [
'label' => __( 'Widget Theme', 'livemesh-el-addons' ),
'tab' => Controls_Manager::TAB_STYLE,
'show_label' => false,
] );
$this->add_control( 'toggle_dark_mode', [
'label' => __( 'Dark Mode', 'elementor-pro' ),
'description' => __( 'Enable dark mode when this widget is placed in those pages or sections/rows within a page that have a dark color (such as black) set as background color. ', 'livemesh-el-addons' ),
'type' => Controls_Manager::SWITCHER,
'return_value' => 'dark-bg',
'prefix_class' => 'lae-',
] );
$this->end_controls_section();
$this->start_controls_section( 'section_styling', [
'label' => __( 'Title', 'livemesh-el-addons' ),
'tab' => Controls_Manager::TAB_STYLE,
] );
$this->add_control( 'title_tag', [
'label' => __( 'Title HTML Tag', 'livemesh-el-addons' ),
'type' => Controls_Manager::SELECT,
'options' => [
'h1' => __( 'H1', 'livemesh-el-addons' ),
'h2' => __( 'H2', 'livemesh-el-addons' ),
'h3' => __( 'H3', 'livemesh-el-addons' ),
'h4' => __( 'H4', 'livemesh-el-addons' ),
'h5' => __( 'H5', 'livemesh-el-addons' ),
'h6' => __( 'H6', 'livemesh-el-addons' ),
'div' => __( 'div', 'livemesh-el-addons' ),
],
'default' => 'h3',
] );
$this->add_control( 'heading_color', [
'label' => __( 'Heading Color', 'livemesh-el-addons' ),
'type' => Controls_Manager::COLOR,
'default' => '',
'selectors' => [
'{{WRAPPER}} .lae-heading .lae-title' => 'color: {{VALUE}};',
],
] );
$this->add_group_control( Group_Control_Typography::get_type(), [
'name' => 'heading_typography',
'label' => __( 'Typography', 'livemesh-el-addons' ),
'selector' => '{{WRAPPER}} .lae-heading .lae-title',
] );
$this->end_controls_section();
$this->start_controls_section( 'section_subtitle', [
'label' => __( 'Subtitle', 'livemesh-el-addons' ),
'tab' => Controls_Manager::TAB_STYLE,
] );
$this->add_control( 'subtitle_color', [
'label' => __( 'Color', 'livemesh-el-addons' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .lae-heading .lae-subtitle' => 'color: {{VALUE}};',
],
] );
$this->add_group_control( Group_Control_Typography::get_type(), [
'name' => 'subtitle_typography',
'selector' => '{{WRAPPER}} .lae-heading .lae-subtitle',
] );
$this->end_controls_section();
$this->start_controls_section( 'section_short_text', [
'label' => __( 'Short Text', 'livemesh-el-addons' ),
'tab' => Controls_Manager::TAB_STYLE,
] );
$this->add_control( 'text_color', [
'label' => __( 'Color', 'livemesh-el-addons' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .lae-heading .lae-text' => 'color: {{VALUE}};',
],
] );
$this->add_group_control( Group_Control_Typography::get_type(), [
'name' => 'text_typography',
'selector' => '{{WRAPPER}} .lae-heading .lae-text',
] );
$this->end_controls_section();
}
/**
* Render HTML widget output on the frontend.
*
* Written in PHP and used to generate the final HTML.
*
* @return void
*/
protected function render() {
$settings = $this->get_settings_for_display();
$settings = apply_filters( 'lae_heading_' . $this->get_id() . '_settings', $settings );
$args['settings'] = $settings;
$args['widget_instance'] = $this;
$widget_template = esc_attr( $settings['style'] );
lae_get_template_part( "addons/heading/{$widget_template}", $args );
}
/**
* Render the widget output in the editor.
* @return void
*/
protected function content_template() {
}
}