
Event.observe(window, 'load', function() {
	CMS.resizeImageContainers("round-image");
});

CMS = Class.create();

/**
 * Open new window
 */
CMS.open = function(event) {
	event = Event.extend(event);
	element = event.findElement();
	element = element.nodeName.toLowerCase() != "a" ? element.up("a") : element;
	window.open(element.getAttribute("href"));
	event.stop();
}

/**
 * Set location
 */
CMS.setLocation = function(sUrl){
    window.location.href = sUrl;
}

/**
 * Add to favourites
 */
CMS.addToFavourites = function(sName, sUrl) {
	if(window.sidebar)
		window.sidebar.addPanel(sName, sUrl , "");
	else if(window.external)
		window.external.AddFavorite(sUrl, sName)
}

/**
 * Send e-mail
 */
CMS.mail = function(sUser, sSite, bUrl, bShowMail, sClassName) {
	if(typeof sClassName == "undefined")
		sClassName == "";
	
	document.write(bUrl ? '<a class="' + sClassName + '" href=\"mailto:' + sUser + '@' + sSite + '\">' : '');
	document.write((bShowMail ? sUser + '@' + sSite : '') + (bUrl ? '</a>' : ''));
}


/**
 * Show pop up
 */
CMS.openPopup = function(sUrl){
	var sWidth = window.screen.width;
	var sHeight = window.screen.height;
	var oWindow = window.open(sUrl, "popupWindow", "height=510, width=700, left="+parseInt((sWidth-700)/2)+", top="+parseInt((sHeight-400)/2)+", scrollbars, resizable");
	oWindow.focus();
}

/**
 * Search form
 */
CMS.SearchForm = Class.create();
CMS.SearchForm.prototype = {
    initialize: function(form, field, fieldSubmit, emptyText){
        this.form = $(form);
        this.buttonSubmit = $(fieldSubmit);
        this.field = $(field);
        this.emptyText = emptyText;
        
        Event.observe(this.form, 'submit', this.submit.bind(this));
        Event.observe(this.buttonSubmit, 'click', this.click.bind(this));
        Event.observe(this.field, 'focus', this.focus.bind(this));
        Event.observe(this.field, 'blur', this.blur.bind(this));
        this.blur();
    },
    
    submit: function(event){
        if (this.field.value == this.emptyText || this.field.value == '') {
            Event.stop(event);
            return false;
        }
        return true;
    },
    
    click: function(event){
        if (this.submit(event) && !this.form.action.blank()) 
            this.form.submit();
    },
    
    focus: function(event){
        if (this.field.value == this.emptyText) {
            this.field.value = '';
        }
        
    },
    
    blur: function(event){
        if (this.field.value == '') {
            this.field.value = this.emptyText;
        }
    }
}

/**
 * Decorate anchors
 */
CMS.DecorateAnchors = Class.create({

	initialize: function(content){
        
		var anchors = $(content).select("a");
		anchors.each(function(anchor) {
			
			if(/^.*\.(doc|docx)$/.test(anchor.getAttribute("href")) == true) {
				anchor.addClassName("anchor_word");
			}
			
			if(/^.*\.(xls|xlsx)$/.test(anchor.getAttribute("href")) == true) {
				anchor.addClassName("anchor_excel");
			}
			
			if(/^.*\.(ppt|pptx)$/.test(anchor.getAttribute("href")) == true) {
				anchor.addClassName("anchor_powerpoint");
			}
			
			if(/^.*\.pdf$/.test(anchor.getAttribute("href")) == true) {
				anchor.addClassName("anchor_pdf");
			}
		});
    }
});

/**
 * Print
 */
CMS.print = function(iTimeout){
	if(window.print) {
		setTimeout(function() {
			window.print();
		}, iTimeout);
	}
}

/**
 * Resize image containers
 */
CMS.resizeImageContainers = function(className) {
	
	var documentBody = Element.extend(document.getElementsByTagName("body")[0]);
	var divs  = documentBody.select("." + className);
	
	divs.each(function(div) {
		var img = div.select("img").first();
		div.setStyle({'width': img.getWidth() + 'px'});
	});
}

/**
 * Patronate
 */
CMS.patronate = Class.create({
	initialize: function(id){
		this.intervalTime = 20;
		
		this.patronate = $(id);
		this.list = this.patronate.select('ul').first();
		this.elements = this.patronate.select('li');
		
		this.widthElements = new Array();
		this.heightElements = new Array();
		for(i = 0; i < this.elements.size(); i++) {
			this.widthElements.push(this.elements[i].getWidth());
			this.heightElements.push(this.elements[i].getHeight());
		}
		
		var width = 0;
		var marginLeft = 0;
		var marginRight = 0;
		for(i = 0; i < this.elements.size(); i++) {
			this.elements[i].writeAttribute('index', i);
			this.elements[i].absolutize();
			
			marginLeft = parseInt(this.elements[i].getStyle("margin-left"));
			marginRight = parseInt(this.elements[i].getStyle("margin-right"));
			
			this.elements[i].setStyle({'left' : width + 'px', 'width' : this.widthElements[i] + 'px', 'height' : this.heightElements[i] + 'px'});
			width += this.widthElements[i] + marginLeft + marginRight;			
		}
		this.width = width;
		
		Event.observe(this.patronate, 'mouseover', this.stop.bindAsEventListener(this));
		Event.observe(this.patronate, 'mouseout', this.start.bindAsEventListener(this));
		
		this.start();
	},
	start: function() {
		
		this.intervalId = setInterval(function() {
			var elementsLength = this.elements.size();
			for(index = 0; index < elementsLength; index++) {
				
				var element = this.elements[index];
				var left = parseInt(element.getStyle('left'));
				
				if((left * -1) >= element.getWidth()) {
					element.setStyle({'left' : (this.width - element.getWidth()) + "px"});
				} else {
					element.setStyle({'left': (left - 1) + "px" });
				}
			}
			
		}.bind(this), this.intervalTime);
	},
	stop: function() {
		clearInterval(this.intervalId);
	}
});

CMS.linksBoxes = function(urls) {
	
	var elements = $('boxes').select('li');
	
	elements.each(function(item, index) {
		Event.observe(item, 'click', function(event) {
			document.location.href = urls[index];
		});
	});
	
};

/**
 * Promotion
 */
CMS.promotion = Class.create({
	initialize: function(id, elements){
		this.id = id;
		this.elements = elements;
		this.index = 0;
		this.intervalTime = 3500;
	},
	start: function() {
		
		this.intervalId = setInterval(function() {
			var container = $(this.id);
			
			this.index = (this.index+1) % this.elements.size();
			
			container.hide();
			
			container.update(this.elements[this.index].message);
			
			container.show();
		}.bind(this), this.intervalTime);
		
	}
});
