Difference between revisions of "Template:CSU CHINA/JS/easyResponsiveTabs.js"

(Blanked the page)
Line 1: Line 1:
// Easy Responsive Tabs Plugin
 
// Author: Samson.Onna <Email : samson3d@gmail.com>
 
(function ($) {
 
    $.fn.extend({
 
        easyResponsiveTabs: function (options) {
 
            //Set the default values, use comma to separate the settings, example:
 
            var defaults = {
 
                type: 'default', //default, vertical, accordion;
 
                width: 'auto',
 
                fit: true
 
            }
 
            //Variables
 
            var options = $.extend(defaults, options);           
 
            var opt = options, jtype = opt.type, jfit = opt.fit, jwidth = opt.width, vtabs = 'vertical', accord = 'accordion';
 
  
            //Main function
 
            this.each(function () {
 
                var $respTabs = $(this);
 
                $respTabs.find('ul.resp-tabs-list li').addClass('resp-tab-item');
 
                $respTabs.css({
 
                    'display': 'block',
 
                    'width': jwidth
 
                });
 
 
                $respTabs.find('.resp-tabs-container > div').addClass('resp-tab-content');
 
                jtab_options();
 
                //Properties Function
 
                function jtab_options() {
 
                    if (jtype == vtabs) {
 
                        $respTabs.addClass('resp-vtabs');
 
                    }
 
                    if (jfit == true) {
 
                        $respTabs.css({ width: '100%', margin: '0px' });
 
                    }
 
                    if (jtype == accord) {
 
                        $respTabs.addClass('resp-easy-accordion');
 
                        $respTabs.find('.resp-tabs-list').css('display', 'none');
 
                    }
 
                }
 
 
                //Assigning the h2 markup
 
                var $tabItemh2;
 
                $respTabs.find('.resp-tab-content').before('<h2 class='resp-accordion' role='tab'><span class='resp-arrow'></span></h2>');
 
 
                var itemCount = 0;
 
                $respTabs.find('.resp-accordion').each(function () {
 
                    $tabItemh2 = $(this);
 
                    var innertext = $respTabs.find('.resp-tab-item:eq(' + itemCount + ')').text();
 
                    $respTabs.find('.resp-accordion:eq(' + itemCount + ')').append(innertext);
 
                    $tabItemh2.attr('aria-controls', 'tab_item-' + (itemCount));
 
                    itemCount++;
 
                });
 
 
                //Assigning the 'aria-controls' to Tab items
 
                var count = 0,
 
                    $tabContent;
 
                $respTabs.find('.resp-tab-item').each(function () {
 
                    $tabItem = $(this);
 
                    $tabItem.attr('aria-controls', 'tab_item-' + (count));
 
                    $tabItem.attr('role', 'tab');
 
 
                    //First active tab                 
 
                    $respTabs.find('.resp-tab-item').first().addClass('resp-tab-active');
 
                    $respTabs.find('.resp-accordion').first().addClass('resp-tab-active');
 
                    $respTabs.find('.resp-tab-content').first().addClass('resp-tab-content-active').attr('style', 'display:block');
 
 
                    //Assigning the 'aria-labelledby' attr to tab-content
 
                    var tabcount = 0;
 
                    $respTabs.find('.resp-tab-content').each(function () {
 
                        $tabContent = $(this);
 
                        $tabContent.attr('aria-labelledby', 'tab_item-' + (tabcount));
 
                        tabcount++;
 
                    });
 
                    count++;
 
                });
 
 
                //Tab Click action function
 
                $respTabs.find("[role=tab]").each(function () {
 
                    var $currentTab = $(this);
 
                    $currentTab.click(function () {
 
 
                        var $tabAria = $currentTab.attr('aria-controls');
 
 
                        if ($currentTab.hasClass('resp-accordion') && $currentTab.hasClass('resp-tab-active')) {
 
                            $respTabs.find('.resp-tab-content-active').slideUp('', function () { $(this).addClass('resp-accordion-closed'); });
 
                            $currentTab.removeClass('resp-tab-active');
 
                            return false;
 
                        }
 
                        if (!$currentTab.hasClass('resp-tab-active') && $currentTab.hasClass('resp-accordion')) {
 
                            $respTabs.find('.resp-tab-active').removeClass('resp-tab-active');
 
                            $respTabs.find('.resp-tab-content-active').slideUp().removeClass('resp-tab-content-active resp-accordion-closed');
 
                            $respTabs.find("[aria-controls=" + $tabAria + "]").addClass('resp-tab-active');
 
 
                            $respTabs.find('.resp-tab-content[aria-labelledby = ' + $tabAria + ']').slideDown().addClass('resp-tab-content-active');
 
                        } else {
 
                            $respTabs.find('.resp-tab-active').removeClass('resp-tab-active');
 
                            $respTabs.find('.resp-tab-content-active').removeAttr('style').removeClass('resp-tab-content-active').removeClass('resp-accordion-closed');
 
                            $respTabs.find("[aria-controls=" + $tabAria + "]").addClass('resp-tab-active');
 
                            $respTabs.find('.resp-tab-content[aria-labelledby = ' + $tabAria + ']').addClass('resp-tab-content-active').attr('style', 'display:block');
 
                        }
 
                    });
 
                    //Window resize function                 
 
                    $(window).resize(function () {
 
                        $respTabs.find('.resp-accordion-closed').removeAttr('style');
 
                    });
 
                });
 
            });
 
        }
 
    });
 

Revision as of 20:56, 18 October 2019