Sha256: fc114358b63638e317c3eb8b2ce160303d8933575fe5dc071d875daff8ce411e

Contents?: true

Size: 1.87 KB

Versions: 14

Compression:

Stored size: 1.87 KB

Contents

/**
* Gumby Tabs
*/
!function($) {

	'use strict';

	function Tabs($el) {

		Gumby.debug('Initializing Tabs', $el);

		this.$el = $el;
		this.$nav = this.$el.find('> ul.tab-nav > li');
		this.$content = this.$el.children('.tab-content');

		var scope = this;

		// listen for click event on tab nav and custom gumby set event
		this.$nav.children('a').on(Gumby.click, function(e) {
			e.preventDefault();
			scope.click($(this));
		});

		// listen for gumby.set value for dynamically set tabs
		this.$el.on('gumby.set', function(e, index) {
			Gumby.debug('Set event triggered', scope.$el);
			scope.set(e, index);
		});
	}

	// handle tab nav click event
	Tabs.prototype.click = function($this) {
		// index of item to activate
		var index = $this.parent().index();

		if(this.$nav.eq(index).add(this.$content.eq(index)).hasClass('active')) {
			return;
		}

		Gumby.debug('Setting active tab to '+index, this.$el);

		// deactivate other tab navigation and content
		this.$nav.add(this.$content).removeClass('active');

		// activate this tab nav link and content
		this.$nav.eq(index).add(this.$content.eq(index)).addClass('active');

		// trigger gumby.change event and pass current active tab index
		Gumby.debug('Triggering onChange event', this.$el);
		this.$el.trigger('gumby.onChange', index);
	};

	// set specific tab
	Tabs.prototype.set = function(e, index) {
		this.$nav.eq(index).find('a').trigger(Gumby.click);
	};

	// add initialisation
	Gumby.addInitalisation('tabs', function() {
		$('.tabs').each(function() {
			var $this = $(this);
			// this element has already been initialized
			if($this.data('isTabs')) {
				return true;
			}
			// mark element as initialized
			$this.data('isTabs', true);
			new Tabs($this);
		});
	});

	// register UI module
	Gumby.UIModule({
		module: 'tabs',
		events: ['onChange', 'set'],
		init: function() {
			Gumby.initialize('tabs');
		}
	});
}(jQuery);

Version data entries

14 entries across 14 versions & 3 rubygems

Version Path
loldesign_publisher-2.0.0 app/assets/javascripts/loldesign_publisher/libs/ui/gumby.tabs.js
loldesign_publisher-1.5.1 app/assets/javascripts/loldesign_publisher/libs/ui/gumby.tabs.js
loldesign_publisher-1.5.0 app/assets/javascripts/loldesign_publisher/libs/ui/gumby.tabs.js
loldesign_publisher-1.4.0 app/assets/javascripts/loldesign_publisher/libs/ui/gumby.tabs.js
loldesign_publisher-1.3.6 app/assets/javascripts/loldesign_publisher/libs/ui/gumby.tabs.js
loldesign_publisher-1.3.4 app/assets/javascripts/loldesign_publisher/libs/ui/gumby.tabs.js
loldesign_publisher-1.3.3 app/assets/javascripts/loldesign_publisher/libs/ui/gumby.tabs.js
loldesign_publisher-1.3.2 app/assets/javascripts/loldesign_publisher/libs/ui/gumby.tabs.js
loldesign_publisher-1.3.1 app/assets/javascripts/loldesign_publisher/libs/ui/gumby.tabs.js
loldesign_publisher-1.3.0 app/assets/javascripts/loldesign_publisher/libs/ui/gumby.tabs.js
loldesign_publisher-1.1.0 app/assets/javascripts/loldesign_publisher/libs/ui/gumby.tabs.js
gumby_on_rails-0.0.1 app/assets/javascripts/gumby/libs/ui/gumby.tabs.js
gumbie-0.1.2 vendor/assets/javascripts/libs/ui/gumby.tabs.js
gumbie-0.1.0 vendor/assets/javascripts/libs/ui/gumby.tabs.js