<?php namespace BdevsElementor\Widget; use Elementor\Controls_Manager; use Elementor\Group_Control_Typography; use Elementor\Scheme_Typography; use Elementor\Group_Control_Border; use Elementor\Group_Control_Box_Shadow; /** * Bdevs Elementor Widget. * * Elementor widget that inserts an embbedable content into the page, from any given URL. * * @since 1.0.0 */ class BdevsBannerSingle extends \Elementor\Widget_Base { /** * Get widget name. * * Retrieve Bdevs Elementor widget name. * * @since 1.0.0 * @access public * * @return string Widget name. */ public function get_name() { return 'bdevs-banner-single'; } /** * Get widget title. * * Retrieve Bdevs Elementor widget title. * * @since 1.0.0 * @access public * * @return string Widget title. */ public function get_title() { return __( 'Banner Single', 'bdevs-elementor' ); } /** * Get widget icon. * * Retrieve Bdevs Slider widget icon. * * @since 1.0.0 * @access public * * @return string Widget icon. */ public function get_icon() { return 'eicon-slideshow'; } /** * Get widget categories. * * Retrieve the list of categories the Bdevs Slider widget belongs to. * * @since 1.0.0 * @access public * * @return array Widget categories. */ public function get_categories() { return [ 'single-elementor' ]; } public function get_keywords() { return [ 'Banner Single', 'carousel' ]; } public function get_script_depends() { return [ 'bdevs-elementor']; } // BDT Position protected function element_pack_position() { $position_options = [ '' => esc_html__('Default', 'bdevs-elementor'), 'top-left' => esc_html__('Top Left', 'bdevs-elementor') , 'top-center' => esc_html__('Top Center', 'bdevs-elementor') , 'top-right' => esc_html__('Top Right', 'bdevs-elementor') , 'center' => esc_html__('Center', 'bdevs-elementor') , 'center-left' => esc_html__('Center Left', 'bdevs-elementor') , 'center-right' => esc_html__('Center Right', 'bdevs-elementor') , 'bottom-left' => esc_html__('Bottom Left', 'bdevs-elementor') , 'bottom-center' => esc_html__('Bottom Center', 'bdevs-elementor') , 'bottom-right' => esc_html__('Bottom Right', 'bdevs-elementor') , ]; return $position_options; } protected function _register_controls() { $this->start_controls_section( 'section_content_banner', [ 'label' => esc_html__( 'Banner Single', 'bdevs-elementor' ), ] ); $this->add_control( 'image', [ 'label' => esc_html__( 'Background Image', 'bdevs-elementor' ), 'type' => Controls_Manager::MEDIA, 'dynamic' => [ 'active' => true ], 'label_block' => true, 'description' => esc_html__( 'Upload Background Image', 'bdevs-elementor' ), ] ); $this->add_control( 'heading', [ 'label' => __( 'Heading', 'bdevs-elementor' ), 'type' => Controls_Manager::TEXT, 'placeholder' => __( 'Enter your heading', 'bdevs-elementor' ), 'default' => __( 'Title', 'bdevs-elementor' ), 'label_block' => true, ] ); $this->add_control( 'home', [ 'label' => __( 'Home', 'bdevs-elementor' ), 'type' => Controls_Manager::TEXT, 'placeholder' => __( 'Enter Home', 'bdevs-elementor' ), 'default' => __( 'Home', 'bdevs-elementor' ), 'label_block' => true, ] ); $this->add_control( 'link_home', [ 'label' => __( 'Link Home', 'bdevs-elementor' ), 'type' => Controls_Manager::TEXT, 'placeholder' => __( 'Enter Home', 'bdevs-elementor' ), 'default' => __( '#', 'bdevs-elementor' ), 'label_block' => true, ] ); $this->add_control( 'subheading', [ 'label' => __( 'Subheading', 'bdevs-elementor' ), 'type' => Controls_Manager::TEXT, 'placeholder' => __( 'Enter Subheading', 'bdevs-elementor' ), 'default' => __( '', 'bdevs-elementor' ), 'label_block' => true, ] ); $this->add_control( 'link_subheading', [ 'label' => __( 'Link Subheading', 'bdevs-elementor' ), 'type' => Controls_Manager::TEXT, 'placeholder' => __( 'Enter Subheading', 'bdevs-elementor' ), 'default' => __( '#', 'bdevs-elementor' ), 'label_block' => true, ] ); $this->end_controls_section(); $this->start_controls_section( 'section_content_layout', [ 'label' => esc_html__( 'Layout', 'bdevs-elementor' ), ] ); $this->add_responsive_control( 'align', [ 'label' => esc_html__( 'Alignment', 'bdevs-elementor' ), 'type' => Controls_Manager::CHOOSE, 'options' => [ 'left' => [ 'title' => esc_html__( 'Left', 'bdevs-elementor' ), 'icon' => 'fa fa-align-left', ], 'center' => [ 'title' => esc_html__( 'Center', 'bdevs-elementor' ), 'icon' => 'fa fa-align-center', ], 'right' => [ 'title' => esc_html__( 'Right', 'bdevs-elementor' ), 'icon' => 'fa fa-align-right', ], 'justify' => [ 'title' => esc_html__( 'Justified', 'bdevs-elementor' ), 'icon' => 'fa fa-align-justify', ], ], 'prefix_class' => 'elementor%s-align-', 'description' => 'Use align to match position', 'default' => 'left', ] ); $this->end_controls_section(); } public function render() { $settings = $this->get_settings_for_display(); extract($settings); ?> <section class="banner-header section-padding bg-img bg-fixed" data-overlay-dark="5" data-background="<?php print esc_url($settings['image']['url']); ?>"> <div class="v-middle"> <div class="container"> <div class="row"> <div class="col-md-12 text-center mt-60"> <?php if ( '' !== $settings['heading'] ) : ?> <h1><?php echo wp_kses_post($settings['heading']); ?></h1> <?php endif; ?> <ul class="breadcrumbs"> <li><a href="<?php echo wp_kses_post($settings['link_home']); ?>"><?php echo wp_kses_post($settings['home']); ?></a></li> <li><a href="<?php echo wp_kses_post($settings['link_subheading']); ?>"><?php echo wp_kses_post($settings['subheading']); ?></a></li> <?php if ( '' !== $settings['heading'] ) : ?> <li><?php echo wp_kses_post($settings['heading']); ?></li> <?php endif; ?> </ul> </div> </div> </div> </div> </section> <div class="line-vr-section"></div> <?php if (is_admin()) { ?> <script type="text/javascript"> var pageSection = $(".bg-img, section"); pageSection.each(function (indx) { if ($(this).attr("data-background")) { $(this).css("background-image", "url(" + $(this).data("background") + ")"); } }); </script> <?php } ?> <?php } }