/**
 * Flash (http://jquery.lukelutman.com/plugins/flash)
 * A jQuery plugin for embedding Flash movies.
 * 
 * Version 1.0
 * November 9th, 2006
 *
 * Copyright (c) 2006 Luke Lutman (http://www.lukelutman.com)
 * Dual licensed under the MIT and GPL licenses.
 * http://www.opensource.org/licenses/mit-license.php
 * http://www.opensource.org/licenses/gpl-license.php
 * 
 * Inspired by:
 * SWFObject (http://blog.deconcept.com/swfobject/)
 * UFO (http://www.bobbyvandersluis.com/ufo/)
 * sIFR (http://www.mikeindustries.com/sifr/)
 * 
 * IMPORTANT: 
 * The packed version of jQuery breaks ActiveX control
 * activation in Internet Explorer. Use JSMin to minifiy
 * jQuery (see: http://jquery.lukelutman.com/plugins/flash#activex).
 *
 **/ 
;(function(){
	
var $$;

/**
 * 
 * @desc Replace matching elements with a flash movie.
 * @author Luke Lutman
 * @version 1.0.1
 *
 * @name flash
 * @param Hash htmlOptions Options for the embed/object tag.
 * @param Hash pluginOptions Options for detecting/updating the Flash plugin (optional).
 * @param Function replace Custom block called for each matched element if flash is installed (optional).
 * @param Function update Custom block called for each matched if flash isn't installed (optional).
 * @type jQuery
 *
 * @cat plugins/flash
 * 
 * @example $('#hello').flash({ src: 'hello.swf' });
 * @desc Embed a Flash movie.
 *
 * @example $('#hello').flash({ src: 'hello.swf' }, { version: 8 });
 * @desc Embed a Flash 8 movie.
 *
 * @example $('#hello').flash({ src: 'hello.swf' }, { expressInstall: true });
 * @desc Embed a Flash movie using Express Install if flash isn't installed.
 *
 * @example $('#hello').flash({ src: 'hello.swf' }, { update: false });
 * @desc Embed a Flash movie, don't show an update message if Flash isn't installed.
 *
**/
$$ = jQuery.fn.flash = function(htmlOptions, pluginOptions, replace, update) {
	
	// Set the default block.
	var block = replace || $$.replace;
	
	// Merge the default and passed plugin options.
	pluginOptions = $$.copy($$.pluginOptions, pluginOptions);
	
	// Detect Flash.
	if(!$$.hasFlash(pluginOptions.version)) {
		// Use Express Install (if specified and Flash plugin 6,0,65 or higher is installed).
		if(pluginOptions.expressInstall && $$.hasFlash(6,0,65)) {
			// Add the necessary flashvars (merged later).
			var expressInstallOptions = {
				flashvars: {  	
					MMredirectURL: location,
					MMplayerType: 'PlugIn',
					MMdoctitle: jQuery('title').text() 
				}					
			};
		// Ask the user to update (if specified).
		} else if (pluginOptions.update) {
			// Change the block to insert the update message instead of the flash movie.
			block = update || $$.update;
		// Fail
		} else {
			// The required version of flash isn't installed.
			// Express Install is turned off, or flash 6,0,65 isn't installed.
			// Update is turned off.
			// Return without doing anything.
			return this;
		}
	}
	
	// Merge the default, express install and passed html options.
	htmlOptions = $$.copy($$.htmlOptions, expressInstallOptions, htmlOptions);
	
	// Invoke $block (with a copy of the merged html options) for each element.
	return this.each(function(){
		block.call(this, $$.copy(htmlOptions));
	});
	
};
/**
 *
 * @name flash.copy
 * @desc Copy an arbitrary number of objects into a new object.
 * @type Object
 * 
 * @example $$.copy({ foo: 1 }, { bar: 2 });
 * @result { foo: 1, bar: 2 };
 *
**/
$$.copy = function() {
	var options = {}, flashvars = {};
	for(var i = 0; i < arguments.length; i++) {
		var arg = arguments[i];
		if(arg == undefined) continue;
		jQuery.extend(options, arg);
		// don't clobber one flash vars object with another
		// merge them instead
		if(arg.flashvars == undefined) continue;
		jQuery.extend(flashvars, arg.flashvars);
	}
	options.flashvars = flashvars;
	return options;
};
/*
 * @name flash.hasFlash
 * @desc Check if a specific version of the Flash plugin is installed
 * @type Boolean
 *
**/
$$.hasFlash = function() {
	// look for a flag in the query string to bypass flash detection
	if(/hasFlash\=true/.test(location)) return true;
	if(/hasFlash\=false/.test(location)) return false;
	var pv = $$.hasFlash.playerVersion().match(/\d+/g);
	var rv = String([arguments[0], arguments[1], arguments[2]]).match(/\d+/g) || String($$.pluginOptions.version).match(/\d+/g);
	for(var i = 0; i < 3; i++) {
		pv[i] = parseInt(pv[i] || 0);
		rv[i] = parseInt(rv[i] || 0);
		// player is less than required
		if(pv[i] < rv[i]) return false;
		// player is greater than required
		if(pv[i] > rv[i]) return true;
	}
	// major version, minor version and revision match exactly
	return true;
};
/**
 *
 * @name flash.hasFlash.playerVersion
 * @desc Get the version of the installed Flash plugin.
 * @type String
 *
**/
$$.hasFlash.playerVersion = function() {
	// ie
	try {
		try {
			// avoid fp6 minor version lookup issues
			// see: http://blog.deconcept.com/2006/01/11/getvariable-setvariable-crash-internet-explorer-flash-6/
			var axo = new ActiveXObject('ShockwaveFlash.ShockwaveFlash.6');
			try { axo.AllowScriptAccess = 'always';	} 
			catch(e) { return '6,0,0'; }				
		} catch(e) {}
		return new ActiveXObject('ShockwaveFlash.ShockwaveFlash').GetVariable('$version').replace(/\D+/g, ',').match(/^,?(.+),?$/)[1];
	// other browsers
	} catch(e) {
		try {
			if(navigator.mimeTypes["application/x-shockwave-flash"].enabledPlugin){
				return (navigator.plugins["Shockwave Flash 2.0"] || navigator.plugins["Shockwave Flash"]).description.replace(/\D+/g, ",").match(/^,?(.+),?$/)[1];
			}
		} catch(e) {}		
	}
	return '0,0,0';
};
/**
 *
 * @name flash.htmlOptions
 * @desc The default set of options for the object or embed tag.
 *
**/
$$.htmlOptions = {
	height: 240,
	flashvars: {},
	pluginspage: 'http://www.adobe.com/go/getflashplayer',
	src: '#',
	type: 'application/x-shockwave-flash',
	width: 320		
};
/**
 *
 * @name flash.pluginOptions
 * @desc The default set of options for checking/updating the flash Plugin.
 *
**/
$$.pluginOptions = {
	expressInstall: false,
	update: true,
	version: '6.0.65'
};
/**
 *
 * @name flash.replace
 * @desc The default method for replacing an element with a Flash movie.
 *
**/
$$.replace = function(htmlOptions) {
	this.innerHTML = '<div class="alt">'+this.innerHTML+'</div>';
	jQuery(this)
		.addClass('flash-replaced')
		.prepend($$.transform(htmlOptions));
};
/**
 *
 * @name flash.update
 * @desc The default method for replacing an element with an update message.
 *
**/
$$.update = function(htmlOptions) {
	var url = String(location).split('?');
	url.splice(1,0,'?hasFlash=true&');
	url = url.join('');
	var msg = '<p>This content requires the Flash Player. <a href="http://www.adobe.com/go/getflashplayer">Download Flash Player</a>. Already have Flash Player? <a href="'+url+'">Click here.</a></p>';
	this.innerHTML = '<span class="alt">'+this.innerHTML+'</span>';
	jQuery(this)
		.addClass('flash-update')
		.prepend(msg);
};
/**
 *
 * @desc Convert a hash of html options to a string of attributes, using Function.apply(). 
 * @example toAttributeString.apply(htmlOptions)
 * @result foo="bar" foo="bar"
 *
**/
function toAttributeString() {
	var s = '';
	for(var key in this)
		if(typeof this[key] != 'function')
			s += key+'="'+this[key]+'" ';
	return s;		
};
/**
 *
 * @desc Convert a hash of flashvars to a url-encoded string, using Function.apply(). 
 * @example toFlashvarsString.apply(flashvarsObject)
 * @result foo=bar&foo=bar
 *
**/
function toFlashvarsString() {
	var s = '';
	for(var key in this)
		if(typeof this[key] != 'function')
			s += key+'='+encodeURIComponent(this[key])+'&';
	return s.replace(/&$/, '');		
};
/**
 *
 * @name flash.transform
 * @desc Transform a set of html options into an embed tag.
 * @type String 
 *
 * @example $$.transform(htmlOptions)
 * @result <embed src="foo.swf" ... />
 *
 * Note: The embed tag is NOT standards-compliant, but it 
 * works in all current browsers. flash.transform can be
 * overwritten with a custom function to generate more 
 * standards-compliant markup.
 *
**/
$$.transform = function(htmlOptions) {
	htmlOptions.toString = toAttributeString;
	if(htmlOptions.flashvars) htmlOptions.flashvars.toString = toFlashvarsString;
	return '<embed ' + String(htmlOptions) + '/>';		
};

/**
 *
 * Flash Player 9 Fix (http://blog.deconcept.com/2006/07/28/swfobject-143-released/)
 *
**/
if (window.attachEvent) {
	window.attachEvent("onbeforeunload", function(){
		__flash_unloadHandler = function() {};
		__flash_savedUnloadHandler = function() {};
	});
}
	
})();




















$(document).ready(function()
{
	if($.browser.msie)
	{


		$('ul#portfolio-categories').each(function(){
		
			var nwidth = $(this).find('img').size() * 400;
			$(this).css('width', nwidth );
			
		});
		
		$('ul#portfolio-categories li').each(function(){
			$(this).css('float','left');								   
		});

		$('ul.fotoserie').each(function(){
		
			var nwidth = $(this).find('img').size() * 700;
			$(this).css('width', nwidth );
			
		});
		
		$('ul.fotoserie li').each(function(){
			$(this).css('float','left');								   
		});

	}
	
	
	$('ol.portfolio-categorie li:first').show().addClass('currentCategory');


	$('ol.portfolio-categorie').each(function(){
	
		// show menu for follow up projects
		var countprojects = $('ol.portfolio-categorie li.project').size();
		
		if(countprojects > 1 )
		{
			$('#page').append('<div id="category-nav"><span>PAGINA</span></div>');			
			//$('#category-nav').append('<a id="prev" href="#">&lt;</a>');
		
			for (var i = 0; i < countprojects; i++) {
				j = i+1;
				var ttarget = $('ol.portfolio-categorie li.project').eq(i).attr('id');
				$('#category-nav').append('<a class="project" href="#'+ttarget+'" rel="'+ttarget+'">'+j+'</a>');
			
			}
			//$('#category-nav').append('<a id="next" href="#">&gt;</a>');
			
			$('#category-nav a.project:first').addClass('current');
			
			
			$('#category-nav a.project').click(function(event){
				event.preventDefault();
				$('#category-nav a').removeClass('current');
				$(this).addClass('current');
				//alert( $(this).attr('rel') );
				var rel=$(this).attr('rel');
				$('ol.portfolio-categorie li.project').hide().removeClass('currentCategory');
				$('ol.portfolio-categorie li#'+rel).show().addClass('currentCategory');
				
			});
			
			$('#category-nav a#prev').click(function(event){
				event.preventDefault();
				
				var countprojects = $('ol.portfolio-categorie li.project').size();
				var currentIndex = 0;
				for (var i = 0; i < countprojects; i++) {
					if( $('ol.portfolio-categorie li.project').eq(i).hasClass('currentCategory'))
					{
					currentIndex = i;					
					}
				}
				
				if (currentIndex > 0)
				{
					var newIndex = currentIndex - 1;
					$('#category-nav a').removeClass('current');
					$('ol.portfolio-categorie li.project').hide().removeClass('currentCategory');
					
					$('ol.portfolio-categorie li.project').eq(newIndex).show().addClass('currentCategory');
					$('#category-nav a.project').eq(newIndex).addClass('current');
				}

				
				
			});
			
			$('#category-nav a#next').click(function(event){
				event.preventDefault();
				var countprojects = $('ol.portfolio-categorie li.project').size();
				var currentIndex = 0;
				for (var i = 0; i < countprojects; i++) {
					if( $('ol.portfolio-categorie li.project').eq(i).hasClass('currentCategory'))
					{
					currentIndex = i;					
					}
				}
				
				if (currentIndex < countprojects -1)
				{
					var newIndex = currentIndex +1;
					$('#category-nav a').removeClass('current');
					$('ol.portfolio-categorie li.project').hide().removeClass('currentCategory');
					
					$('ol.portfolio-categorie li.project').eq(newIndex).show().addClass('currentCategory');
					$('#category-nav a.project').eq(newIndex).addClass('current');
				}
			});
		
		
		}
												 
	});
	
	if(document.location.hash)
	{
//		alert(document.location.hash);
				$('#category-nav a').removeClass('current');
			
				var rel = document.location.hash.replace('#','');
				
				$('#category-nav a[rel='+rel+']').addClass('current');
				
				
				$('ol.portfolio-categorie li.project').hide().removeClass('currentCategory');
				$('ol.portfolio-categorie li'+document.location.hash).show().addClass('currentCategory');
	}
	
	
	$('#flash-filmpje-home').flash({
    src: '/afbeeldingen/SWF/090614_962x380.swf',
    width: 962,
    height: 380
	});

	
	
	/*
	
			// finally to satisfy iE6 users, simulate the table and table-cell css by calculating the width of the parent and setting it.

	$('ul#portfolio-categories').each(function(){
											   
		$(this).css('display','block');
		$(this).css('overflow','hidden');						
		
		var pwidth=0;
		$(this).find('img').each(function(){
			pwidth = pwidth + $(this).width() + 30;					  
		});
		$(this).width(pwidth);

											   
		$(this).find('li').css('float','left');
		$(this).find('li').css('display', 'block');

		//alert(pwidth);
	});

	//, ul.fotoserie the same thing 
	$('ul.fotoserie').each(function(){

		$(this).css('display','block');
		$(this).css('overflow','hidden');						

		var pwidth=0;
		$(this).find('img').each(function(){
			pwidth = pwidth + $(this).width() + 30;					  
		});
		$(this).width(pwidth);
		//alert(pwidth);


		$(this).find('li').css('float','left');
		$(this).find('li').css('display', 'block');
	});
	
	
	*/
	

});

