File: /home/smilepac/public_html/wp-content/plugins/codevz-plus/elementor/widgets/360_degree.php
<?php if ( ! defined( 'ABSPATH' ) ) {exit;} // Exit if accessed directly.
use Elementor\Widget_Base;
use Elementor\Controls_Manager;
use Elementor\Group_Control_Image_Size;
class Xtra_Elementor_Widget_360_degree extends Widget_Base {
protected $id = 'cz_360_degree';
public function get_name() {
return $this->id;
}
public function get_title() {
return esc_html__( '360 Degree', 'codevz-plus' );
}
public function get_icon() {
return 'xtra-360-degree';
}
public function get_categories() {
return [ 'xtra' ];
}
public function get_keywords() {
return [
esc_html__( 'XTRA', 'codevz-plus' ),
esc_html__( 'Codevz Plus', 'codevz-plus' ),
esc_html__( '360 Degree', 'codevz-plus' ),
'XTRA',
'Codevz Plus',
'360 Degree',
'Image',
'Panorama',
'Spin',
'Product View',
];
}
public function get_style_depends() {
return [ $this->id, 'cz_parallax' ];
}
public function get_script_depends() {
return [ $this->id, 'cz_parallax' ];
}
public function register_controls() {
$free = Codevz_Plus::is_free();
$this->start_controls_section(
'360_degree',
[
'label' => esc_html__( 'Settings', 'codevz-plus' ),
]
);
$this->add_control(
'image',
[
'label' => esc_html__( 'Placeholder (loading image)', 'codevz-plus' ),
'type' => Controls_Manager::MEDIA,
'default' => [
'url' => 'https://xtratheme.com/img/360.jpg',
],
]
);
$this->add_control(
'stripe_image',
[
'label' => esc_html__( 'Stripe image', 'codevz-plus' ),
'type' => Controls_Manager::MEDIA,
'default' => [
'url' => 'https://xtratheme.com/img/360s.jpg',
],
]
);
$this->add_control(
'count',
[
'label' => esc_html__( 'Frames count', 'codevz-plus' ),
'type' => Controls_Manager::NUMBER,
'min' => 1,
'step' => 1,
'max' => 40,
'default' => 8,
]
);
$this->add_control(
'action',
[
'label' => esc_html__( 'Rotate by', 'codevz-plus' ),
'type' => $free ? 'codevz_pro' : Controls_Manager::SELECT,
'default' => 'drag',
'options' => [
'drag' => esc_html__( 'Mouse Dragging', 'codevz-plus' ),
'hover' => esc_html__( 'Mouse Hover', 'codevz-plus' ),
],
]
);
$this->add_control(
'handle',
[
'label' => esc_html__( 'Show handle', 'codevz-plus' ),
'type' => $free ? 'codevz_pro' : Controls_Manager::SWITCHER
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_style',
[
'label' => esc_html__( 'Style', 'codevz-plus' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_responsive_control(
'sk_con',
[
'label' => esc_html__( 'Container', 'codevz-plus' ),
'type' => $free ? 'stylekit_pro' : 'stylekit',
'settings' => [ 'background', 'border' ],
'selectors' => Xtra_Elementor::sk_selectors( '.cz_product-viewer-wrapper .product-viewer' ),
]
);
$this->add_responsive_control(
'sk_handle',
[
'label' => esc_html__( 'Handle', 'codevz-plus' ),
'type' => $free ? 'stylekit_pro' : 'stylekit',
'settings' => [ 'color', 'background' ],
'selectors' => Xtra_Elementor::sk_selectors( '.cz_product-viewer-wrapper .handle' ),
]
);
$this->add_responsive_control(
'sk_bar',
[
'label' => esc_html__( 'Bar', 'codevz-plus' ),
'type' => $free ? 'stylekit_pro' : 'stylekit',
'settings' => [ 'background', 'border' ],
'selectors' => Xtra_Elementor::sk_selectors( '.cz_product-viewer-wrapper .cz_product-viewer-handle' ),
]
);
$this->end_controls_section();
}
public function render() {
// Settings.
$settings = $this->get_settings_for_display();
$imgsrc = '';
// Images
if ( ! empty( $settings[ 'stripe_image' ][ 'url' ] ) ) {
$imgsrc = $settings[ 'stripe_image' ][ 'url' ];
}
$plc_imgsrc = Group_Control_Image_Size::get_attachment_image_html( $settings );
// Count
$count = $settings['count'] ? $settings['count'] : 16;
// Classes
$classes = [];
$classes[] = 'cz_product-viewer-wrapper';
ob_start();
?>
<div data-frame="<?php echo esc_attr( $count ); ?>" data-friction="0.33" data-action="<?php echo esc_attr( $settings['action'] ); ?>"<?php echo wp_kses_post( (string) Codevz_Plus::classes( [], $classes ) ); ?>>
<div>
<figure class="product-viewer">
<?php echo wp_kses_post( (string) $plc_imgsrc ); ?>
<div class="product-sprite" data-image="<?php echo esc_url( $imgsrc ); ?>" style="width: <?php echo esc_attr( $count ) * 100; ?>%;background-image:url(<?php echo esc_url( $imgsrc ); ?>)"></div>
</figure>
<?php if ( $settings['handle'] == true ) { ?>
<div class="cz_product-viewer-handle"><span class="fill"></span><span class="handle"><i class="fa fa-arrows-h"></i></span></div>
<?php } ?>
</div>
</div>
<?php
$content = ob_get_clean();
Codevz_Plus::tpl( 'page_builder', $content );
}
}