File: /python/moda/public_html/tech/old/theme/wp-content/plugins/whmpress/widgets/bundle-pricing.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 Bundle_Pricing extends Widget_Base
{
/**
* Retrieve the widget name.
*
* @since 1.0.0
*
* @access public
*
* @return string Widget name.
*/
public function get_name()
{
return 'bundle-pricing';
}
/**
* Retrieve the widget title.
*
* @since 1.0.0
*
* @access public
*
* @return string Widget title.
*/
public function get_title()
{
return __('Whmpress Bundle Pricing', '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);
$Files = $WHMPress->get_template_files("whmpress_bundle_pricing_table");
$FilesList = $ImagesList = [];
$FilesList["Default"] = "";
$ImagesList["Default"] = "";
$YesNo["Default"] = "";
$YesNo["Yes"] = "yes";
$YesNo["No"] = "no";
if (get_option("load_sytle_orders") == "author" || get_option("load_sytle_orders") == "whmpress") {
if (isset($Files["html"]) && is_array($Files["html"])) {
foreach ($Files["html"] as $name => $filename) {
$FilesList["Template: " . $name] = $filename;
}
}
} else {
$AllTemplateFiles = $WHMPress->get_all_template_files("whmpress_bundle_pricing_table");
foreach ($AllTemplateFiles as $FILE) {
$FilesList[$FILE['description']] = $FILE['file_path'];
}
}
$this->start_controls_section(
'general',
[
'label' => __('General', 'whmpress'),
]
);
$this->add_control(
'html_template',
[
'label' => __('Select template file', 'whmpress'),
'type' => \Elementor\Controls_Manager::SELECT,
'default' => '',
'options' => array_flip($FilesList),
]
);
$this->add_control(
'product_id',
[
'label' => __('Bundle ID', 'whmpress'),
'type' => \Elementor\Controls_Manager::TEXT,
'default' => __('', 'whmpress'),
'placeholder' => __('', 'whmpress'),
]
);
$this->add_control(
'itemdata',
[
'label' => __('Item Data', 'whmpress'),
'type' => \Elementor\Controls_Manager::SELECT,
'default' => '',
'options' => array_flip($YesNo),
]
);
$this->add_control(
'button_text',
[
'label' => __('Button Text', 'whmpress'),
'type' => \Elementor\Controls_Manager::TEXT,
'default' => __('Buy Now', 'whmpress'),
'placeholder' => __('', 'whmpress'),
]
);
$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">';
$html_template = $settings['html_template'];
$id = $settings['product_id'];
$itemdata = $settings['itemdata'];
$button_text = $settings['button_text'];
echo do_shortcode('[whmpress_bundle_pricing_table html_template="' . $html_template . '"
id="' . $id . '" itemdata="' . $itemdata . '" button_text="' . $button_text . '" ]');
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 Bundle Price
</div>
<?php
}
}