File: /home/wwwprimemarka/public_html/wp-content/themes/Zephyr/framework/shortcodes/vc_tta_tabs.php
<?php defined( 'ABSPATH' ) OR die( 'This script cannot be accessed directly.' );
/**
* Shortcode: vc_tta_tabs
*
* Overloaded by UpSolution custom implementation.
*
* Dev note: if you want to change some of the default values or acceptable attributes, overload the shortcodes config.
*
* @var $shortcode string Current shortcode name
* @var $shortcode_base string The original called shortcode name (differs if called an alias)
* @var $content string Shortcode's inner content
* @var $atts array Shortcode attributes
*
* @param $atts ['toggle'] bool {@for [vc_tta_accordion]} Act as toggle?
* @param $atts ['c_align'] string {@for [vc_tta_accordion], [vc_tta_tour]} Text alignment: 'left' / 'center' / 'right'
* @param $atts ['c_icon'] string {@for [vc_tta_accordion]} Icon: '' / 'chevron' / 'plus' / 'triangle'
* @param $atts ['c_position'] string {@for [vc_tta_accordion]} Icon position: 'left' / 'right'
* @param $atts ['title_tag'] string Title Tag Name (inherited from wrapping vc_tta_tabs shortcode): 'div' / 'h2'/ 'h3'/ 'h4'/ 'h5'/ 'h6'/ 'p'
* @param $atts ['title_size'] string Title Size
* @param $atts ['layout'] string {@for [vc_tta_tabs]} Tabs layout: 'default' / 'modern' / 'trendy' / 'timeline'
* @param $atts ['stretch'] bool {@for [vc_tta_tabs]} Stretch tabs to the full available width
* @param $atts ['tab_position'] string {@for [vc_tta_tour]} Tabs position: 'left' / 'right'
* @param $atts ['controls_size'] string {@for [vc_tta_tour]} Tabs size: 'auto' / '10' / '20' / '30' / '40' / '50'
* @param $atts ['el_id'] string element ID
* @param $atts ['el_class'] string {@for [vc_tta_accordion], [vc_tta_tabs], [vc_tta_tour]} Extra class
* @param $atts ['css'] string Custom CSS
*/
// Backward compatibility
if ( $shortcode_base == 'vc_tour' ) {
$shortcode_base = 'vc_tta_tour';
} elseif ( $shortcode_base == 'vc_accordion' ) {
$shortcode_base = 'vc_tta_accordion';
} elseif ( $shortcode_base == 'vc_tabs' ) {
$shortcode_base = 'vc_tta_tabs';
}
// $shorcode_base may be: 'vc_tta_tour' / 'vc_tta_accordion' / 'vc_tta_tabs'
$atts = us_shortcode_atts( $atts, $shortcode_base );
$classes = '';
$list_classes = '';
// Extract tab attributes for future html preparations
global $us_tabs_atts;
preg_match_all( '/\[vc_tta_section([^\]]*?)\]/i', $content, $matches, PREG_OFFSET_CAPTURE );
$us_tabs_atts = isset( $matches[0] ) ? $matches[0] : array();
$active_tab_indexes = array();
foreach ( $us_tabs_atts as $index => $tab_atts ) {
$us_tabs_atts[$index] = shortcode_parse_atts( '[' . rtrim( $tab_atts[0], '[]' ) . ' ]' );
if ( isset( $us_tabs_atts[$index]['active'] ) AND $us_tabs_atts[$index]['active'] ) {
$active_tab_indexes[] = $index;
$us_tabs_atts[$index]['defined_active'] = 1;
}
}
// If none of the tabs is active, the first one will be
if ( empty( $active_tab_indexes ) AND $shortcode_base != 'vc_tta_accordion' ) {
$active_tab_indexes[] = 0;
$us_tabs_atts[0]['active'] = 'yes';
}
// Inheriging some of the attributes to the sections
if ( isset( $atts['c_position'] ) ) {
foreach ( $us_tabs_atts as $index => $tab_atts ) {
$us_tabs_atts[$index]['c_position'] = $atts['c_position'];
}
}
// Inheriging some of the attributes to the sections
if ( isset( $atts['title_tag'] ) ) {
foreach ( $us_tabs_atts as $index => $tab_atts ) {
$us_tabs_atts[$index]['title_tag'] = $atts['title_tag'];
}
}
// Inheriging some of the attributes to the sections
if ( isset( $atts['title_size'] ) ) {
foreach ( $us_tabs_atts as $index => $tab_atts ) {
$us_tabs_atts[$index]['title_size'] = $atts['title_size'];
}
}
$layout = 'default';
if ( isset( $atts['layout'] ) AND ! empty ( $atts['layout'] ) ) {
$layout = $atts['layout'];
} elseif ( $shortcode_base == 'vc_tta_tabs' ) {
$list_classes .= ' hidden';
} elseif ( $shortcode_base == 'vc_tta_tour' ) {
$layout = 'ver';
$classes .= ' navpos_' . $atts['tab_position'] . ' navwidth_' . $atts['controls_size'] . ' title_' . $atts['c_align'];
}
$classes .= ' layout_' . $layout;
$list_classes .= ' items_' . count( $us_tabs_atts );
$list_classes .= ( isset( $atts['stretch'] ) AND $atts['stretch'] ) ? ' stretch' : '';
// Accordion-specific settings
if ( $shortcode_base == 'vc_tta_accordion' ) {
$classes .= ' accordion';
if ( $atts['toggle'] ) {
$classes .= ' type_togglable';
}
$classes .= ' title_' . $atts['c_align'];
if ( ! empty( $atts['c_icon'] ) ) {
$classes .= ' icon_' . $atts['c_icon'] . ' iconpos_' . $atts['c_position'];
} else {
$classes .= ' icon_none';
}
} else {
// For accordion state of tabs
$classes .= ' icon_chevron iconpos_right';
}
if ( ! empty( $atts['css'] ) AND function_exists( 'vc_shortcode_custom_css_class' ) ) {
$classes .= ' ' . vc_shortcode_custom_css_class( $atts['css'] );
}
if ( ! empty( $atts['el_class'] ) ) {
$classes .= ' ' . $atts['el_class'];
}
$el_id_string = '';
if ( $atts['el_id'] != '' ) {
$el_id_string = ' id="' . esc_attr( $atts['el_id'] ) . '"';
}
$output = '<div class="w-tabs' . $classes . ' "' . $el_id_string . '>';
// Preparing tab titles
$tabs_list_inline_css = ( $atts['title_size'] != '' ) ? ' style="font-size:' . $atts['title_size'] . '"' : '';
$output .= '<div class="w-tabs-list' . $list_classes . '"' . $tabs_list_inline_css . '><div class="w-tabs-list-h">';
foreach ( $us_tabs_atts as $index => $tab_atts ) {
$tab_atts['title'] = isset( $tab_atts['title'] ) ? $tab_atts['title'] : '';
$tab_atts['i_position'] = isset( $tab_atts['i_position'] ) ? $tab_atts['i_position'] : 'left';
$tab_atts['el_class'] = isset( $tab_atts['el_class'] ) ? ' ' . $tab_atts['el_class'] : '';
$item_tag = 'div';
$item_tag_href = '';
if ( ! empty( $tab_atts['tab_id'] ) ) {
$item_tag = 'a';
$item_tag_href = ' href="#' . $tab_atts['tab_id'] . '"';
}
$active_class = ( isset( $tab_atts['active'] ) AND $tab_atts['active'] ) ? ' active' : '';
$active_class .= ( isset( $tab_atts['defined_active'] ) AND $tab_atts['defined_active'] ) ? ' defined-active' : '';
$icon_class = isset( $tab_atts['icon'] ) ? ' with_icon' : '';
$output .= '<div class="w-tabs-item' . $active_class . $icon_class . $tab_atts['el_class'] . '"><' . $item_tag . $item_tag_href . ' class="w-tabs-item-h">';
if ( isset( $tab_atts['icon'] ) AND $tab_atts['i_position'] == 'left' ) {
$output .= us_prepare_icon_tag( $tab_atts['icon'] );
}
$output .= '<span class="w-tabs-item-title">' . $tab_atts['title'] . '</span>';
if ( isset( $tab_atts['icon'] ) AND $tab_atts['i_position'] == 'right' ) {
$output .= us_prepare_icon_tag( $tab_atts['icon'] );
}
$output .= '</' . $item_tag . '></div>' . "\n";
}
$output .= '</div></div>';
// Handling inner tabs
global $us_tab_index;
$us_tab_index = 0;
$output .= '<div class="w-tabs-sections"><div class="w-tabs-sections-h">' . do_shortcode( $content ) . '</div></div></div>';
echo $output;