File "SliderWidget.php"
Full path: C:/Inetpub/vhosts/drshti.com/httpdocs/wp-content/plugins/depicter/app/src/Modules/Elementor/SliderWidget.php
File
size: 4.2 B (4.2 KB bytes)
MIME-type: text/x-php
Charset: utf-8
Download Open Edit Advanced Editor &nnbsp; Back
<?php
namespace Depicter\Modules\Elementor;
use Elementor\Plugin;
use Depicter\Document\CSS\Selector;
use Elementor\Controls_Manager;
use Elementor\Widget_Base;
if ( ! defined( 'ABSPATH' ) ) {
exit; // Exit if accessed directly.
}
/**
* Elementor 'Slider' widget.
*
* Elementor widget that displays an 'Slider' with lightbox.
*
* @since 1.0.0
*/
class SliderWidget extends Widget_Base {
/**
* Get widget name.
*
* Retrieve 'Slider' widget name.
*
* @since 1.0.0
* @access public
*
* @return string Widget name.
*/
public function get_name() {
return 'depicter_slider';
}
/**
* Get widget title.
*
* Retrieve 'Slider' widget title.
*
* @since 1.0.0
* @access public
*
* @return string Widget title.
*/
public function get_title() {
return __('Depicter Slider', 'depicter' );
}
/**
* Get widget icon.
*
* Retrieve Slider widget icon.
*
* @since 1.0.0
* @access public
*
* @return string Widget icon.
*/
public function get_icon() {
return 'eicon-post-slider depicter-badge';
}
/**
* Get widget categories.
*
* @since 1.0.0
* @access public
*
* @return string Widget icon.
*/
public function get_categories() {
return ['basic'];
}
/**
* load dependent styles
*
* @return array
*/
public function get_style_depends() {
$styles = \Depicter::front()->assets()->enqueueStyles();
return array_keys( $styles );
}
/**
* load dependent scripts
*
* @return array
*/
public function get_script_depends() {
$scripts = \Depicter::front()->assets()->enqueueScripts();
return array_keys( $scripts );
}
public function getSlidersList() {
$list = [
'0' => __( 'Select Slider', 'depicter' )
];
$documents = \Depicter::documentRepository()->select( ['id', 'name'] )->orderBy('modified_at', 'DESC')->findAll()->get();
$documents = $documents ? $documents->toArray() : [];
foreach( $documents as $document ) {
$list[ "#" . $document['id'] ] = "[#{$document['id']}]: " . $document['name'];
}
return $list;
}
/**
* Register 'Slider' 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() {
/*-----------------------------------------------------------------------------------*/
/* slider_section
/*-----------------------------------------------------------------------------------*/
$this->start_controls_section(
'slider_section',
array(
'label' => __('Slider', 'depicter' ),
)
);
$this->add_control(
'slider_id',
[
'label' => __('Select a Depicter slider','depicter' ),
'type' => Controls_Manager::SELECT,
'label_block' => 'true',
'options' => $this->getSlidersList(),
'default' => '0'
]
);
$documents = \Depicter::documentRepository()->select( ['id', 'name', 'status'] )->orderBy('modified_at', 'DESC')->findAll()->get();
$documents = $documents ? $documents->toArray() : [];
foreach( $documents as $key => $document ) {
$args = [
'isPublishedBefore' => \Depicter::documentRepository()->isPublishedBefore( $document['id'] ),
'documentStatus' => $document['status'],
'documentID' => $document['id']
];
$markup = \Depicter::view('admin/notices/builders-draft-notice')->with('view_args', $args)->toString();
if ( current_user_can( 'access_depicter' ) ) {
$this->add_control(
'slider_control_buttons_' . $key,
[
'type' => Controls_Manager::RAW_HTML,
'raw' => $markup,
'condition' => [
'slider_id' => '#' . $document['id']
]
]
);
}
}
$this->end_controls_section();
}
/**
* Render image box 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();
if ( $settings['slider_id'] ) {
echo \Depicter::front()->render()->document( ltrim( $settings['slider_id'], '#' ) );
} else {
echo esc_html__('Please select a Depicter slider','depicter' );
}
}
}