function swfUploadLoaded() {
	var formSubmitButton		=	document.getElementById("submit_resource");
	formSubmitButton.onclick	=	submitForm;
}


function enterDescriptionConfirm(errCount, numFiles){
	
	var msg	=	"You have not entered "+errCount+" descriptions for the "+numFiles+" resources you selected to upload.";
	msg		+=	" Press Cancel to go back and enter descriptions for these files or press OK to continue without entering descriptions.";
	
	if(errCount>0)
	{
		if(confirm(msg))
		{
			return true;	
		}else{
			return false;	
		}
	}else{
		return true;	
	}
	
}

/*	VALIDATION FOR RESOURCE UPLOAD FORM		*/

function validation(numFiles){
	
	if(numFiles<1)
	{
		alert("Please select at least one image file to upload");
		return false;
	}
	else if(document.getElementById("name").value=='')
	{
		alert("Please enter your name");
		return false;
	}
	else if(document.getElementById("email").value=='')
	{
		alert("Please enter your email address");
		return false;
	}
	else if(!echeck(document.getElementById("email").value))
	{
		alert("Please enter a valid email address");
		return false;
	}
	else{
		return true;	
	}
	
}

//SUBMIT FORM FUNCTIONS

function submitForm(){
	
	var errCount	=	0;
	var numFiles	=	document.getElementById("filesQueued").value;
	
	// DESCRIPTION VALIDATION
	for(i=0; i<numFiles; i++)
	{
		if(document.getElementById("description_"+i).value=='')
		{
			errCount++;	
		}
	}
	
	// VALIDATE FORM INPUTS
	if(validation(numFiles))
	{
		
		// VALIDATE IMAGE DESCRIPTIONS
		if(enterDescriptionConfirm(errCount, numFiles))
		{
			
			document.getElementById("submit_resource").disabled	=	true;
	
			try {
				swfu.startUpload();
			} catch (ex)  {
				swfu.debug(ex);
			}
		
		}
		
	}
	
	return false;
}

// ADD AN ELEMENT DYNAMICALLY

function addElement(parentId, elementTag, html) {
    // Adds an element to the document
    var p 				 = document.getElementById(parentId);
    var newElement 		 = document.createElement(elementTag);
    newElement.innerHTML = html;
	newElement.setAttribute('class', 'row');
    p.appendChild(newElement);
}





/* This is an example of how to cancel all the files queued up.  It's made somewhat generic.  Just pass your SWFUpload
object in to this method and it loops through cancelling the uploads. */
function cancelQueue(instance) {
	document.getElementById(instance.customSettings.cancelButtonId).disabled = true;
	instance.stopUpload();
	var stats;
	
	do {
		stats = instance.getStats();
		instance.cancelUpload();
	} while (stats.files_queued !== 0);
	
}

/* **********************
   Event Handlers
   These are my custom event handlers to make my
   web application behave the way I went when SWFUpload
   completes different tasks.  These aren't part of the SWFUpload
   package.  They are part of my application.  Without these none
   of the actions SWFUpload makes will show up in my application.
   ********************** */
function fileDialogStart() {
	/* I don't need to do anything here */
}
function fileQueued(file) {
	try {
		// You might include code here that prevents the form from being submitted while the upload is in
		// progress.  Then you'll want to put code in the Queue Complete handler to "unblock" the form
		var progress = new FileProgress(file, this.customSettings.progressTarget);
		progress.setStatus("Pending...");
		progress.toggleCancel(true, this);

	} catch (ex) {
		this.debug(ex);
	}

}

function fileQueueError(file, errorCode, message) {
	try {
		if (errorCode === SWFUpload.QUEUE_ERROR.QUEUE_LIMIT_EXCEEDED) {
			alert("You have attempted to queue too many files.\n" + (message === 0 ? "You have reached the upload limit." : "You may select " + (message > 1 ? "up to " + message + " files." : "one file.")));
			return;
		}

		var progress = new FileProgress(file, this.customSettings.progressTarget);
		progress.setError();
		progress.toggleCancel(false);

		switch (errorCode) {
		case SWFUpload.QUEUE_ERROR.FILE_EXCEEDS_SIZE_LIMIT:
			progress.setStatus("File is too big.");
			this.debug("Error Code: File too big, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
			break;
		case SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE:
			progress.setStatus("Cannot upload Zero Byte files.");
			this.debug("Error Code: Zero byte file, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
			break;
		case SWFUpload.QUEUE_ERROR.INVALID_FILETYPE:
			progress.setStatus("Invalid File Type.");
			this.debug("Error Code: Invalid File Type, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
			break;
		case SWFUpload.QUEUE_ERROR.QUEUE_LIMIT_EXCEEDED:
			alert("You have selected too many files.  " +  (message > 1 ? "You may only add " +  message + " more files" : "You cannot add any more files."));
			break;
		default:
			if (file !== null) {
				progress.setStatus("Unhandled Error");
			}
			this.debug("Error Code: " + errorCode + ", File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
			break;
		}
	} catch (ex) {
        this.debug(ex);
    }
}

function fileDialogComplete(numFilesSelected, numFilesQueued) {
	
	// TOTAL FILES QUED SO FAR (PREVIOUSLY QUEUED AND QUEUED THIS TIME)
	var totalFilesQueued							=	parseInt(document.getElementById("filesQueued").value)+parseInt(numFilesQueued);
	
	// UPDATE HIDDEN VAR CONTAINING NUMBER OF FILES QUEUED
	document.getElementById("filesQueued").value	=	totalFilesQueued;
	
	// REMOVE (RESET) WHATEVER'S IN THE FILE DESCRIPTIONS DIV
	document.getElementById("fileDescriptions").innerHTML='';
	
	//CREATE A DECRIPTION INPUT BOX FOR EACH FILE SELECTED
	for(i=0; i<totalFilesQueued; i++)
	{
		var n	=	i+1;
		var html	=	'<label for="description_'+i+'">Description for resource '+n+'</label>';
			html	+=	'<textarea id="description_'+i+'" name="description_'+i+'" rows="3" class="textarea"></textarea>';
		addElement("fileDescriptions", "div", html);	
	}
	
	
	
	
	/*
	
	try {
		if (this.getStats().files_queued > 0) {
			document.getElementById(this.customSettings.cancelButtonId).disabled = false;
		}
		
		// I want auto start and I can do that here
		this.startUpload();
	} catch (ex)  {
        this.debug(ex);
	}
	*/
}

function uploadStart(file) {
	try {
		/* I don't want to do any file validation or anything,  I'll just update the UI and return true to indicate that the upload should start */
		var progress = new FileProgress(file, this.customSettings.progressTarget);
		progress.setStatus("Uploading...");
		progress.toggleCancel(true, this);
	}
	catch (ex) {
	}
	
	return true;
}

function uploadProgress(file, bytesLoaded, bytesTotal) {

	try {
		var percent = Math.ceil((bytesLoaded / bytesTotal) * 100);

		var progress = new FileProgress(file, this.customSettings.progressTarget);
		progress.setProgress(percent);
		progress.setStatus("Uploading...");
	} catch (ex) {
		this.debug(ex);
	}
}

function uploadSuccess(file, serverData) {
	try {
		var progress = new FileProgress(file, this.customSettings.progressTarget);
		progress.setComplete();
		progress.setStatus("Complete.");
		progress.toggleCancel(false);
		
		//UPDATE THE HIDDEN FORM VALUE THAT CONTAINS THE FILENAMES
		document.getElementById("fileList").value+=file.name+",";

	} catch (ex) {
		this.debug(ex);
	}
}

function uploadComplete(file) {
	
	try {
		/*  I want the next upload to continue automatically so I'll call startUpload here */
		if (this.getStats().files_queued === 0) {
			
			// IF ALL FILES HAVE BEEN UPLOADED, SUBMIT THE FORM ITSELF
			document.upload_resources.submit();
			
		} else {	
			this.startUpload();
		}
	} catch (ex) {
		this.debug(ex);
	}

}

function uploadError(file, errorCode, message) {
	try {
		var progress = new FileProgress(file, this.customSettings.progressTarget);
		progress.setError();
		progress.toggleCancel(false);

		switch (errorCode) {
		case SWFUpload.UPLOAD_ERROR.HTTP_ERROR:
			progress.setStatus("Upload Error: " + message);
			this.debug("Error Code: HTTP Error, File name: " + file.name + ", Message: " + message);
			break;
		case SWFUpload.UPLOAD_ERROR.MISSING_UPLOAD_URL:
			progress.setStatus("Configuration Error");
			this.debug("Error Code: No backend file, File name: " + file.name + ", Message: " + message);
			break;
		case SWFUpload.UPLOAD_ERROR.UPLOAD_FAILED:
			progress.setStatus("Upload Failed.");
			this.debug("Error Code: Upload Failed, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
			break;
		case SWFUpload.UPLOAD_ERROR.IO_ERROR:
			progress.setStatus("Server (IO) Error");
			this.debug("Error Code: IO Error, File name: " + file.name + ", Message: " + message);
			break;
		case SWFUpload.UPLOAD_ERROR.SECURITY_ERROR:
			progress.setStatus("Security Error");
			this.debug("Error Code: Security Error, File name: " + file.name + ", Message: " + message);
			break;
		case SWFUpload.UPLOAD_ERROR.UPLOAD_LIMIT_EXCEEDED:
			progress.setStatus("Upload limit exceeded.");
			this.debug("Error Code: Upload Limit Exceeded, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
			break;
		case SWFUpload.UPLOAD_ERROR.SPECIFIED_FILE_ID_NOT_FOUND:
			progress.setStatus("File not found.");
			this.debug("Error Code: The file was not found, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
			break;
		case SWFUpload.UPLOAD_ERROR.FILE_VALIDATION_FAILED:
			progress.setStatus("Failed Validation.  Upload skipped.");
			this.debug("Error Code: File Validation Failed, File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
			break;
		case SWFUpload.UPLOAD_ERROR.FILE_CANCELLED:
			if (this.getStats().files_queued === 0) {
				document.getElementById(this.customSettings.cancelButtonId).disabled = true;
			}
			progress.setStatus("Cancelled");
			progress.setCancelled();
			break;
		case SWFUpload.UPLOAD_ERROR.UPLOAD_STOPPED:
			progress.setStatus("Stopped");
			break;
		default:
			progress.setStatus("Unhandled Error: " + error_code);
			this.debug("Error Code: " + errorCode + ", File name: " + file.name + ", File size: " + file.size + ", Message: " + message);
			break;
		}
	} catch (ex) {
        this.debug(ex);
    }
}



function echeck(str) {

	var at="@"
	var dot="."
	var lat=str.indexOf(at)
	var lstr=str.length
	var ldot=str.indexOf(dot)
	if (str.indexOf(at)==-1){
	   return false
	}

	if (str.indexOf(at)==-1 || str.indexOf(at)==0 || str.indexOf(at)==lstr){
	   return false
	}

	if (str.indexOf(dot)==-1 || str.indexOf(dot)==0 || str.indexOf(dot)==lstr){
		return false
	}

	 if (str.indexOf(at,(lat+1))!=-1){
		return false
	 }

	 if (str.substring(lat-1,lat)==dot || str.substring(lat+1,lat+2)==dot){
		return false
	 }

	 if (str.indexOf(dot,(lat+2))==-1){
		return false
	 }
	
	 if (str.indexOf(" ")!=-1){
		return false
	 }

	 return true					
}