/home/arranoyd/mice/wp-content/plugins/auxin-elements/includes/elementor/widgets/before-after.php
<?php
namespace Auxin\Plugin\CoreElements\Elementor\Elements;

use Elementor\Plugin;
use Elementor\Widget_Base;
use Elementor\Controls_Manager;
use Elementor\Group_Control_Image_Size;


if ( ! defined( 'ABSPATH' ) ) {
  exit; // Exit if accessed directly.
}

/**
 * Elementor 'BeforeAfter' widget.
 *
 * Elementor widget that displays an 'BeforeAfter' with lightbox.
 *
 * @since 1.0.0
 */
class BeforeAfter extends Widget_Base {

    /**
     * Get widget name.
     *
     * Retrieve 'BeforeAfter' widget name.
     *
     * @since 1.0.0
     * @access public
     *
     * @return string Widget name.
     */
    public function get_name() {
        return 'aux-before-after';
    }

    /**
     * Get widget title.
     *
     * Retrieve 'BeforeAfter' widget title.
     *
     * @since 1.0.0
     * @access public
     *
     * @return string Widget title.
     */
    public function get_title() {
        return __( 'Before After Slider', 'auxin-elements' );
    }

    /**
     * Get widget icon.
     *
     * Retrieve 'BeforeAfter' widget icon.
     *
     * @since 1.0.0
     * @access public
     *
     * @return string Widget icon.
     */
    public function get_icon() {
        return 'eicon-image-before-after auxin-badge';
    }

    /**
     * Get widget categories.
     *
     * Retrieve 'BeforeAfter' widget icon.
     *
     * @since 1.0.0
     * @access public
     *
     * @return string Widget icon.
     */
    public function get_categories() {
        return array( 'auxin-core' );
    }

    /**
     * Register 'BeforeAfter' 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() {

        /*-----------------------------------------------------------------------------------*/
        /*  images_section
        /*-----------------------------------------------------------------------------------*/

        $this->start_controls_section(
            'images_section',
            array(
                'label' => __( 'Images', 'auxin-elements' ),
            )
        );

        $this->add_control(
            'before_image',
            array(
                'label'      => __('Before image','auxin-elements' ),
                'type'       => Controls_Manager::MEDIA,
                'show_label' => false
            )
        );

        $this->add_group_control(
            Group_Control_Image_Size::get_type(),
            array(
                'name'       => 'before', // Usage: `{name}_size` and `{name}_custom_dimension`, in this case `thumbnail_size` and `thumbnail_custom_dimension`.
                'exclude'    => array( 'custom' ),
                'separator'  => 'none',
                'default'    => 'large',
            )
        );

        $this->add_control(
            'after_image',
            array(
                'label'      => __('After image','auxin-elements' ),
                'type'       => Controls_Manager::MEDIA,
                'show_label' => false
            )
        );

        $this->add_group_control(
            Group_Control_Image_Size::get_type(),
            array(
                'name'       => 'after', // Usage: `{name}_size` and `{name}_custom_dimension`, in this case `thumbnail_size` and `thumbnail_custom_dimension`.
                'exclude'    => array( 'custom' ),
                'separator'  => 'none',
                'default'    => 'large',
            )
        );

        $this->end_controls_section();

        /*-----------------------------------------------------------------------------------*/
        /*  style_section
        /*-----------------------------------------------------------------------------------*/

        $this->start_controls_section(
            'style_section',
            array(
                'label' => __( 'Style', 'auxin-elements' ),
                'tab'   => Controls_Manager::TAB_STYLE
            )
        );

        $this->add_control(
            'default_offset',
            array(
                'label'       => __( 'Start offset','auxin-elements' ),
                'description' => __( 'How much of the before image is visible when the page loads.', 'auxin-elements' ),
                'type'        => Controls_Manager::SLIDER,
                'size_units'  => array('px'),
                'default'     => array(
                    'size' => 50
                ),
                'range'       => array(
                    'px' => array(
                        'min'  => 1,
                        'max'  => 100,
                        'step' => 1
                    )
                )
            )
        );

        $this->add_control(
            'width',
            array(
                'label'      => __('Width','auxin-elements' ),
                'type'       => Controls_Manager::SLIDER,
                'size_units' => array('px'),
                'range'      => array(
                    'px' => array(
                        'min'  => 1,
                        'max'  => 1400,
                        'step' => 1,
                    )
                ),
                'selectors'  => array(
                    '{{WRAPPER}} .aux-before-after' => 'max-width: {{SIZE}}{{UNIT}};',
                ),
            )
        );

        $this->add_control(
            'height',
            array(
                'label'      => __('Height','auxin-elements' ),
                'type'       => Controls_Manager::SLIDER,
                'size_units' => array('px'),
                'range'      => array(
                    'px' => array(
                        'min'  => 1,
                        'max'  => 1400,
                        'step' => 1,
                    )
                ),
                'selectors'  => array(
                    '{{WRAPPER}} .aux-before-after' => 'max-height: {{SIZE}}{{UNIT}};',
                ),
            )
        );

        $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();
    $before_image = '';
    $after_image  = '';

    if( ! empty( $settings['before_image'] ) ) {
        $before_image = Group_Control_Image_Size::get_attachment_image_html( $settings, 'before', 'before_image' );
    }

    if( ! empty( $settings['after_image'] ) ) {
        $after_image = Group_Control_Image_Size::get_attachment_image_html( $settings, 'after', 'after_image' );
    }

    $this->add_render_attribute(
        'wrapper',
        [
            'class'       => [ 'aux-before-after' ],
            'data-offset' => ( (int) $settings['default_offset']['size'] ) / 100
        ]
    );

    if ( Plugin::instance()->editor->is_edit_mode() ) {
        $this->add_render_attribute( 'wrapper', [
            'class' => 'elementor-clickable',
        ] );
    }

    if( ! empty( $settings['after_image'] ) ) {
        echo sprintf( '<div class="widget-container aux-widget-before-after"><div %s >%s %s</div></div>',
                        $this->get_render_attribute_string( 'wrapper' ),
                        wp_kses_post( $before_image ), 
                        wp_kses_post( $after_image ) 
                    ) ;
    } else {
        echo sprintf( '<div class="widget-container aux-widget-before-after"><div %s >%s</div></div>',
                        $this->get_render_attribute_string( 'wrapper' ),
                        wp_kses_post( $before_image ) 
                    );
    }

  }

  /**
   * Render image box 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() {
    ?>
    <#

    var images = '';

    if ( settings.before_image ) {
        var before_image = {
            id: settings.before_image.id,
            url: settings.before_image.url,
            size: settings.before_size,
            dimension: settings.before_custom_dimension,
            model: view.getEditModel()
        };
        var before_image_url = elementor.imagesManager.getImageUrl( before_image );
        images += '<img src="' + before_image_url + '" />';
    }

    if ( settings.after_image ) {
        var after_image = {
            id: settings.after_image.id,
            url: settings.after_image.url,
            size: settings.after_size,
            dimension: settings.after_custom_dimension,
            model: view.getEditModel()
        };
        var after_image_url = elementor.imagesManager.getImageUrl( after_image );
        images += '<img src="' + after_image_url + '" />';
    }

    view.addRenderAttribute(
        'wrapper',
        {
            'class'      : [ 'aux-before-after' ],
            'data-offset': Number( settings.default_offset.size )/100
        }
    );

    #>
    <div class="widget-container aux-widget-before-after">
        <div {{{  view.getRenderAttributeString( 'wrapper' ) }}}>
            {{{ images }}}
        <div>
    </div>
    <?php
  }

}