File "parallax_group.php"
Full path: /home/webide/saman-clinic.ir/wp-content/plugins/codevz-plus/elementor/widgets/parallax_group.php
File size: 6.88 KB
MIME-type: text/x-php
Charset: utf-8
<?php if ( ! defined( 'ABSPATH' ) ) {exit;} // Exit if accessed directly.
use Elementor\Utils;
use Elementor\Repeater;
use Elementor\Widget_Base;
use Elementor\Controls_Manager;
use Elementor\Group_Control_Image_Size;
class Xtra_Elementor_Widget_parallax_group extends Widget_Base {
protected $id = 'cz_parallax_group';
public function get_name() {
return $this->id;
}
public function get_title() {
return esc_html__( 'Parallax Layers', 'codevz' );
}
public function get_icon() {
return 'xtra-parallax-group';
}
public function get_categories() {
return [ 'xtra' ];
}
public function get_keywords() {
return [
esc_html__( 'XTRA', 'codevz' ),
esc_html__( 'Parallax', 'codevz' ),
esc_html__( 'Layers', 'codevz' ),
esc_html__( 'Group', 'codevz' ),
];
}
public function get_style_depends() {
return [ $this->id, 'cz_parallax' ];
}
public function get_script_depends() {
return [ $this->id, 'cz_parallax' ];
}
public function register_controls() {
$this->start_controls_section(
'section_content',
[
'label' => esc_html__( 'Settings', 'codevz' ),
'tab' => Controls_Manager::TAB_CONTENT
]
);
$repeater = new Repeater();
$repeater->add_control(
'image',
[
'label' => esc_html__( 'Image', 'codevz' ),
'type' => Controls_Manager::MEDIA,
]
);
$repeater->add_group_control(
Group_Control_Image_Size::get_type(),
[
'name' => 'image',
'default' => 'full',
'separator' => 'none'
]
);
$repeater->add_responsive_control(
'width',
[
'label' => esc_html__( 'Width', 'codevz' ),
'type' => Controls_Manager::SLIDER,
'size_units' => [ 'px', '%' ],
'range' => [
'px' => [
'min' => 1,
'max' => 1000,
'step' => 1,
],
'%' => [
'min' => 1,
'max' => 100,
'step' => 1,
],
],
'selectors' => [
'{{WRAPPER}} {{CURRENT_ITEM}} > div' => 'width: {{SIZE}}{{UNIT}};',
],
]
);
$repeater->add_responsive_control(
'height',
[
'label' => esc_html__( 'Height', 'codevz' ),
'type' => Controls_Manager::SLIDER,
'size_units' => [ 'px', '%' ],
'range' => [
'px' => [
'min' => 1,
'max' => 1000,
'step' => 1,
],
'%' => [
'min' => 1,
'max' => 100,
'step' => 1,
],
],
'selectors' => [
'{{WRAPPER}} {{CURRENT_ITEM}} > div' => 'height: {{SIZE}}{{UNIT}};',
],
]
);
$repeater->add_responsive_control(
'position_top',
[
'label' => esc_html__( 'Position top', 'codevz' ),
'type' => Controls_Manager::SLIDER,
'size_units' => [ 'px', '%' ],
'range' => [
'px' => [
'min' => -300,
'max' => 300,
'step' => 1,
],
'%' => [
'min' => -100,
'max' => 200,
'step' => 1,
],
],
'selectors' => [
'{{WRAPPER}} {{CURRENT_ITEM}}' => 'top: {{SIZE}}{{UNIT}};',
],
]
);
$repeater->add_responsive_control(
'position_left',
[
'label' => esc_html__( 'Position left', 'codevz' ),
'type' => Controls_Manager::SLIDER,
'size_units' => [ 'px', '%' ],
'range' => [
'px' => [
'min' => -300,
'max' => 300,
'step' => 1,
],
'%' => [
'min' => -100,
'max' => 200,
'step' => 1,
],
],
'selectors' => [
'{{WRAPPER}} {{CURRENT_ITEM}}' => 'left: {{SIZE}}{{UNIT}};',
],
]
);
$repeater->add_responsive_control(
'position_right',
[
'label' => esc_html__( 'Position right', 'codevz' ),
'type' => Controls_Manager::SLIDER,
'size_units' => [ 'px', '%' ],
'range' => [
'px' => [
'min' => -300,
'max' => 300,
'step' => 1,
],
'%' => [
'min' => -100,
'max' => 200,
'step' => 1,
],
],
'selectors' => [
'{{WRAPPER}} {{CURRENT_ITEM}}' => 'right: {{SIZE}}{{UNIT}};',
],
]
);
$repeater->add_responsive_control(
'position_bottom',
[
'label' => esc_html__( 'Position bottom', 'codevz' ),
'type' => Controls_Manager::SLIDER,
'size_units' => [ 'px', '%' ],
'range' => [
'px' => [
'min' => -300,
'max' => 300,
'step' => 1,
],
'%' => [
'min' => -100,
'max' => 200,
'step' => 1,
],
],
'selectors' => [
'{{WRAPPER}} {{CURRENT_ITEM}}' => 'bottom: {{SIZE}}{{UNIT}};',
],
]
);
$repeater->add_responsive_control(
'sk_item',
[
'label' => esc_html__( 'Styling', 'codevz' ),
'type' => 'stylekit',
'settings' => [ 'background', 'border', 'box-shadow' ],
'selectors' => Xtra_Elementor::sk_selectors( '{{CURRENT_ITEM}} > div' ),
]
);
$repeater->add_control(
'title', [
'label' => esc_html__( 'Hide on mobile?', 'codevz' ),
'type' => Controls_Manager::SWITCHER
]
);
Xtra_Elementor::parallax_settings( $repeater, true );
$this->add_control(
'items',
[
'label' => esc_html__( 'Item(s)', 'codevz' ),
'type' => Controls_Manager::REPEATER,
'fields' => $repeater->get_controls()
]
);
$this->add_responsive_control(
'position_bottom',
[
'label' => esc_html__( 'Container height', 'codevz' ),
'type' => Controls_Manager::SLIDER,
'size_units' => [ 'px' ],
'range' => [
'px' => [
'min' => 100,
'max' => 1000,
'step' => 1,
],
],
'selectors' => [
'{{WRAPPER}} .cz_group_parallax' => 'height: {{SIZE}}{{UNIT}};',
],
]
);
$this->end_controls_section();
$this->start_controls_section(
'section_style',
[
'label' => esc_html__( 'Style', 'codevz' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->add_responsive_control(
'sk_con',
[
'label' => esc_html__( 'Container', 'codevz' ),
'type' => 'stylekit',
'settings' => [ 'background', 'border', 'box-shadow' ],
'selectors' => Xtra_Elementor::sk_selectors( '.cz_group_parallax' ),
]
);
$this->end_controls_section();
}
public function render() {
// Settings.
$settings = $this->get_settings_for_display();
ob_start();
foreach ( $settings[ 'items' ] as $i ) {
$image = Group_Control_Image_Size::get_attachment_image_html( $i );
$class = empty( $i['hide_on_mobile'] ) ? '' : ' hide_on_mobile';
Xtra_Elementor::parallax( $i );
echo '<div class="elementor-repeater-item-' . esc_attr( $i[ '_id' ] ) . ' cz_layer_parallax' . $class . '"><div>' . $image . '</div></div>';
Xtra_Elementor::parallax( $i, true );
}
$layers = ob_get_clean();
echo '<div class="cz_group_parallax">' . $layers . '</div>';
}
}