Spade

Mini Shell

Directory:~$ /home/lmsyaran/public_html/j3/components/com_sppagebuilder/addons/testimonial_carousel/
Upload File

[Home] [System Details] [Kill Me]
Current File:~$ /home/lmsyaran/public_html/j3/components/com_sppagebuilder/addons/testimonial_carousel/site.php

<?php

/**
 * @package SP Page Builder
 * @author JoomShaper http://www.joomshaper.com
 * @copyright Copyright (c) 2010 - 2023 JoomShaper
 * @license http://www.gnu.org/licenses/gpl-2.0.html GNU/GPLv2 or later
 */
//no direct access
defined('_JEXEC') or die('Restricted access');

use Joomla\CMS\Uri\Uri;

class SppagebuilderAddonTestimonial_carousel extends SppagebuilderAddons
{

    public function render()
    {
        $settings = $this->addon->settings;

        $class = (isset($settings->class) &&
$settings->class) ? ' ' . $settings->class : '';
        $testimonial_carousel_layout =
(isset($settings->testimonial_carousel_layout) &&
$settings->testimonial_carousel_layout) ?
$settings->testimonial_carousel_layout : '';
        $carousel_autoplay = (isset($settings->carousel_autoplay)
&& $settings->carousel_autoplay) ?
$settings->carousel_autoplay : 0;
        $carousel_speed = (isset($settings->carousel_speed) &&
$settings->carousel_speed) ? $settings->carousel_speed : 1500;
        $carousel_interval = (isset($settings->carousel_interval)
&& $settings->carousel_interval) ?
$settings->carousel_interval : 4500;
        $carousel_margin = (isset($settings->carousel_margin) &&
$settings->carousel_margin) ? $settings->carousel_margin : 0;
        $carousel_item_number_xl =
(isset($settings->carousel_item_number_original->xl) &&
$settings->carousel_item_number_original->xl) ?
$settings->carousel_item_number_original->xl : 3;
        $carousel_item_number_lg =
(isset($settings->carousel_item_number_original->lg) &&
$settings->carousel_item_number_original->lg) ?
$settings->carousel_item_number_original->lg : 3;
        $carousel_item_number_md =
(isset($settings->carousel_item_number_original->md) &&
$settings->carousel_item_number_original->md) ?
$settings->carousel_item_number_original->md : 3;
        $carousel_item_number_sm =
(isset($settings->carousel_item_number_original->sm) &&
$settings->carousel_item_number_original->sm) ?
$settings->carousel_item_number_original->sm : 3;
        $carousel_item_number_xs =
(isset($settings->carousel_item_number_original->xs) &&
$settings->carousel_item_number_original->xs) ?
$settings->carousel_item_number_original->xs : 1;
        $carousel_bullet = (isset($settings->carousel_bullet) &&
$settings->carousel_bullet) ? $settings->carousel_bullet : 0;

        //Arrow style
        $carousel_arrow = (isset($settings->carousel_arrow) &&
$settings->carousel_arrow) ? $settings->carousel_arrow : 0;
        $arrow_icon = (isset($settings->arrow_icon) &&
$settings->arrow_icon) ? $settings->arrow_icon : 'angle';
        $left_arrow = '';
        $right_arrow = '';
        if ($arrow_icon == 'long_arrow')
        {
            $left_arrow = 'fa-long-arrow-left';
            $right_arrow = 'fa-long-arrow-right';
        }
        else
        {
            $left_arrow = 'fa-angle-left';
            $right_arrow = 'fa-angle-right';
        }

        //Quote icon
        $quote_icon = '';
        if (isset($settings->show_quote_icon) &&
$settings->show_quote_icon)
        {
            $quote_icon .= '<div
class="sppb-testimonial-carousel-icon">';
            $quote_icon .= '<i class="fa fa-quote-left"
aria-hidden="true"></i>';
            $quote_icon .= '</div>';
        }

        //Output
        $output = '<div class="sppb-addon
sppb-carousel-extended' . $class . '
sppb-testimonial-carousel-' . $testimonial_carousel_layout .
'"
		data-left-arrow="' . $left_arrow . '"
		data-right-arrow="' . $right_arrow . '"
		data-arrow="' . $carousel_arrow . '"
		data-dots="' . $carousel_bullet . '"
		data-testi-layout="' . $testimonial_carousel_layout .
'"
		data-autoplay="' . $carousel_autoplay . '"
		data-speed="' . $carousel_speed . '"
		data-interval="' . $carousel_interval . '"
		data-margin="' . $carousel_margin . '"
		data-item-number-xl="' . $carousel_item_number_xl .
'"
		data-item-number-lg="' . $carousel_item_number_lg .
'"
		data-item-number-md="' . $carousel_item_number_md .
'"
		data-item-number-sm="' . $carousel_item_number_sm .
'"
		data-item-number-xs="' . $carousel_item_number_xs .
'">';

        if (isset($settings->sp_testimonial_carousel_item) &&
is_array($settings->sp_testimonial_carousel_item))
        {
            foreach ($settings->sp_testimonial_carousel_item as
$item_key => $carousel_item)
            {
                $uniqId = 'sppb-testi-' . $this->addon->id
. '-carousel-item-key-' . $item_key;
                $client_details = '';

                $carousel_img =
isset($carousel_item->testimonial_carousel_img) &&
$carousel_item->testimonial_carousel_img ?
$carousel_item->testimonial_carousel_img : '';
                $carousel_img_src = isset($carousel_img->src) ?
$carousel_img->src : $carousel_img;

                $client_details .= '<div
class="sppb-testimonial-carousel-content-wrap">';
                if ($carousel_img_src)
                {
                    $client_details .= '<div
class="sppb-testimonial-carousel-img-wrap">';
                    $client_details .= '<img src="' .
$carousel_img_src . '" alt="' .
(isset($carousel_item->client_name) ? $carousel_item->client_name :
'') . '">';
                    $client_details .= '</div>';
                }

                $client_details .= '<div
class="sppb-testimonial-carousel-name-designation">';
                if (isset($carousel_item->client_name))
                {
                    $client_details .= '<div
class="sppb-testimonial-carousel-name">';
                    $client_details .= $carousel_item->client_name;
                    $client_details .= '</div>';
                }

                if (isset($carousel_item->client_desgination))
                {
                    $client_details .= '<div
class="sppb-testimonial-carousel-designation">';
                    $client_details .=
$carousel_item->client_desgination;
                    $client_details .= '</div>';
                }
                $client_details .= '</div>';
                $client_details .= '</div>';

                $rating = '';
                if (isset($carousel_item->show_rating) &&
$carousel_item->show_rating)
                {
                    $rating .= '<div
class="sppb-testimonial-carousel-client-rating rating-key-' .
$item_key . '"><span
class="sppb-testimonial-carousel-rating"></span></div>';
                }

                $output .= '<div id="' . $uniqId .
'" class="sppb-carousel-extended-item">';
                if ($testimonial_carousel_layout ==
'testi_layout1')
                {
                    $output .= $quote_icon;
                }

                if ($testimonial_carousel_layout ==
'testi_layout2')
                {
                    $output .= $client_details;
                };

                $output .= '<div
class="sppb-testimonial-carousel-item-content">';
                if ($testimonial_carousel_layout ==
'testi_layout2' || $testimonial_carousel_layout ==
'testi_layout3')
                {
                    $output .= $rating;
                };

                if (isset($carousel_item->client_message))
                {
                    $output .= '<div
class="sppb-testimonial-carousel-message">';
                    $output .= $carousel_item->client_message;
                    $output .= '</div>';
                }

                if ($testimonial_carousel_layout ==
'testi_layout1')
                {
                    $output .= $rating;
                };
                $output .= '</div>';
                if ($testimonial_carousel_layout ==
'testi_layout1' || $testimonial_carousel_layout ==
'testi_layout3')
                {
                    $output .= $client_details;
                };

                if ($testimonial_carousel_layout ==
'testi_layout2')
                {
                    $output .= $quote_icon;
                }
                $output .= '</div>';
            }
        }
        $output .= '</div>';

        return $output;
    }

    public function scripts()
    {
        return array(Uri::base(true) .
'/components/com_sppagebuilder/assets/js/sp_carousel.js');
    }

    public function css()
    {
        $settings = $this->addon->settings;
        $addon_id = '#sppb-addon-' . $this->addon->id;
        $cssHelper = new CSSHelper($addon_id);

        $css = '';

        $settings->arrow_border_width =
(isset($settings->arrow_border_width) &&
$settings->arrow_border_width) ? $settings->arrow_border_width : 0;
        $settings->bullet_border_width =
(isset($settings->bullet_border_width) &&
$settings->bullet_border_width) ? $settings->bullet_border_width : 0;

        $testimonial_carousel_layout =
(isset($settings->testimonial_carousel_layout) &&
$settings->testimonial_carousel_layout) ?
$settings->testimonial_carousel_layout : '';
        //Arrow Style
        $carousel_arrow = (isset($settings->carousel_arrow) &&
$settings->carousel_arrow) ? $settings->carousel_arrow : 1;

        $settings->arrow_line_height =
(isset($settings->arrow_height) && $settings->arrow_height) ?
(int) $settings->arrow_height - (int) $settings->arrow_border_width :
null;

        if ($carousel_arrow)
        {
            $carouselArrowProps = [
                'arrow_height' => 'height',
                'arrow_line_height' =>
'line-height',
                'arrow_width' => 'width',
                'arrow_background' => 'background',
                'arrow_color' => 'color',
                'arrow_font_size' => 'font-size',
                'arrow_border_width' => 'border-style:
solid; border-width',
                'arrow_border_color' =>
'border-color',
                'arrow_border_radius' =>
'border-radius',
                'arrow_position_verti' =>
'margin-top',
                'arrow_position_hori' =>
['margin-left', 'margin-right'],
            ];
            $carouselArrowUnits = [
                'arrow_background' => false,
                'arrow_color' => false,
                'arrow_border_color' => false,
                'arrow_position_verti' => '%',
                'arrow_position_hori' => 'px',
            ];

            $carouselArrowHoverProps = [
                'arrow_hover_background' =>
'background',
                'arrow_hover_color' => 'color',
                'arrow_hover_border_color' =>
'border-color',
            ];
            $carouselArrowHoverUnits = [
                'arrow_hover_background' => false,
                'arrow_hover_color' => false,
                'arrow_hover_border_color' => false,
            ];
            $arrowStyle = '';
            $arrowStyle .=
$cssHelper->generateStyle('.sppb-carousel-extended-nav-control
.nav-control', $settings, $carouselArrowProps, $carouselArrowUnits);
            $arrowHoverStyle =
$cssHelper->generateStyle('.sppb-carousel-extended-nav-control
.nav-control:hover', $settings, $carouselArrowHoverProps,
$carouselArrowHoverUnits);

            $css .= $arrowStyle;
            $css .= $arrowHoverStyle;
        }
        //Bullet Style
        $carousel_bullet = (isset($settings->carousel_bullet) &&
$settings->carousel_bullet) ? $settings->carousel_bullet : 1;

        $settings->bullet_line_height =
(isset($settings->bullet_height) && $settings->bullet_height)
? (($settings->bullet_height) - ($settings->bullet_border_width)) :
"";

        if ($carousel_bullet)
        {
            $carouselBulletProps = [
                'bullet_width' => 'width',
                'bullet_background' => 'background',
                'bullet_height' => 'height',
                'bullet_line_height' =>
'line-height',
                'bullet_color' => 'color',
                'bullet_font_size' => 'font-size',
                'bullet_border_width' => 'border-style:
solid; border-width',
                'bullet_border_color' =>
'border-color',
                'bullet_border_radius' =>
'border-radius',
            ];

            $carouselBulletUnits = [
                'bullet_background' => false,
                'bullet_color' => false,
                'bullet_border_color' => false,
            ];

            $carouselBulletHoverProps = [
                'bullet_active_background' =>
'background',
            ];

            $carouselBulletHoverUnits = [
                'bullet_active_background' => false,
            ];

            $bulletStyle = '';
            $bulletStyle .=
$cssHelper->generateStyle('.sppb-carousel-extended-dots ul
li', $settings, $carouselBulletProps, $carouselBulletUnits);
            $bulletStyle .=
$cssHelper->generateStyle('.sppb-carousel-extended-dots',
$settings, ['bullet_position_verti' => 'bottom',
'bullet_position_hori' => 'left'],
['bullet_position_verti' => '%',
'bullet_position_hori' => 'px']);
            $bulletHoverStyle =
$cssHelper->generateStyle('.sppb-carousel-extended-dots ul li:hover
span, .sppb-carousel-extended-dots ul li.active span', $settings,
$carouselBulletHoverProps, $carouselBulletHoverUnits);

            $css .= $bulletStyle;
            $css .= $bulletHoverStyle;
        }

        //Avatar style
        $avatar_layout = (isset($settings->avatar_layout) &&
$settings->avatar_layout) ? $settings->avatar_layout : '';
        $settings->content_alignment =
$cssHelper->parseAlignment($settings, 'content_alignment');
        $settings->content_alignment_wrap =
$cssHelper->parseAlignment($settings, 'content_alignment',
false);
        $margin = '';
        if ($testimonial_carousel_layout !== 'testi_layout3')
        {
            if ($avatar_layout == 'avatar_layout1')
            {
                $margin = 'margin-right';
            }
            elseif ($avatar_layout == 'avatar_layout2')
            {
                $margin = 'margin-left';
            }
            elseif ($avatar_layout == 'avatar_layout3')
            {
                $margin = 'margin-bottom';
            }
            elseif ($avatar_layout == 'avatar_layout4')
            {
                $margin = 'margin-top';
            }
        }

        $avatarStyleProps = [
            'avatar_height' => 'height',
            'avatar_width' => 'width',
            'avatar_gap' => $margin,
        ];

        $avatarStyle =
$cssHelper->generateStyle('.sppb-testimonial-carousel-img-wrap',
$settings, $avatarStyleProps);
        $css .= $avatarStyle;

        if (!empty($settings->content_alignment_wrap) &&
is_object($settings->content_alignment_wrap))
        {
            $css .= $addon_id . ' .sppb-testimonial-carousel-img-wrap
{';
            if ($settings->content_alignment_wrap->xl ==
"left" /*|| $settings->content_alignment_wrap->lg ==
"left" || $settings->content_alignment_wrap->md ==
"left" || $settings->content_alignment_wrap->sm ==
"left" || $settings->content_alignment_wrap->xs ==
"left"*/)
            {
                $css .= 'margin-right: auto;';
            }
            elseif ($settings->content_alignment_wrap->xl ==
"right" && $testimonial_carousel_layout ==
'testi_layout3' && $avatar_layout !=
'avatar_layout1'/*|| $settings->content_alignment_wrap->lg
== "right" || $settings->content_alignment_wrap->md ==
"right" || $settings->content_alignment_wrap->sm ==
"right" || $settings->content_alignment_wrap->xs ==
"right"*/)
            {
                $css .= 'margin-left: auto;';
            }
            elseif ($settings->content_alignment_wrap->xl ==
"center" /*|| $settings->content_alignment_wrap->lg ==
"center" || $settings->content_alignment_wrap->md ==
"center" || $settings->content_alignment_wrap->sm ==
"center" || $settings->content_alignment_wrap->xs ==
"center"*/)
            {
                $css .= 'margin-left: auto;';
                $css .= 'margin-right: auto;';
            }
            $css .= '}';
        }

        $avatarBorderRadiusStyle =
$cssHelper->generateStyle('.sppb-testimonial-carousel-img-wrap
img', $settings, ['avatar_border_radius' =>
'border-radius']);
        $css .= $avatarBorderRadiusStyle;

        if ($testimonial_carousel_layout == 'testi_layout3')
        {
            // $css .=
$cssHelper->generateStyle('.sppb-testimonial-carousel-content-wrap',
$settings, ['content_alignment_wrap' =>
'align-items'], false);
            $css .= $addon_id . '
.sppb-testimonial-carousel-content-wrap {';
            $css .= 'align-items: initial;';
            $css .= 'flex-direction: column;';
            $css .= '}';
        }
        else
        {
            if ($avatar_layout == 'avatar_layout2')
            {
                $css .= $addon_id . '
.sppb-testimonial-carousel-content-wrap {';
                $css .= 'flex-direction: row-reverse;';
                $css .= '}';
                $css .= $addon_id . '
.sppb-testimonial-carousel-name-designation {';
                $css .= 'text-align: right;';
                $css .= '}';
            }
            elseif ($avatar_layout == 'avatar_layout3')
            {
                // $css .=
$cssHelper->generateStyle('.sppb-testimonial-carousel-content-wrap',
$settings, ['content_alignment_wrap' =>
'align-items'], false);
                $css .= $addon_id . '
.sppb-testimonial-carousel-content-wrap {';
                $css .= 'align-items: initial;';
                $css .= 'flex-direction: column;';
                $css .= '}';
            }
            elseif ($avatar_layout == 'avatar_layout4')
            {
                // $css .=
$cssHelper->generateStyle('.sppb-testimonial-carousel-content-wrap',
$settings, ['content_alignment_wrap' =>
'align-items'], false);
                $css .= $addon_id . '
.sppb-testimonial-carousel-content-wrap {';
                $css .= 'align-items: initial;';
                $css .= 'flex-direction: column-reverse;';
                $css .= '}';
            }

            if ($avatar_layout == 'avatar_layout1')
            {
                $css .= $addon_id . '
.sppb-testimonial-carousel-name-designation {';
                $css .= 'text-align: left;';
                $css .= '}';
            }
        }

        //Quote icon style
        if ($testimonial_carousel_layout == 'testi_layout1')
        {
            $margin = 'margin-bottom';
        }
        elseif ($testimonial_carousel_layout == 'testi_layout2')
        {
            $margin = 'margin-top';
        }

        $quoteStyleProps = [
            'quote_icon_size' => 'font-size',
            'quote_icon_color' => 'color',
            'quote_icon_gap' => $margin,
        ];

        $quoteStyleUnits = [
            'quote_icon_color' => false,
        ];

        $quoteStyle =
$cssHelper->generateStyle('.sppb-testimonial-carousel-icon',
$settings, $quoteStyleProps, $quoteStyleUnits);
        $css .= $quoteStyle;

        //Rating style
        $marginRating = '';
        if ($testimonial_carousel_layout == 'testi_layout1' ||
$testimonial_carousel_layout == 'testi_layout3')
        {
            $marginRating = 'margin-bottom';
        }
        elseif ($testimonial_carousel_layout == 'testi_layout2')
        {
            $marginRating = 'margin-top';
        }
        $ratingStyle =
$cssHelper->generateStyle('.sppb-testimonial-carousel-rating',
$settings, ['rating_size' => 'font-size',
'rating_color' => 'color', 'rating_gap'
=> $marginRating], ['rating_color' => false]);

        $css .= $ratingStyle;

        if (isset($settings->sp_testimonial_carousel_item) &&
is_array($settings->sp_testimonial_carousel_item))
        {
            foreach ($settings->sp_testimonial_carousel_item as
$item_key => $carousel_item)
            {
                $uniqId = '#sppb-testi-' . $this->addon->id
. '-carousel-item-key-' . $item_key;
                $css .= $uniqId . '.sppb-carousel-extended-item
.sppb-testimonial-carousel-rating:before {';
                $css .= 'width:' . ((20 *
$carousel_item->client_rating) - 2) . '%';
                $css .= '}';
            }
        }

        //Name style
        $nameTypographyStyle =
$cssHelper->typography('.sppb-testimonial-carousel-name',
$settings, 'name_typography', [
            'font'           => 'name_font_family',
            'size'           => 'name_fontsize',
            'line_height'    => 'name_lineheight',
            'letter_spacing' => 'name_letterspace',
            'uppercase'      =>
'name_font_style.uppercase',
            'italic'         =>
'name_font_style.italic',
            'underline'      =>
'name_font_style.underline',
            'weight'         =>
'name_font_style.weight',
        ]);

        $css .= $nameTypographyStyle;

        $nameStyle =
$cssHelper->generateStyle('.sppb-testimonial-carousel-name',
$settings, ['name_text_color' => 'color',
'name_margin' => 'margin'],
['name_text_color' => false, 'name_margin' =>
false]);
        $css .= $nameStyle;

        //Designation style
        $designationStyle =
$cssHelper->generateStyle('.sppb-testimonial-carousel-designation',
$settings, ['designation_text_color' => 'color'],
false);
        $css .= $designationStyle;

        $designationTypographyStyle =
$cssHelper->typography('.sppb-testimonial-carousel-designation
', $settings, 'title_typography', [
            'font' => 'designation_font_family',
            'size' => 'designation_fontsize',
            'line_height' =>
'designation_lineheight',
            'letter_spacing' =>
'designation_letterspace',
            'uppercase' =>
'designation_font_style.uppercase',
            'italic' =>
'designation_font_style.italic',
            'underline' =>
'designation_font_style.underline',
            'weight' =>
'designation_font_style.weight',
        ]);

        $css .= $designationTypographyStyle;

        //Message style
        $itemContentProps = [
            'message_margin_bottom' =>
($testimonial_carousel_layout == 'testi_layout3') ?
'margin-bottom' : null,
            'message_background' =>
($testimonial_carousel_layout == 'testi_layout3') ?
'background' : null,
            'message_border_radius' =>
($testimonial_carousel_layout == 'testi_layout3') ?
'border-radius' : null,
            'message_padding' => ($testimonial_carousel_layout
== 'testi_layout3') ? 'padding' : null,
        ];

        $css .=
$cssHelper->generateStyle('.sppb-testimonial-carousel-item-content',
$settings, $itemContentProps, ['message_background' => false,
'message_padding' => false], ['message_padding'
=> 'spacing']);

        $messageStyleProps = [
            'message_text_color' => 'color',
            'message_margin_top' => 'margin-top',
            'message_margin_bottom' =>
($testimonial_carousel_layout != 'testi_layout3') ?
'margin-bottom' : null,
        ];

        $messageStyleUnits = [
            'message_text_color' => false,
        ];

        $messageStyle =
$cssHelper->generateStyle('.sppb-testimonial-carousel-message',
$settings, $messageStyleProps, $messageStyleUnits);
        $css .= $messageStyle;

        $messageTypographyFallbacks = [
            'font' => 'message_font_family',
            'size' => 'message_fontsize',
            'line_height' => 'message_lineheight',
            'letter_spacing' =>
'message_letterspace',
            'uppercase' =>
'message_font_style.uppercase',
            'italic' => 'message_font_style.italic',
            'underline' =>
'message_font_style.underline',
            'weight' => 'message_font_style.weight',
        ];

        $messageTypography =
$cssHelper->typography('.sppb-testimonial-carousel-message',
$settings, 'message_typography', $messageTypographyFallbacks);
        $css .= $messageTypography;

        $arrowHeightStyle =
$cssHelper->generateStyle('.sppb-carousel-extended-nav-control',
$settings, ['arrow_height' => 'top: -%s']);
        $css .= $arrowHeightStyle;

        //Item style
        $itemStyle =
$cssHelper->generateStyle('.sppb-carousel-extended-item',
$settings, ['content_alignment' => 'text-align',
'content_background' => 'background',
'content_padding' => 'padding',
'content_border_radius' => 'border-radius'],
['content_background' => false, 'content_padding'
=> false, 'content_alignment' => false],
['content_padding' => 'spacing']);
        $css .= $itemStyle;

        return $css;
    }

    public static function getTemplate()
    {
        $lodash = new Lodash('#sppb-addon-{{ data.id }}');
        $output = '
		<style  type="text/css">';

        $output .= '<# if (data.carousel_arrow) { #>';
        $output .= $lodash->unit('margin-top',
'.sppb-carousel-extended-nav-control .nav-control',
'data.arrow_position_verti', '%');
        $output .= $lodash->unit('margin-left',
'.sppb-carousel-extended-nav-control .nav-control',
'data.arrow_position_hori', 'px');
        $output .= $lodash->unit('margin-right',
'.sppb-carousel-extended-nav-control .nav-control',
'data.arrow_position_hori', 'px');
        $output .= $lodash->unit('font-size',
'.sppb-carousel-extended-nav-control .nav-control',
'data.arrow_font_size', 'px', false);
        $output .= $lodash->unit('border-radius',
'.sppb-carousel-extended-nav-control .nav-control',
'data.arrow_border_radius', 'px', false);
        $output .= $lodash->unit('width',
'.sppb-carousel-extended-nav-control .nav-control',
'data.arrow_width', 'px', false);
        //normal
        $output .= $lodash->border('border-color',
'.sppb-carousel-extended-nav-control .nav-control',
'data.arrow_border_color');
        $output .= $lodash->color('color',
'.sppb-carousel-extended-nav-control .nav-control',
'data.arrow_color');
        $output .= $lodash->color('background-color',
'.sppb-carousel-extended-nav-control .nav-control',
'data.arrow_background');
        // hover
        $output .= $lodash->border('border-color',
'.sppb-carousel-extended-nav-control .nav-control:hover',
'data.arrow_hover_border_color');
        $output .= $lodash->color('color',
'.sppb-carousel-extended-nav-control .nav-control:hover',
'data.arrow_hover_color');
        $output .= $lodash->color('background-color',
'.sppb-carousel-extended-nav-control .nav-control:hover',
'data.arrow_hover_background');
        $output .= '<# if (data.arrow_height) { #>';
        $output .= $lodash->unit('height',
'.sppb-carousel-extended-nav-control .nav-control',
'data.arrow_height', 'px', false);
        $output .= '<# let lineHeight = data.arrow_height -
((data.arrow_border_width != undefined) ? data.arrow_border_width :
0);#>';
        $output .= $lodash->unit('line-height',
'.sppb-carousel-extended-nav-control .nav-control',
'lineHeight', 'px', false);
        $output .= '<# } #>';
        $output .= '<# if (data.arrow_border_width) { #>';
        $output .= $lodash->unit('border-width',
'.sppb-carousel-extended-nav-control .nav-control',
'data.arrow_border_width', 'px', false);
        $output .= '#sppb-addon-{{ data.id }}
.sppb-carousel-extended-nav-control .nav-control { border-style: solid;
}';
        $output .= '<# } #>';
        $output .= $lodash->unit('top',
'.sppb-carousel-extended-nav-control',
'data.arrow_height', 'px', false, '-');
        $output .= '<# } #>';

        // Bullet
        $output .= '<# if (data.carousel_bullet) { #>';
        $output .= $lodash->unit('bottom',
'.sppb-carousel-extended-dots',
'data.bullet_position_verti', '%');
        $output .= $lodash->unit('left',
'.sppb-carousel-extended-dots',
'data.bullet_position_hori', 'px');
        $output .= ' <# if (data.bullet_height) { #>';
        $output .= $lodash->unit('height',
'.sppb-carousel-extended-dots ul li',
'data.bullet_height', 'px', false);
        $output .= $lodash->unit('line-height',
'.sppb-carousel-extended-dots ul li',
'(data.bullet_height)-(data.bullet_border_width)',
'px', false);
        $output .= '<# } #>';
        $output .= ' <# if (data.bullet_height) { #>';
        $output .= $lodash->unit('border-width',
'.sppb-carousel-extended-dots ul li',
'data.bullet_border_width', 'px', false);
        //$output .= '#sppb-addon-{{ data.id }}
.sppb-carousel-extended-dots ul li { border-style: solid; }';
        $output .= '<# } #>';
        $output .= $lodash->unit('border-radius',
'.sppb-carousel-extended-dots ul li',
'data.bullet_border_radius', 'px', false);
        $output .= $lodash->unit('width',
'.sppb-carousel-extended-dots ul li',
'data.bullet_width', 'px', false);
        $output .= $lodash->border('border-color',
'.sppb-carousel-extended-dots ul li',
'data.bullet_border_color');
        $output .= $lodash->color('background-color',
'.sppb-carousel-extended-dots ul li',
'data.bullet_background');
        $output .= $lodash->color('background-color',
'.sppb-carousel-extended-dots ul li:hover span,
.sppb-carousel-extended-dots ul li.active span',
'data.bullet_active_background');
        $output .= '<# } #>';

        $output .= $lodash->unit('border-radius',
'.sppb-testimonial-carousel-item-content',
'data.content_border_radius', 'px');
        $output .= $lodash->unit('height',
'.sppb-testimonial-carousel-img-wrap',
'data.avatar_height', 'px');
        $output .= $lodash->unit('width',
'.sppb-testimonial-carousel-img-wrap',
'data.avatar_width', 'px');
        $output .= $lodash->unit('border-radius',
'.sppb-testimonial-carousel-img-wrap img',
'data.avatar_border_radius', 'px', false);

        $output .= $lodash->unit('font-size',
'.sppb-testimonial-carousel-icon',
'data.quote_icon_size', 'px');
        $output .= $lodash->color('color',
'.sppb-testimonial-carousel-icon',
'data.quote_icon_color');

        $output .= $lodash->unit('font-size',
'.sppb-testimonial-carousel-rating',
'data.rating_size', 'px');
        $output .= $lodash->color('color',
'.sppb-testimonial-carousel-rating',
'data.rating_color');

        $output .= '<# if (data.testimonial_carousel_layout ===
"testi_layout1") { #>';
        $output .= $lodash->unit('margin-bottom',
'.sppb-testimonial-carousel-rating',
'data.quote_icon_gap', 'px');
        $output .= '<# } #>';

        $output .= '<# if (data.testimonial_carousel_layout ===
"testi_layout1" ||  data.testimonial_carousel_layout ===
"testi_layout3") { #>';
        $output .= $lodash->unit('margin-bottom',
'.sppb-testimonial-carousel-icon',
'data.quote_icon_gap', 'px');
        $output .= $lodash->unit('margin-bottom',
'.sppb-testimonial-carousel-rating', 'data.rating_gap',
'px');
        $output .= '<# } #>';
        $output .= '<# if (data.testimonial_carousel_layout ===
"testi_layout2") { #>';
        $output .= $lodash->unit('margin-top',
'.sppb-testimonial-carousel-icon',
'data.quote_icon_gap', 'px');
        $output .= $lodash->unit('margin-top',
'.sppb-testimonial-carousel-rating', 'data.rating_gap',
'px');
        $output .= '<# } #>';

        $output .= '<# if (data.content_alignment ===
"sppb-text-left" || (_.isObject(data.content_alignment)
&& data.content_alignment.xl === "left")) {#>';
        $output .= '#sppb-addon-{{ data.id }}
.sppb-testimonial-carousel-img-wrap { margin-right:auto;}';
        $output .= '<# } else if ((data.testimonial_carousel_layout
!= "testi_layout3" && data.avatar_layout ==
"avatar_layout1" && data.content_alignment ==
"sppb-text-right") || ((_.isObject(data.content_alignment)
&& data.content_alignment.xl == "right") &&
data.testimonial_carousel_layout != "testi_layout3" &&
data.avatar_layout == "avatar_layout1")) {#>';
        $output .= '#sppb-addon-{{ data.id }}
.sppb-testimonial-carousel-img-wrap { margin-left:auto;}';
        $output .= '<# } else if ((data.testimonial_carousel_layout
== "testi_layout3" && data.content_alignment ==
"sppb-text-right") || ((_.isObject(data.content_alignment)
&& data.content_alignment.xl == "right") &&
data.testimonial_carousel_layout == "testi_layout3"))
{#>';
        $output .= '#sppb-addon-{{ data.id }}
.sppb-testimonial-carousel-img-wrap { margin-left:auto;}';
        $output .= '<# } else if (data.content_alignment ==
"sppb-text-center" || (_.isObject(data.content_alignment)
&& data.content_alignment.xl == "center")) {#>';
        $output .= '#sppb-addon-{{ data.id }}
.sppb-testimonial-carousel-img-wrap { margin-left:auto;
margin-right:auto;}';
        $output .= '<# } #>';

        $output .= '<# if (data.testimonial_carousel_layout !=
"testi_layout3") { #>';
        $output .= '<# if (data.avatar_layout ==
"avatar_layout1") { #>';
        $output .= $lodash->unit('margin-right',
'.sppb-testimonial-carousel-img-wrap',
'data.avatar_gap', 'px');
        $output .= '#sppb-addon-{{ data.id }}
.sppb-testimonial-carousel-name-designation { text-align: left; }';
        $output .= '<# } #>';

        $output .= '<# if (data.avatar_layout ==
"avatar_layout2") { #>';
        $output .= $lodash->unit('margin-left',
'.sppb-testimonial-carousel-img-wrap',
'data.avatar_gap', 'px');
        $output .= '#sppb-addon-{{ data.id }}
.sppb-testimonial-carousel-content-wrap { flex-direction: row-reverse;
}';
        $output .= '#sppb-addon-{{ data.id }}
.sppb-testimonial-carousel-name-designation { text-align: right;}';
        $output .= '<# } #>';

        $output .= '<# if (data.avatar_layout ==
"avatar_layout3") { #>';
        $output .= $lodash->unit('margin-bottom',
'.sppb-testimonial-carousel-img-wrap',
'data.avatar_gap', 'px');
        $output .= '#sppb-addon-{{ data.id }}
.sppb-testimonial-carousel-content-wrap { align-items: initial;
flex-direction: column;}';
        $output .= '<# } #>';

        $output .= '<# if (data.avatar_layout ==
"avatar_layout4") { #>';
        $output .= $lodash->unit('margin-top',
'.sppb-testimonial-carousel-img-wrap',
'data.avatar_gap', 'px');
        $output .= '#sppb-addon-{{ data.id }}
.sppb-testimonial-carousel-content-wrap { align-items: initial;
flex-direction: column-reverse;}';
        $output .= '<# } #>';
        $output .= '<# } #>';

        $output .= '<# if (data.testimonial_carousel_layout ==
"testi_layout3") { #>';
        $output .= $lodash->unit('border-radius',
'.sppb-testimonial-carousel-item-content',
'data.message_border_radius', 'px');
        $output .= $lodash->color('background-color',
'.sppb-testimonial-carousel-item-content',
'data.message_background');
        $output .= $lodash->unit('margin-bottom',
'.sppb-testimonial-carousel-item-content',
'data.message_margin_bottom', 'px');
        $output .= $lodash->spacing('padding',
'.sppb-testimonial-carousel-item-content',
'data.message_padding');
        $output .= '#sppb-addon-{{ data.id }}
.sppb-testimonial-carousel-content-wrap { align-items: initial;
flex-direction: column;}';
        $output .= '<# } #>';

        $nameTypographyFallbacks = [
            'font' => 'data.name_font_family',
            'size' => 'data.name_fontsize',
            'line_height' => 'data.name_lineheight',
            'letter_spacing' =>
'data.name_letterspace',
            'uppercase' =>
'data.name_font_style?.uppercase',
            'italic' =>
'data.name_font_style?.italic',
            'underline' =>
'data.name_font_style?.underline',
            'weight' =>
'data.name_font_style?.weight',
        ];

        $output .=
$lodash->typography('.sppb-testimonial-carousel-name',
'data.name_typography', $nameTypographyFallbacks);
        $output .= $lodash->color('color',
'.sppb-testimonial-carousel-name',
'data.name_text_color');
        $output .= $lodash->spacing('margin',
'.sppb-testimonial-carousel-name', 'data.name_margin');

        $messageTypographyFallbacks = [
            'font' => 'data.message_font_family',
            'size' => 'data.message_fontsize',
            'line_height' =>
'data.message_lineheight',
            'letter_spacing' =>
'data.message_letterspace',
            'uppercase' =>
'data.message_font_style?.uppercase',
            'italic' =>
'data.message_font_style?.italic',
            'underline' =>
'data.message_font_style?.underline',
            'weight' =>
'data.message_font_style?.weight',
        ];

        $output .=
$lodash->typography('.sppb-testimonial-carousel-message',
'data.message_typography', $messageTypographyFallbacks);
        $output .= $lodash->color('color',
'.sppb-testimonial-carousel-message',
'data.message_text_color');
        $output .= $lodash->unit('margin-top',
'.sppb-testimonial-carousel-message',
'data.message_margin_top', 'px');
        
        $output .= '<# if (data.testimonial_carousel_layout !==
"testi_layout3") { #>';
        $output .= $lodash->unit('margin-bottom',
'.sppb-testimonial-carousel-message',
'data.message_margin_bottom', 'px');
        $output .= '<# } #>';

        $titleTypographyFallbacks = [
            'font' =>
'data.designation_font_family',
            'size' => 'data.designation_fontsize',
            'line_height' =>
'data.designation_lineheight',
            'letter_spacing' =>
'data.designation_letterspace',
            'uppercase' =>
'data.designation_font_style?.uppercase',
            'italic' =>
'data.designation_font_style?.italic',
            'underline' =>
'data.designation_font_style?.underline',
            'weight' =>
'data.designation_font_style?.weight',
        ];

        $output .=
$lodash->typography('.sppb-testimonial-carousel-designation',
'data.title_typography', $titleTypographyFallbacks);
        $output .= $lodash->color('color',
'.sppb-testimonial-carousel-designation',
'data.designation_text_color');

        $output .= $lodash->color('background-color',
'.sppb-carousel-extended-item',
'data.content_background');
        $output .= $lodash->spacing('padding',
'.sppb-carousel-extended-item',
'data.content_padding');
        $output .= $lodash->alignment('text-align',
'.sppb-carousel-extended-item',
'data.content_alignment');

        $output .= '
			<# if(_.isArray(data.sp_testimonial_carousel_item)){
				_.each(data.sp_testimonial_carousel_item, function(carousel_item,
caro_index){
					const uniqId =
`#sppb-testi-${data.id}-carousel-item-key-${caro_index}`;
			#>
					{{uniqId}}.sppb-carousel-extended-item
.sppb-testimonial-carousel-rating:before {
						width:{{(20 * carousel_item.client_rating)-2}}%;
					}
				<# })
			} #>
		</style>
		<#
		var left_arrow ="";
		var right_arrow = "";
		if(data.arrow_icon=="long_arrow"){
			left_arrow ="fa-long-arrow-left";
			right_arrow = "fa-long-arrow-right";
		} else {
			left_arrow ="fa-angle-left";
			right_arrow = "fa-angle-right";
		}

		let carousel_item_number_xl = 3;
		let carousel_item_number_lg = 3;
		let carousel_item_number_md = 3;
		let carousel_item_number_sm = 2;
		let carousel_item_number_xs = 1;
		if (_.isObject(data.carousel_item_number))
		{
			carousel_item_number_xl = data.carousel_item_number.xl
			carousel_item_number_lg = data.carousel_item_number.lg
			carousel_item_number_md = data.carousel_item_number.md
			carousel_item_number_sm = data.carousel_item_number.sm
			carousel_item_number_xs = data.carousel_item_number.xs
		}

		let quote_icon = "";
		if (data.show_quote_icon)
		{
			quote_icon += `<div
class="sppb-testimonial-carousel-icon">`;
			quote_icon += `<i class="fa fa-quote-left"
aria-hidden="true"></i>`;
			quote_icon += `</div>`;
		}

		#>
			<div class="sppb-addon sppb-carousel-extended {{data.class}}
sppb-testimonial-carousel-{{data.testimonial_carousel_layout}}"
				data-left-arrow="{{left_arrow}}"
				data-right-arrow="{{right_arrow}}"
				data-arrow="{{data.carousel_arrow}}"
				data-dots="{{data.carousel_bullet}}"
				data-testi-layout="{{data.testimonial_carousel_layout}}"
				data-autoplay="{{data.carousel_autoplay}}"
				data-speed="{{data.carousel_speed}}"
				data-interval="{{data.carousel_interval}}"
				data-margin="{{data.carousel_margin}}"
				data-item-number-xl="{{carousel_item_number_xl || 3}}"
				data-item-number-lg="{{carousel_item_number_lg || 3}}"
				data-item-number-md="{{carousel_item_number_md || 3}}"
				data-item-number-sm="{{carousel_item_number_sm || 3}}"
				data-item-number-xs="{{carousel_item_number_xs || 1}}">
				<# if(_.isArray(data.sp_testimonial_carousel_item)){
					_.each(data.sp_testimonial_carousel_item, function(carousel_item,
caro_index){
					const uniqId= `sppb-testi-${data.id}-carousel-item-key-${caro_index}`;
					let client_details = "";
					var carouselImg = {}
					if (typeof carousel_item.testimonial_carousel_img !==
"undefined" && typeof
carousel_item.testimonial_carousel_img.src !== "undefined") {
						carouselImg = carousel_item.testimonial_carousel_img
					} else {
						carouselImg = {src: carousel_item.testimonial_carousel_img}
					}
					client_details += `<div
class="sppb-testimonial-carousel-content-wrap">`;
						if(carouselImg.src){
							client_details += `<div
class="sppb-testimonial-carousel-img-wrap">`;
							client_details += `<img src=${carouselImg.src}
alt=${carousel_item.client_name}>`;
							client_details += `</div>`;
						}
						client_details += `<div
class="sppb-testimonial-carousel-name-designation">`;
							if(carousel_item.client_name){
								client_details += `<div
class="sppb-testimonial-carousel-name">`;
								client_details += `${carousel_item.client_name}`;
								client_details += `</div>`;
							}
							if(carousel_item.client_desgination){
								client_details += `<div
class="sppb-testimonial-carousel-designation">`;
								client_details += `${carousel_item.client_desgination}`;
								client_details += `</div>`;
							}
						client_details += `</div>`;
					client_details += `</div>`;

					let rating = "";
					if(carousel_item.show_rating){
						rating += `<div
class="sppb-testimonial-carousel-client-rating"><span
class="sppb-testimonial-carousel-rating"></span></div>`;
					}
				#>
						<div id="{{uniqId}}"
class="sppb-carousel-extended-item">
							<# if(data.testimonial_carousel_layout ==
"testi_layout1"){ #>
								{{{quote_icon}}}
							<# }

							if(data.testimonial_carousel_layout == "testi_layout2"){
							#>
								{{{client_details}}}
							<# } #>

							<div class="sppb-testimonial-carousel-item-content">
							<# if(data.testimonial_carousel_layout ==
"testi_layout2" || data.testimonial_carousel_layout ==
"testi_layout3"){ #>
								{{{rating}}}
							<# }

							if(carousel_item.client_message) {
							#>
								<div class="sppb-testimonial-carousel-message">
									{{carousel_item.client_message}}
								</div>
							<# }

							if(data.testimonial_carousel_layout == "testi_layout1"){
							#>
								{{{rating}}}
							<# } #>
							</div>

							<# if(data.testimonial_carousel_layout ==
"testi_layout1" || data.testimonial_carousel_layout ==
"testi_layout3"){ #>
								{{{client_details}}}
							<# }

							if(data.testimonial_carousel_layout == "testi_layout2"){
							#>
								{{{quote_icon}}}
							<# } #>

						</div>
					<#
					})
				} #>
			</div>
		';
        return $output;
    }
}