var SlideList = new Class({	initialize: function(menu, options) {		this.setOptions(this.getOptions(), options);				this.menu = $(menu), this.current = this.menu.getElement('li.current');				this.menu.getElements('li').each(function(item){			item.addEvent('mouseover', function(){ this.moveBg(item); }.bind(this));			item.addEvent('mouseout', function(){ this.moveBg(this.current); }.bind(this));			item.addEvent('click', function(event){ this.clickItem(event, item); }.bind(this));		}.bind(this));						this.back = new Element('li').addClass('background').adopt(new Element('div').addClass('left')).injectInside(this.menu);		this.back.fx = this.back.effects(this.options);		if(this.current) this.setCurrent(this.current);	},		setCurrent: function(el, effect){		this.back.setStyles({left: (el.offsetLeft)+'px', width: (el.offsetWidth)+'px'});		(effect) ? this.back.effect('opacity').set(0).start(1) : this.back.setOpacity(1);		this.current = el;	},		getOptions: function(){		return {			transition: Fx.Transitions.sineInOut,			duration: 500, wait: false,			onClick: Class.empty		};	},	clickItem: function(event, item) {		if(!this.current) this.setCurrent(item, true);		this.current = item;		this.options.onClick(new Event(event), item);	},	moveBg: function(to) {		if(!this.current) return;		this.back.fx.custom({			left: [this.back.offsetLeft, to.offsetLeft],			width: [this.back.offsetWidth, to.offsetWidth]		});	}});SlideList.implement(new Options);