web/wp-content/themes/aparatus/scripts/mootabs1.2.js
author ymh
Fri, 12 Mar 2010 13:29:04 +0000
changeset 1 0d28b7c10758
permissions -rw-r--r--
First commit
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
0d28b7c10758 First commit
ymh
parents:
diff changeset
     1
var mootabs = new Class({
0d28b7c10758 First commit
ymh
parents:
diff changeset
     2
	
0d28b7c10758 First commit
ymh
parents:
diff changeset
     3
	initialize: function(element, options) {
0d28b7c10758 First commit
ymh
parents:
diff changeset
     4
		this.options = Object.extend({
0d28b7c10758 First commit
ymh
parents:
diff changeset
     5
			width:				'300px',
0d28b7c10758 First commit
ymh
parents:
diff changeset
     6
			height:				'200px',
0d28b7c10758 First commit
ymh
parents:
diff changeset
     7
			changeTransition:	Fx.Transitions.Bounce.easeOut,
0d28b7c10758 First commit
ymh
parents:
diff changeset
     8
			duration:			1000,
0d28b7c10758 First commit
ymh
parents:
diff changeset
     9
			mouseOverClass:		'active',
0d28b7c10758 First commit
ymh
parents:
diff changeset
    10
			activateOnLoad:		'first',
0d28b7c10758 First commit
ymh
parents:
diff changeset
    11
			useAjax: 			false,
0d28b7c10758 First commit
ymh
parents:
diff changeset
    12
			ajaxUrl: 			'',
0d28b7c10758 First commit
ymh
parents:
diff changeset
    13
			ajaxOptions: 		{method:'get'},
0d28b7c10758 First commit
ymh
parents:
diff changeset
    14
			ajaxLoadingText: 	'Loading...'
0d28b7c10758 First commit
ymh
parents:
diff changeset
    15
		}, options || {});
0d28b7c10758 First commit
ymh
parents:
diff changeset
    16
		
0d28b7c10758 First commit
ymh
parents:
diff changeset
    17
		this.el = $(element);
0d28b7c10758 First commit
ymh
parents:
diff changeset
    18
		this.elid = element;
0d28b7c10758 First commit
ymh
parents:
diff changeset
    19
		
0d28b7c10758 First commit
ymh
parents:
diff changeset
    20
		this.el.setStyles({
0d28b7c10758 First commit
ymh
parents:
diff changeset
    21
			height: this.options.height,
0d28b7c10758 First commit
ymh
parents:
diff changeset
    22
			width: this.options.width
0d28b7c10758 First commit
ymh
parents:
diff changeset
    23
		});
0d28b7c10758 First commit
ymh
parents:
diff changeset
    24
		
0d28b7c10758 First commit
ymh
parents:
diff changeset
    25
		this.titles = $$('#' + this.elid + ' ul.mootabs_title li');
0d28b7c10758 First commit
ymh
parents:
diff changeset
    26
		this.panelHeight = this.el.getSize().size.y - (this.titles[0].getSize().size.y + 4);
0d28b7c10758 First commit
ymh
parents:
diff changeset
    27
		this.panels = $$('#' + this.elid + ' .mootabs_panel');
0d28b7c10758 First commit
ymh
parents:
diff changeset
    28
0d28b7c10758 First commit
ymh
parents:
diff changeset
    29
		
0d28b7c10758 First commit
ymh
parents:
diff changeset
    30
		this.panels.setStyle('height', this.panelHeight);
0d28b7c10758 First commit
ymh
parents:
diff changeset
    31
		
0d28b7c10758 First commit
ymh
parents:
diff changeset
    32
		this.titles.each(function(item) {
0d28b7c10758 First commit
ymh
parents:
diff changeset
    33
			item.addEvent('click', function(){
0d28b7c10758 First commit
ymh
parents:
diff changeset
    34
					item.removeClass(this.options.mouseOverClass);
0d28b7c10758 First commit
ymh
parents:
diff changeset
    35
					this.activate(item);
0d28b7c10758 First commit
ymh
parents:
diff changeset
    36
				}.bind(this)
0d28b7c10758 First commit
ymh
parents:
diff changeset
    37
			);
0d28b7c10758 First commit
ymh
parents:
diff changeset
    38
			
0d28b7c10758 First commit
ymh
parents:
diff changeset
    39
			item.addEvent('mouseover', function() {
0d28b7c10758 First commit
ymh
parents:
diff changeset
    40
				if(item != this.activeTitle)
0d28b7c10758 First commit
ymh
parents:
diff changeset
    41
				{
0d28b7c10758 First commit
ymh
parents:
diff changeset
    42
					item.addClass(this.options.mouseOverClass);
0d28b7c10758 First commit
ymh
parents:
diff changeset
    43
				}
0d28b7c10758 First commit
ymh
parents:
diff changeset
    44
			}.bind(this));
0d28b7c10758 First commit
ymh
parents:
diff changeset
    45
			
0d28b7c10758 First commit
ymh
parents:
diff changeset
    46
			item.addEvent('mouseout', function() {
0d28b7c10758 First commit
ymh
parents:
diff changeset
    47
				if(item != this.activeTitle)
0d28b7c10758 First commit
ymh
parents:
diff changeset
    48
				{
0d28b7c10758 First commit
ymh
parents:
diff changeset
    49
					item.removeClass(this.options.mouseOverClass);
0d28b7c10758 First commit
ymh
parents:
diff changeset
    50
				}
0d28b7c10758 First commit
ymh
parents:
diff changeset
    51
			}.bind(this));
0d28b7c10758 First commit
ymh
parents:
diff changeset
    52
		}.bind(this));
0d28b7c10758 First commit
ymh
parents:
diff changeset
    53
		
0d28b7c10758 First commit
ymh
parents:
diff changeset
    54
		
0d28b7c10758 First commit
ymh
parents:
diff changeset
    55
		if(this.options.activateOnLoad != 'none')
0d28b7c10758 First commit
ymh
parents:
diff changeset
    56
		{
0d28b7c10758 First commit
ymh
parents:
diff changeset
    57
			if(this.options.activateOnLoad == 'first')
0d28b7c10758 First commit
ymh
parents:
diff changeset
    58
			{
0d28b7c10758 First commit
ymh
parents:
diff changeset
    59
				this.activate(this.titles[0], true);
0d28b7c10758 First commit
ymh
parents:
diff changeset
    60
			}
0d28b7c10758 First commit
ymh
parents:
diff changeset
    61
			else
0d28b7c10758 First commit
ymh
parents:
diff changeset
    62
			{
0d28b7c10758 First commit
ymh
parents:
diff changeset
    63
				this.activate(this.options.activateOnLoad, true);	
0d28b7c10758 First commit
ymh
parents:
diff changeset
    64
			}
0d28b7c10758 First commit
ymh
parents:
diff changeset
    65
		}
0d28b7c10758 First commit
ymh
parents:
diff changeset
    66
	},
0d28b7c10758 First commit
ymh
parents:
diff changeset
    67
	
0d28b7c10758 First commit
ymh
parents:
diff changeset
    68
	activate: function(tab, skipAnim){
0d28b7c10758 First commit
ymh
parents:
diff changeset
    69
		if(! $defined(skipAnim))
0d28b7c10758 First commit
ymh
parents:
diff changeset
    70
		{
0d28b7c10758 First commit
ymh
parents:
diff changeset
    71
			skipAnim = false;
0d28b7c10758 First commit
ymh
parents:
diff changeset
    72
		}
0d28b7c10758 First commit
ymh
parents:
diff changeset
    73
		if($type(tab) == 'string') 
0d28b7c10758 First commit
ymh
parents:
diff changeset
    74
		{
0d28b7c10758 First commit
ymh
parents:
diff changeset
    75
			myTab = $$('#' + this.elid + ' ul li').filterByAttribute('title', '=', tab)[0];
0d28b7c10758 First commit
ymh
parents:
diff changeset
    76
			tab = myTab;
0d28b7c10758 First commit
ymh
parents:
diff changeset
    77
		}
0d28b7c10758 First commit
ymh
parents:
diff changeset
    78
		
0d28b7c10758 First commit
ymh
parents:
diff changeset
    79
		if($type(tab) == 'element')
0d28b7c10758 First commit
ymh
parents:
diff changeset
    80
		{
0d28b7c10758 First commit
ymh
parents:
diff changeset
    81
			var newTab = tab.getProperty('title');
0d28b7c10758 First commit
ymh
parents:
diff changeset
    82
			this.panels.removeClass('active');
0d28b7c10758 First commit
ymh
parents:
diff changeset
    83
			
0d28b7c10758 First commit
ymh
parents:
diff changeset
    84
			this.activePanel = this.panels.filterById(newTab)[0];
0d28b7c10758 First commit
ymh
parents:
diff changeset
    85
			
0d28b7c10758 First commit
ymh
parents:
diff changeset
    86
			this.activePanel.addClass('active');
0d28b7c10758 First commit
ymh
parents:
diff changeset
    87
			
0d28b7c10758 First commit
ymh
parents:
diff changeset
    88
			if(this.options.changeTransition != 'none' && skipAnim==false)
0d28b7c10758 First commit
ymh
parents:
diff changeset
    89
			{
0d28b7c10758 First commit
ymh
parents:
diff changeset
    90
				this.panels.filterById(newTab).setStyle('height', 0);
0d28b7c10758 First commit
ymh
parents:
diff changeset
    91
				var changeEffect = new Fx.Elements(this.panels.filterById(newTab), {duration: this.options.duration, transition: this.options.changeTransition});
0d28b7c10758 First commit
ymh
parents:
diff changeset
    92
				changeEffect.start({
0d28b7c10758 First commit
ymh
parents:
diff changeset
    93
					'0': {
0d28b7c10758 First commit
ymh
parents:
diff changeset
    94
						'height': [0, this.panelHeight]
0d28b7c10758 First commit
ymh
parents:
diff changeset
    95
					}
0d28b7c10758 First commit
ymh
parents:
diff changeset
    96
				});
0d28b7c10758 First commit
ymh
parents:
diff changeset
    97
			}
0d28b7c10758 First commit
ymh
parents:
diff changeset
    98
			
0d28b7c10758 First commit
ymh
parents:
diff changeset
    99
			this.titles.removeClass('active');
0d28b7c10758 First commit
ymh
parents:
diff changeset
   100
			
0d28b7c10758 First commit
ymh
parents:
diff changeset
   101
			tab.addClass('active');
0d28b7c10758 First commit
ymh
parents:
diff changeset
   102
			
0d28b7c10758 First commit
ymh
parents:
diff changeset
   103
			this.activeTitle = tab;
0d28b7c10758 First commit
ymh
parents:
diff changeset
   104
			
0d28b7c10758 First commit
ymh
parents:
diff changeset
   105
			if(this.options.useAjax)
0d28b7c10758 First commit
ymh
parents:
diff changeset
   106
			{
0d28b7c10758 First commit
ymh
parents:
diff changeset
   107
				this._getContent();
0d28b7c10758 First commit
ymh
parents:
diff changeset
   108
			}
0d28b7c10758 First commit
ymh
parents:
diff changeset
   109
		}
0d28b7c10758 First commit
ymh
parents:
diff changeset
   110
	},
0d28b7c10758 First commit
ymh
parents:
diff changeset
   111
	
0d28b7c10758 First commit
ymh
parents:
diff changeset
   112
	_getContent: function(){
0d28b7c10758 First commit
ymh
parents:
diff changeset
   113
		this.activePanel.setHTML(this.options.ajaxLoadingText);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   114
		var newOptions = {update: this.activePanel.getProperty('id')};
0d28b7c10758 First commit
ymh
parents:
diff changeset
   115
		this.options.ajaxOptions = Object.extend(this.options.ajaxOptions, newOptions || {});
0d28b7c10758 First commit
ymh
parents:
diff changeset
   116
		var tabRequest = new Ajax(this.options.ajaxUrl + '?tab=' + this.activeTitle.getProperty('title'), this.options.ajaxOptions);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   117
		tabRequest.request();
0d28b7c10758 First commit
ymh
parents:
diff changeset
   118
	},
0d28b7c10758 First commit
ymh
parents:
diff changeset
   119
	
0d28b7c10758 First commit
ymh
parents:
diff changeset
   120
	addTab: function(title, label, content){
0d28b7c10758 First commit
ymh
parents:
diff changeset
   121
		//the new title
0d28b7c10758 First commit
ymh
parents:
diff changeset
   122
		var newTitle = new Element('li', {
0d28b7c10758 First commit
ymh
parents:
diff changeset
   123
			'title': title
0d28b7c10758 First commit
ymh
parents:
diff changeset
   124
		});
0d28b7c10758 First commit
ymh
parents:
diff changeset
   125
		newTitle.appendText(label);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   126
		this.titles.include(newTitle);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   127
		$$('#' + this.elid + ' ul').adopt(newTitle);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   128
		newTitle.addEvent('click', function() {
0d28b7c10758 First commit
ymh
parents:
diff changeset
   129
			this.activate(newTitle);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   130
		}.bind(this));
0d28b7c10758 First commit
ymh
parents:
diff changeset
   131
		
0d28b7c10758 First commit
ymh
parents:
diff changeset
   132
		newTitle.addEvent('mouseover', function() {
0d28b7c10758 First commit
ymh
parents:
diff changeset
   133
			if(newTitle != this.activeTitle)
0d28b7c10758 First commit
ymh
parents:
diff changeset
   134
			{
0d28b7c10758 First commit
ymh
parents:
diff changeset
   135
				newTitle.addClass(this.options.mouseOverClass);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   136
			}
0d28b7c10758 First commit
ymh
parents:
diff changeset
   137
		}.bind(this));
0d28b7c10758 First commit
ymh
parents:
diff changeset
   138
		newTitle.addEvent('mouseout', function() {
0d28b7c10758 First commit
ymh
parents:
diff changeset
   139
			if(newTitle != this.activeTitle)
0d28b7c10758 First commit
ymh
parents:
diff changeset
   140
			{
0d28b7c10758 First commit
ymh
parents:
diff changeset
   141
				newTitle.removeClass(this.options.mouseOverClass);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   142
			}
0d28b7c10758 First commit
ymh
parents:
diff changeset
   143
		}.bind(this));
0d28b7c10758 First commit
ymh
parents:
diff changeset
   144
		//the new panel
0d28b7c10758 First commit
ymh
parents:
diff changeset
   145
		var newPanel = new Element('div', {
0d28b7c10758 First commit
ymh
parents:
diff changeset
   146
			'style': {'height': this.options.panelHeight},
0d28b7c10758 First commit
ymh
parents:
diff changeset
   147
			'id': title,
0d28b7c10758 First commit
ymh
parents:
diff changeset
   148
			'class': 'mootabs_panel'
0d28b7c10758 First commit
ymh
parents:
diff changeset
   149
		});
0d28b7c10758 First commit
ymh
parents:
diff changeset
   150
		if(!this.options.useAjax)
0d28b7c10758 First commit
ymh
parents:
diff changeset
   151
		{
0d28b7c10758 First commit
ymh
parents:
diff changeset
   152
			newPanel.setHTML(content);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   153
		}
0d28b7c10758 First commit
ymh
parents:
diff changeset
   154
		this.panels.include(newPanel);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   155
		this.el.adopt(newPanel);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   156
	},
0d28b7c10758 First commit
ymh
parents:
diff changeset
   157
	
0d28b7c10758 First commit
ymh
parents:
diff changeset
   158
	removeTab: function(title){
0d28b7c10758 First commit
ymh
parents:
diff changeset
   159
		if(this.activeTitle.title == title)
0d28b7c10758 First commit
ymh
parents:
diff changeset
   160
		{
0d28b7c10758 First commit
ymh
parents:
diff changeset
   161
			this.activate(this.titles[0]);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   162
		}
0d28b7c10758 First commit
ymh
parents:
diff changeset
   163
		$$('#' + this.elid + ' ul li').filterByAttribute('title', '=', title)[0].remove();
0d28b7c10758 First commit
ymh
parents:
diff changeset
   164
		
0d28b7c10758 First commit
ymh
parents:
diff changeset
   165
		$$('#' + this.elid + ' .mootabs_panel').filterById(title)[0].remove();
0d28b7c10758 First commit
ymh
parents:
diff changeset
   166
	},
0d28b7c10758 First commit
ymh
parents:
diff changeset
   167
	
0d28b7c10758 First commit
ymh
parents:
diff changeset
   168
	next: function(){
0d28b7c10758 First commit
ymh
parents:
diff changeset
   169
		var nextTab = this.activeTitle.getNext();
0d28b7c10758 First commit
ymh
parents:
diff changeset
   170
		if(!nextTab) {
0d28b7c10758 First commit
ymh
parents:
diff changeset
   171
			nextTab = this.titles[0];
0d28b7c10758 First commit
ymh
parents:
diff changeset
   172
		}
0d28b7c10758 First commit
ymh
parents:
diff changeset
   173
		this.activate(nextTab);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   174
	},
0d28b7c10758 First commit
ymh
parents:
diff changeset
   175
	
0d28b7c10758 First commit
ymh
parents:
diff changeset
   176
	previous: function(){
0d28b7c10758 First commit
ymh
parents:
diff changeset
   177
		var previousTab = this.activeTitle.getPrevious();
0d28b7c10758 First commit
ymh
parents:
diff changeset
   178
		if(!previousTab) {
0d28b7c10758 First commit
ymh
parents:
diff changeset
   179
			previousTab = this.titles[this.titles.length - 1];
0d28b7c10758 First commit
ymh
parents:
diff changeset
   180
		}
0d28b7c10758 First commit
ymh
parents:
diff changeset
   181
		this.activate(previousTab);
0d28b7c10758 First commit
ymh
parents:
diff changeset
   182
	}
0d28b7c10758 First commit
ymh
parents:
diff changeset
   183
});