/home/arranoyd/magicraft/wp-content/themes/massive-dynamic/lib/shortcodes/md_hor_tabs/index.php
<?php
/**
 *  Horizontal Tabs Shortcode
 *
 * @author Pixflow
 */

add_shortcode('md_hor_tabs', 'pixflow_get_style_script');

function pixflow_sc_hor_tabs( $atts, $content = null ){
    $animation=$output = $title = $tab_icon  = $general_color = $use_bg=$bg_type = $bg_color = $bg_image='';
    extract( shortcode_atts( array(
        'general_color' => 'rgb(255,255,255)',
        'use_bg'        => 'yes',
        'bg_type'       => 'color',
        'bg_color'      => 'rgb(215,176,126)',
        'hor_tab_hover_color' => 'rgb(215,176,126)',
        'bg_image'      => ''
    ), $atts ) );
    $animation = array();
    $animation = pixflow_shortcodeAnimation('md_hor_tabs',$atts);
    wp_enqueue_script('jquery-ui-tabs');
    $element = 'wpb_tabs';
    $id = esc_attr(pixflow_sc_id('md_hor_tabs'));
    ob_start();
    ?>
    <style >
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li a i,
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li a .horTabTitle,
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li a.md-hor-tab-add-tab{
            color: <?php echo esc_attr($general_color); ?>;
        }
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li{
            border-bottom: solid 1px <?php echo esc_attr(pixflow_colorConvertor($general_color,'rgba', 0.5)); ?>;
        }
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li:first-child{
            border-top: solid 1px <?php echo esc_attr(pixflow_colorConvertor($general_color,'rgba', 0.5)); ?>;
        }
        <?php if($use_bg=='yes'){ ?>
        .<?php echo esc_attr($id); ?>.md_hor_tab.wpb_content_element .px_tabs_nav.md-custom-tab > li > a{
            padding: 0 20px 0 20px;
        }
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li.ui-tabs-active,
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li:hover{
            background-color: <?php echo esc_attr(pixflow_colorConvertor($general_color,'rgba', 0.3)); ?>;
        }
        <?php }else{ ?>
        .<?php echo esc_attr($id); ?>.md_hor_tab.wpb_content_element .px_tabs_nav.md-custom-tab > li > a{
            padding: 0;
        }
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li.ui-tabs-active,
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li:hover{
            background-color: transparent;
        }
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li .horTabTitle,
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li i{
            transition: color 0.3s;
        }

        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li.ui-tabs-active .horTabTitle,
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li:hover .horTabTitle,
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li.ui-tabs-active i,
        .<?php echo esc_attr($id); ?>.wpb_content_element .px_tabs_nav li:hover i{
            color: <?php echo esc_attr($hor_tab_hover_color); ?>;
        }
        <?php } ?>
        <?php if($use_bg=='yes' && $bg_type=='color'){ ?>
        .<?php echo esc_attr($id); ?>.wpb_content_element.md_hor_tab ul.px_tabs_nav {
            background-color: <?php echo esc_attr($bg_color); ?>;
        }
        .<?php echo esc_attr($id); ?>.wpb_content_element.md_hor_tab .overlay{
            display:none;
        }
        <?php }
        if($use_bg=='yes' && $bg_type=='image'){
            if(is_numeric($bg_image)){
                $bg_image =  wp_get_attachment_image_src( $bg_image,'full') ;
                $bg_image = (false == $bg_image)?PIXFLOW_PLACEHOLDER_BLANK:$bg_image[0];
            }
        ?>
        .<?php echo esc_attr($id); ?>.wpb_content_element.md_hor_tab ul.px_tabs_nav {
            background-image: url(<?php echo esc_url($bg_image); ?>);
            background-color: transparent;
            background-repeat: no-repeat;
            background-size: cover;
            background-position: center;
        }
        .<?php echo esc_attr($id); ?>.wpb_content_element.md_hor_tab .overlay{
            display:block;
        }
        <?php }else{
        ?>
        .<?php echo esc_attr($id); ?>.wpb_content_element.md_hor_tab .overlay{
            display:none;
        }
        <?php
        } ?>
    </style>
    <?php
    $output.=ob_get_clean();
    $content = preg_replace_callback('~(md_hor_tab) ([^\]]+)~is','pixflow_tabs_id',$content);

    preg_match_all( '/md_hor_tab ([^\]]+)/i', $content, $matches, PREG_OFFSET_CAPTURE );
    $tab_titles = array();
    if ( isset( $matches[1] ) && count($matches[1]) ) {
        $tab_titles = $matches[1];
    }else{
        if(preg_match_all( '~[^mBuilder\-element]*?<li .*?<a href="#tab-(.*?)".*?<i class=.*? (icon-.*?)["\']></i><div class="horTabTitle">(.*?)</div>~is', $content, $matches, PREG_OFFSET_CAPTURE )){
            foreach($matches[3] as $key =>$titles){
                $tab_titles[$key] = array(' title="'.$titles[0].'" tab_icon_class="'.$matches[2][$key][0].'" tab_id="'.$matches[1][$key][0].'"');
            }
            $content = preg_replace('~[^mBuilder\-element]*?<ul class="px_tabs_nav.*?>.*?</ul>~is','',$content);
        }else{
            $tab_titles[] = array('title="' . esc_attr__( 'TAB', 'massive-dynamic' ) . '" tab_id="'.uniqid('tab').'"');
            $tab_titles[] = array('title="' . esc_attr__( 'TAB', 'massive-dynamic' ) . '" tab_id="'.uniqid('tab').'"');
        }
    }
    $tabs_nav = '';
    $hasBg = $use_bg;
    $tabs_nav .= '<ul class="px_tabs_nav ui-tabs-nav vc_clearfix md-custom-tab">';
    $i=0;
    foreach ( $tab_titles as $tab ) {
        $i++;
        $tab_atts = shortcode_parse_atts($tab[0]);
        $tab_atts['title'] = !array_key_exists('title',$tab_atts)?'Tab ':$tab_atts['title'];
        $tab_atts['tab_icon'] = !array_key_exists('tab_icon',$tab_atts)?'icon-cog':$tab_atts['tab_icon'];
        if (isset($tab_atts['title']) || isset($tab_atts['tab_icon'])) {
            $tabs_nav .= '<li data-model="md_hor_tabs">
                    <a href="#tab-' . (isset($tab_atts['tab_id']) ? $tab_atts['tab_id'] : sanitize_title($tab_atts['title'])) . '"><i class="right-icon '.$tab_atts['tab_icon'].'"></i><div class="horTabTitle">'.$tab_atts['title'].'</div><i class="right-icon icon-angle-right"></i></a>
                </li>';
        }
    }
    if($hasBg=='yes'){
        $tabs_nav.= '<div class="overlay"></div>';
    }
    $tabs_nav .= '</ul>' . "\n";
    $css_class = apply_filters( VC_SHORTCODE_CUSTOM_CSS_FILTER_TAG, trim( $element . ' wpb_content_element ' ), $atts );
    $output .= "\n\t" . '<div class="'.$id.' md_hor_tab clearfix '. $css_class .' '. esc_attr($animation["has-animation"]) .'" data-interval="' . 0 . '" '.esc_attr($animation["animation-attrs"]).'>';
    $output .= "\n\t\t" . '<div class="wpb_wrapper disable-sort wpb_tour_tabs_wrapper ui-tabs vc_clearfix">';
    $output .= pixflow_widget_title( array( 'title' => $title, 'extraclass' => $element . '_heading' ) );
    $output .= "\n\t\t\t" . $tabs_nav;
    $output .= "\n\t\t\t" . pixflow_js_remove_wpautop( $content );
    $output .= "\n\t\t" . '</div> ' ;
    $output .= "\n\t" . '</div> ';
    ob_start();
    ?>
    <script type="text/javascript">
        var $ = jQuery;
        $(function(){
            if(typeof pixflow_horTab == 'function'){
                pixflow_horTab('<?php echo esc_attr($id); ?>','');
            }
            $('.<?php echo esc_attr($id); ?>').closest('.vc_md_hor_tabs').find('.md-hor-tab-add-tab').parent().remove();
            $('.<?php echo esc_attr($id); ?>').closest('.vc_md_hor_tabs').find('.px_tabs_nav').append('<li class="unsortable"><a class="md-hor-tab-add-tab vc_control-btn"><strong>+</strong><div class="modernTabTitle">ADD TAB</div></a></li>');
            $('.<?php echo esc_attr($id); ?>').closest('.vc_md_hor_tabs').find('.md-hor-tab-add-tab').click(function(e){
                e.preventDefault();
				$(this).closest('.mBuilder-element').find('>.mBuilder_controls .vc_control-btn[data-control="add_section"] .vc_btn-content').on( 'click',function (e) {
					e.preventDefault();
					e.stopPropagation();
				});
				
                $(this).closest('.mBuilder-element').find('>.mBuilder_controls .vc_control-btn[data-control="add_section"] .vc_btn-content').click();
            });
            if (!$('.<?php echo esc_attr($id); ?>').data("ui-tabs")) {
                $('.<?php echo esc_attr($id); ?>').on('click','.px_tabs_nav li > a',function(e){$(this).closest('li').click();return false;});
                $('.<?php echo esc_attr($id); ?>').on('click','.ui-tabs-nav li',function(e){
                    e.preventDefault();
                    $(this).parent().parent().find('.ui-tabs-panel,.mBuilder-md_hor_tab').css('display','none');
                    $(this).parent().parent().find($(this).find('a').attr('href')).css('display','block');
                    $(this).parent().parent().find($(this).find('a').attr('href')).closest('.mBuilder-md_hor_tab').css('display','');
                    $(this).siblings('li').removeClass('ui-tabs-active');
                    $(this).addClass('ui-tabs-active');
                });
                $('.<?php echo esc_attr($id); ?> .ui-tabs-nav li').first().click();
            }
        });
        $(window).load(function () {
            if(typeof pixflow_horTab == 'function'){
                pixflow_horTab('<?php echo esc_attr($id); ?>','');
            }
        });
        <?php pixflow_callAnimation(false,$animation['animation-type'],'.'.$id); ?>
    </script>
    <?php
    $output.=ob_get_clean();
    return $output;
}