Current File : /home/mdkeenpw/www/wp-content/plugins/logistik-core/addons/widgets/logistik-team.php |
<?php
use \Elementor\Widget_Base;
use \Elementor\Controls_Manager;
use \Elementor\Group_Control_Typography;
use \Elementor\Utils;
use \Elementor\Group_Control_Image_Size;
use \Elementor\Group_Control_Box_Shadow;
use \Elementor\Group_Control_Border;
use \Elementor\Repeater;
/**
*
* Team Widget .
*
*/
class logistik_Team extends Widget_Base {
public function get_name() {
return 'logistikteam';
}
public function get_title() {
return __( 'Team', 'logistik' );
}
public function get_icon() {
return 'themeholy-icon';
}
public function get_categories() {
return [ 'logistik' ];
}
protected function register_controls() {
$this->start_controls_section(
'team_section',
[
'label' => __( 'Team Content', 'logistik' ),
'tab' => Controls_Manager::TAB_CONTENT,
]
);
$this->add_control(
'layout_style',
[
'label' => __( 'Layout Style', 'logistik' ),
'type' => Controls_Manager::SELECT,
'default' => '1',
'options' => [
'1' => __( 'Style One', 'logistik' ),
'2' => __( 'Style Two', 'logistik' ),
],
]
);
$this->add_control(
'make_it_slider',
[
'label' => __( 'Make It Slider?', 'logistik' ),
'type' => Controls_Manager::SWITCHER,
'label_on' => __( 'Yes', 'logistik' ),
'label_off' => __( 'No', 'logistik' ),
'return_value' => 'yes',
'default' => 'yes',
// 'condition' => [
// 'layout_style' => ['1', '2', '4', '5']
// ]
]
);
$this->add_control(
'team_shape', [
'label' => esc_html__( 'Shape Image', 'logistik' ),
'type' => Controls_Manager::MEDIA,
'default' => [
'url' => Utils::get_placeholder_image_src(),
],
'condition' => [
'layout_style' => ['1']
]
]
);
$repeater = new Repeater();
$repeater->add_control(
'name', [
'label' => __( 'Name', 'logistik' ),
'type' => Controls_Manager::TEXTAREA,
'default' => __( 'Lilar Dikeoa' , 'logistik' ),
'rows' => 2,
'label_block' => true,
]
);
$repeater->add_control(
'profile_link',
[
'label' => esc_html__( 'Profile Link', 'logistik' ),
'type' => Controls_Manager::URL,
'placeholder' => esc_html__( 'https://your-link.com', 'logistik' ),
'show_external' => true,
'default' => [
'url' => '#',
'is_external' => false,
'nofollow' => false,
],
]
);
$repeater->add_control(
'designation', [
'label' => __( 'Designation', 'logistik' ),
'type' => Controls_Manager::TEXT,
'default' => __( 'Customer' , 'logistik' ),
'label_block' => true,
]
);
$repeater->add_control(
'team_image',
[
'label' => esc_html__( 'Member Image', 'logistik' ),
'type' => Controls_Manager::MEDIA,
'default' => [
'url' => Utils::get_placeholder_image_src(),
],
]
);
$repeater->add_control(
'fb_link',
[
'label' => esc_html__( 'Facebook Link', 'logistik' ),
'type' => Controls_Manager::URL,
'placeholder' => esc_html__( 'https://your-link.com', 'logistik' ),
'show_external' => true,
'default' => [
'url' => '#',
'is_external' => false,
'nofollow' => false,
],
]
);
$repeater->add_control(
'twitter_link',
[
'label' => esc_html__( 'Twitter Link', 'logistik' ),
'type' => Controls_Manager::URL,
'placeholder' => esc_html__( 'https://your-link.com', 'logistik' ),
'show_external' => true,
'default' => [
'url' => '#',
'is_external' => false,
'nofollow' => false,
],
]
);
$repeater->add_control(
'instagram_link',
[
'label' => esc_html__( 'Instagram Link', 'logistik' ),
'type' => Controls_Manager::URL,
'placeholder' => esc_html__( 'https://your-link.com', 'logistik' ),
'show_external' => true,
'default' => [
'url' => '#',
'is_external' => false,
'nofollow' => false,
],
]
);
$repeater->add_control(
'linkedin_link',
[
'label' => esc_html__( 'Linkedin Link', 'logistik' ),
'type' => Controls_Manager::URL,
'placeholder' => esc_html__( 'https://your-link.com', 'logistik' ),
'show_external' => true,
]
);
$this->add_control(
'team_lists',
[
'label' => __( 'Member Lists', 'logistik' ),
'type' => Controls_Manager::REPEATER,
'fields' => $repeater->get_controls(),
'default' => [
[
'name' => __( 'Mishel D. Marsh', 'logistik' ),
],
[
'name' => __( 'Famhida Ruko Jon', 'logistik' ),
],
],
'title_field' => '{{{ name }}}',
]
);
$this->end_controls_section();
//---------------------------------------
//Style Section Start
//---------------------------------------
/*-----------------------------------------Team styling------------------------------------*/
$this->start_controls_section(
'overview_con_styling',
[
'label' => __( 'Team Styling', 'logistik' ),
'tab' => Controls_Manager::TAB_STYLE,
]
);
$this->start_controls_tabs(
'style_tabs2'
);
$this->start_controls_tab(
'style_normal_tab2',
[
'label' => esc_html__( 'Name', 'logistik' ),
]
);
$this->add_control(
'overview_title_color',
[
'label' => __( 'Color', 'logistik' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .th-title a' => 'color: {{VALUE}}!important;',
],
]
);
$this->add_control(
'overview_title_color2',
[
'label' => __( 'Hover Color', 'logistik' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .team-card:hover .th-title a' => 'color: {{VALUE}}!important;',
],
'condition' => [
'layout_style' => ['1']
]
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'overview_title_typography',
'label' => __( 'Typography', 'logistik' ),
'selector' => '{{WRAPPER}} .th-title a',
]
);
$this->add_responsive_control(
'overview_title_margin',
[
'label' => __( 'Margin', 'logistik' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%', 'em' ],
'selectors' => [
'{{WRAPPER}} .th-title a' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->add_responsive_control(
'overview_title_padding',
[
'label' => __( 'Padding', 'logistik' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%', 'em' ],
'selectors' => [
'{{WRAPPER}} .th-title a' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->end_controls_tab();
//--------------------secound--------------------//
$this->start_controls_tab(
'style_hover_tab2',
[
'label' => esc_html__( 'Designation', 'logistik' ),
]
);
$this->add_control(
'overview_content_color',
[
'label' => __( 'Color', 'logistik' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .team-desig' => 'color: {{VALUE}}!important;',
],
]
);
$this->add_control(
'overview_content_color2',
[
'label' => __( 'Hover Color', 'logistik' ),
'type' => Controls_Manager::COLOR,
'selectors' => [
'{{WRAPPER}} .team-card:hover .team-desig' => 'color: {{VALUE}}!important;',
],
'condition' => [
'layout_style' => ['1']
]
]
);
$this->add_group_control(
Group_Control_Typography::get_type(),
[
'name' => 'overview_content_typography',
'label' => __( 'Typography', 'logistik' ),
'selector' => '{{WRAPPER}} .team-desig',
]
);
$this->add_responsive_control(
'overview_content_margin',
[
'label' => __( 'Margin', 'logistik' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%', 'em' ],
'selectors' => [
'{{WRAPPER}} .team-desig' => 'margin: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->add_responsive_control(
'overview_content_padding',
[
'label' => __( 'Padding', 'logistik' ),
'type' => Controls_Manager::DIMENSIONS,
'size_units' => [ 'px', '%', 'em' ],
'selectors' => [
'{{WRAPPER}} .team-desig' => 'padding: {{TOP}}{{UNIT}} {{RIGHT}}{{UNIT}} {{BOTTOM}}{{UNIT}} {{LEFT}}{{UNIT}};',
],
]
);
$this->end_controls_tab();
$this->end_controls_tabs();
$this->end_controls_section();
}
protected function render() {
$settings = $this->get_settings_for_display();
if($settings['make_it_slider'] == 'yes'){
if( $settings['layout_style'] == '2' ){
$this->add_render_attribute( 'wrapper', 'class', 'row slider-shadow themeholy-carousel arrow-wrap' );
}else{
$this->add_render_attribute( 'wrapper', 'class', 'row slider-shadow themeholy-carousel arrow-wrap' );
}
}else{
$this->add_render_attribute( 'wrapper', 'class', 'row gy-4 ' );
}
?>
<?php if( $settings['layout_style'] == '2' ): ?>
<?php if( $settings['make_it_slider'] == 'yes' ): ?>
<div <?php echo $this->get_render_attribute_string('wrapper'); ?> id="teamSlide1" data-slide-show="4" data-lg-slide-show="3" data-md-slide-show="2" data-sm-slide-show="2" data-xs-slide-show="1" data-arrows="true">
<?php else: ?>
<div <?php echo $this->get_render_attribute_string('wrapper'); ?> >
<?php endif; ?>
<?php foreach( $settings['team_lists'] as $data ):
$target = $data['profile_link']['is_external'] ? ' target="_blank"' : '';
$nofollow = $data['profile_link']['nofollow'] ? ' rel="nofollow"' : '';
$f_target = $data['fb_link']['is_external'] ? ' target="_blank"' : '';
$f_nofollow = $data['fb_link']['nofollow'] ? ' rel="nofollow"' : '';
$t_target = $data['twitter_link']['is_external'] ? ' target="_blank"' : '';
$t_nofollow = $data['twitter_link']['nofollow'] ? ' rel="nofollow"' : '';
$i_target = $data['instagram_link']['is_external'] ? ' target="_blank"' : '';
$i_nofollow = $data['instagram_link']['nofollow'] ? ' rel="nofollow"' : '';
$l_target = $data['linkedin_link']['is_external'] ? ' target="_blank"' : '';
$l_nofollow = $data['linkedin_link']['nofollow'] ? ' rel="nofollow"' : '';
?>
<div class="col-md-6 col-lg-4 col-xl-4 col-xxl-3">
<div class="themeholy-team team-box">
<div class="team-img">
<?php echo logistik_img_tag( array(
'url' => esc_url( $data['team_image']['url'] ),
)); ?>
<div class="themeholy-social">
<?php if( ! empty( $data['fb_link']['url']) ): ?>
<a <?php echo wp_kses_post( $f_nofollow.$f_target ); ?> href="<?php echo esc_url( $data['fb_link']['url'] ); ?>"><i class="fab fa-facebook-f"></i></a>
<?php endif; ?>
<?php if( ! empty( $data['twitter_link']['url']) ): ?>
<a <?php echo wp_kses_post( $t_nofollow.$t_target ); ?> href="<?php echo esc_url( $data['twitter_link']['url'] ); ?>"><i class="fab fa-twitter"></i></a>
<?php endif; ?>
<?php if( ! empty( $data['instagram_link']['url']) ): ?>
<a <?php echo wp_kses_post( $i_nofollow.$i_target ); ?> href="<?php echo esc_url( $data['instagram_link']['url'] ); ?>"><i class="fab fa-instagram"></i></a>
<?php endif; ?>
<?php if( ! empty( $data['linkedin_link']['url']) ): ?>
<a <?php echo wp_kses_post( $l_nofollow.$l_target ); ?> href="<?php echo esc_url( $data['linkedin_link']['url'] ); ?>"><i class="fab fa-linkedin-in"></i></a>
<?php endif; ?>
</div>
</div>
<div class="team-content">
<div class="plus-btn"> <i class="fa-solid fa-plus"></i></div>
<div class="media-body">
<h3 class="box-title th-title"><a <?php echo wp_kses_post( $nofollow.$target ); ?> href="<?php echo esc_url( $data['profile_link']['url'] ); ?>"><?php echo esc_html($data['name']); ?></a></h3>
<span class="team-desig"><?php echo esc_html($data['designation']); ?></span>
</div>
</div>
</div>
</div>
<?php endforeach; ?>
</div>
<?php else: ?>
<div <?php echo $this->get_render_attribute_string('wrapper'); ?> data-slide-show="4" data-lg-slide-show="3" data-md-slide-show="2" data-sm-slide-show="2" data-xs-slide-show="1" data-arrows="true">
<?php foreach( $settings['team_lists'] as $data ):
$target = $data['profile_link']['is_external'] ? ' target="_blank"' : '';
$nofollow = $data['profile_link']['nofollow'] ? ' rel="nofollow"' : '';
$f_target = $data['fb_link']['is_external'] ? ' target="_blank"' : '';
$f_nofollow = $data['fb_link']['nofollow'] ? ' rel="nofollow"' : '';
$t_target = $data['twitter_link']['is_external'] ? ' target="_blank"' : '';
$t_nofollow = $data['twitter_link']['nofollow'] ? ' rel="nofollow"' : '';
$i_target = $data['instagram_link']['is_external'] ? ' target="_blank"' : '';
$i_nofollow = $data['instagram_link']['nofollow'] ? ' rel="nofollow"' : '';
$l_target = $data['linkedin_link']['is_external'] ? ' target="_blank"' : '';
$l_nofollow = $data['linkedin_link']['nofollow'] ? ' rel="nofollow"' : '';
?>
<div class="col-sm-6 col-lg-4 col-xxl-3">
<div class="themeholy-team team-card">
<div class="team-img">
<?php echo logistik_img_tag( array(
'url' => esc_url( $data['team_image']['url'] ),
)); ?>
</div>
<div class="team-card-content" data-bg-src="<?php echo esc_url($settings['team_shape']['url']); ?>">
<div class="team-social">
<div class="icon-btn"><i class="fa-light fa-plus"></i></div>
<div class="themeholy-social">
<?php if( ! empty( $data['fb_link']['url']) ): ?>
<a <?php echo wp_kses_post( $f_nofollow.$f_target ); ?> href="<?php echo esc_url( $data['fb_link']['url'] ); ?>"><i class="fab fa-facebook-f"></i></a>
<?php endif; ?>
<?php if( ! empty( $data['twitter_link']['url']) ): ?>
<a <?php echo wp_kses_post( $t_nofollow.$t_target ); ?> href="<?php echo esc_url( $data['twitter_link']['url'] ); ?>"><i class="fab fa-twitter"></i></a>
<?php endif; ?>
<?php if( ! empty( $data['instagram_link']['url']) ): ?>
<a <?php echo wp_kses_post( $i_nofollow.$i_target ); ?> href="<?php echo esc_url( $data['instagram_link']['url'] ); ?>"><i class="fab fa-instagram"></i></a>
<?php endif; ?>
<?php if( ! empty( $data['linkedin_link']['url']) ): ?>
<a <?php echo wp_kses_post( $l_nofollow.$l_target ); ?> href="<?php echo esc_url( $data['linkedin_link']['url'] ); ?>"><i class="fab fa-linkedin-in"></i></a>
<?php endif; ?>
</div>
</div>
<div class="team-content">
<h3 class="team-title box-title th-title"><a <?php echo wp_kses_post( $nofollow.$target ); ?> href="<?php echo esc_url( $data['profile_link']['url'] ); ?>"><?php echo esc_html($data['name']); ?></a></h3>
<span class="team-desig"><?php echo esc_html($data['designation']); ?></span>
</div>
</div>
</div>
</div>
<?php endforeach; ?>
</div>
<?php endif;
}
}