File: /python/moda/public_html/tech/old/theme/wp-content/plugins/whmpress/widgets/description.php
<?php
/**
* Created by PhpStorm.
* User: zain
* Date: 6/13/2019
* Time: 8:17 PM
*/
namespace ElementorWhmpress\Widgets;
use Elementor\Widget_Base;
use Elementor\Controls_Manager;
Use Elementor\Controls_Stack;
if (!defined('ABSPATH')) exit; // Exit if accessed directly
/**
* Elementor Hello World
*
* Elementor widget for hello world.
*
* @since 1.0.0
*/
class Description extends Widget_Base
{
/**
* Retrieve the widget name.
*
* @since 1.0.0
*
* @access public
*
* @return string Widget name.
*/
public function get_name()
{
return 'description';
}
/**
* Retrieve the widget title.
*
* @since 1.0.0
*
* @access public
*
* @return string Widget title.
*/
public function get_title()
{
return __('Whmpress Description', 'whmpress');
}
/**
* Retrieve the widget icon.
*
* @since 1.0.0
*
* @access public
*
* @return string Widget icon.
*/
public function get_icon()
{
return 'eicon-posts-ticker';
}
/**
* Retrieve the list of categories the widget belongs to.
*
* Used to determine where to display the widget in the editor.
*
* Note that currently Elementor supports only one category.
* When multiple categories passed, Elementor uses the first one.
*
* @since 1.0.0
*
* @access public
*
* @return array Widget categories.
*/
public function get_categories()
{
return ['WHMpress'];
}
/**
* Retrieve the list of scripts the widget depended on.
*
* Used to set scripts dependencies required to run the widget.
*
* @since 1.0.0
*
* @access public
*
* @return array Widget scripts dependencies.
*/
public function get_script_depends()
{
return ['whmpress'];
}
/**
* Register the widget controls.
*
* Adds different input fields to allow the user to change and customize the widget settings.
*
* @since 1.0.0
*
* @access protected
*/
protected function register_controls()
{
$WHMPress = new \WHMPress;
$Products = whmp_get_products(true);
$Products = array_reverse($Products, true);
$Products = array_reverse($Products, true);
$this->start_controls_section(
'general',
[
'label' => __('General', 'whmpress'),
]
);
$this->add_control(
'product_id',
[
'label' => __('Select Product/Service Package', 'whmpress'),
'type' => \Elementor\Controls_Manager::SELECT,
'default' => '',
'options' => array_flip($Products),
]
);
$this->add_control(
'show_as',
[
'label' => __('Show As', 'whmpress'),
'type' => \Elementor\Controls_Manager::SELECT,
'default' => __('ul', 'whmpress'),
'options' => [
'' => __('Default', 'whmpress'),
'ul' => __('Unordered List', 'whmpress'),
'ol' => __('Ordered List', 'whmpress'),
's' => __('Simple', 'whmpress'),
],
]
);
$this->add_control(
'html_id',
[
'label' => __('HTML ID', 'whmpress'),
'type' => \Elementor\Controls_Manager::TEXT,
]
);
$this->add_control(
'html_class',
[
'label' => __('HTML class', 'whmpress'),
'type' => \Elementor\Controls_Manager::TEXT,
]
);
$this->end_controls_section();
}
/**
* Render the widget output on the frontend.
*
* Written in PHP and used to generate the final HTML.
*
* @since 1.0.0
*
* @access protected
*/
protected function render()
{
$settings = $this->get_settings_for_display();
echo '<div class="whmpress_domain_search">';
$id = $settings['product_id'];
$show_as = $settings['show_as'];
$html_id = $settings['html_id'];
$html_class = $settings['html_class'];
echo do_shortcode('[whmpress_description id="' . $id . '" show_as="' . $show_as . '"
html_id="' . $html_id . '" html_class="' . $html_class . '" ]');
echo '</div>';
}
/**
* Render the widget output in the editor.
*
* Written as a Backbone JavaScript template and used to generate the live preview.
*
* @since 1.0.0
*
* @access protected
*/
protected function content_template()
{
?>
<div class="title">
WHMPress Product Description
</div>
<?php
}
}