Skip to content
Snippets Groups Projects
files.js 11.4 KiB
Newer Older
  • Learn to ignore specific revisions
  • 	$('#file_action_panel').attr('activeAction', false);
    
    
    	//drag/drop of files
    	$('#fileList tr td.filename').draggable(dragOptions);
    	$('#fileList tr[data-type="dir"] td.filename').droppable(folderDropOptions);
    
    Robin Appelman's avatar
    Robin Appelman committed
    	$('div.crumb').droppable(crumbDropOptions);
    	$('#plugins>ul>li:first-child').droppable(crumbDropOptions);
    
    	// Sets the file-action buttons behaviour :
    
    	$('tr').live('mouseenter',function(event) {
    		FileActions.display($(this).children('td.filename'));
    
    	$('tr').live('mouseleave',function(event) {
    		FileActions.hide();
    	});
    
    
    	// Sets the file link behaviour :
    
    	$('td.filename a').live('click',function(event) {
    
    		event.preventDefault();
    
    Robin Appelman's avatar
    Robin Appelman committed
    		var filename=$(this).parent().parent().data('file');
    
    Robin Appelman's avatar
    Robin Appelman committed
    			var mime=$(this).parent().parent().data('mime');
    			var type=$(this).parent().parent().data('type');
    
    			var action=FileActions.getDefault(mime,type);
    			if(action){
    				action(filename);
    			}
    
    	// Sets the select_all checkbox behaviour :
    	$('#select_all').click(function() {
    
    		if($(this).attr('checked')){
    
    			$('td.filename input:checkbox').attr('checked', true);
    			$('td.filename input:checkbox').parent().parent().addClass('selected');
    
    			$('td.filename input:checkbox').attr('checked', false);
    			$('td.filename input:checkbox').parent().parent().removeClass('selected');
    
    		procesSelection();
    
    	$('td.filename input:checkbox').live('click',function() {
    		var selectedCount=$('td.filename input:checkbox:checked').length;
    
    		$(this).parent().parent().toggleClass('selected');
    
    		if(!$(this).attr('checked')){
    			$('#select_all').attr('checked',false);
    		}else{
    
    			if(selectedCount==$('td.filename input:checkbox').length){
    
    				$('#select_all').attr('checked',true);
    			}
    		}
    
    		procesSelection();
    
    	$('#file_newfolder_form').submit(function(event) {
    		event.preventDefault();
    
    		$.ajax({
    			url: 'ajax/newfolder.php',
    
    			data: "dir="+$('#dir').val()+"&foldername="+$('#file_newfolder_name').val(),
    
    			complete: function(data){boolOperationFinished(data, function(){
    				var date=formatDate(new Date());
    				FileList.addDir($('#file_newfolder_name').val(),'0 B',date)
    			});}
    
    		$('#file_newfolder_submit').fadeOut(250).trigger('vanish');
    
    	$('#file_newfolder_name').click(function(){
    		if($('#file_newfolder_name').val() == 'New Folder'){
    			$('#file_newfolder_name').val('');
    		}
    	});
    	
    	$('#file_newfolder_name').bind('keyup', adjustNewFolderSize);
    	
    	$('#file_newfolder_submit').bind('vanish', function() {
    		$('#file_newfolder_name').bind('keyup', adjustNewFolderSize);
    		unsplitSize($('#file_newfolder_name'),$('#file_newfolder_submit'));
    	});
    	
    	$('#file_newfolder_name').focusout(function(){
    		if($('#file_newfolder_name').val() == '') {
    			$('#file_newfolder_form')[0].reset();
    			$('#file_newfolder_submit').fadeOut(250).trigger('vanish');
    		}
    	});
    	
    
    	$('.download').click('click',function(event) {
    
    		var files=getSelectedFiles('name').join(';');
    
    		
    		//send the browser to the download location
    		var dir=$('#dir').val()||'/';
    // 		alert(files);
    
    		window.location='ajax/download.php?files='+encodeURIComponent(files)+'&dir='+encodeURIComponent(dir);
    
    		return false;
    	});
    
    	$('.delete').click(function(event) {
    
    		var files=getSelectedFiles('name').join(';');
    
    		
    		$.ajax({
    			url: 'ajax/delete.php',
    
    			data: "dir="+$('#dir').val()+"&files="+encodeURIComponent(files),
    
    			complete: function(data){
    
    				boolOperationFinished(data, function(){
    
    					var files=getSelectedFiles('name');
    					for(var i=0;i<files.length;i++){
    						FileList.remove(files[i]);
    					}
    					procesSelection();
    
    	$('.file_upload_start').live('change',function(){
    		var form=$(this).parent().parent();
    		var uploadId=form.attr('data-upload-id');
    		var files=this.files;
    		var target=form.children('iframe');
    
    		var totalSize=0;
    		for(var i=0;i<files.length;i++){
    			totalSize+=files[i].size;
    		}
    		if(totalSize>$('#max_upload').val()){
    			$( "#uploadsize-message" ).dialog({
    				modal: true,
    				buttons: {
    					Close: function() {
    						$( this ).dialog( "close" );
    
    			});
    		}else{
    			target.load(function(){
    				var response=jQuery.parseJSON(target.contents().find('body').text());
    				//set mimetype and if needed filesize
    				if(response){
    					for(var i=0;i<response.length;i++){
    						var file=response[i];
    
    Robin Appelman's avatar
    Robin Appelman committed
    						$('tr[data-file="'+file.name+'"]').data('mime',file.mime);
    
    						if(size=='Pending'){
    							$('tr[data-file='+file.name+'] td.filesize').text(file.size);
    						}
    						FileList.loadingDone(file.name);
    					}
    				}
    			});
    			form.submit();
    			var date=new Date();
    			var uploadTime=formatDate(date);
    			for(var i=0;i<files.length;i++){
    				if(files[i].size>0){
    
    					var size=files[i].size;
    
    				}else{
    					var size='Pending';
    				}
    				FileList.addFile(files[i].name,size,uploadTime,true);
    
    
    			//clone the upload form and hide the new one to allow users to start a new upload while the old one is still uploading
    			var clone=form.clone();
    			uploadId++;
    			clone.attr('data-upload-id',uploadId);
    			clone.attr('target','file_upload_target_'+uploadId);
    			clone.children('iframe').attr('name','file_upload_target_'+uploadId)
    			clone.insertBefore(form);
    			form.hide();
    
    	
    	//add multiply file upload attribute to all browsers except konqueror (which crashes when it's used)
    	if(navigator.userAgent.search(/konqueror/i)==-1){
    
    		$('.file_upload_start').attr('multiple','multiple')
    
    
    	//if the breadcrumb is to long, start by replacing foldernames with '...' except for the current folder
    	var crumb=$('div.crumb').first();
    	while($('div.controls').height()>40 && crumb.next('div.crumb').length>0){
    		crumb.children('a').text('...');
    		crumb=crumb.next('div.crumb');
    	}
    	//if that isn't enough, start removing items from the breacrumb except for the current folder and it's parent
    	var crumb=$('div.crumb').first();
    	var next=crumb.next('div.crumb');
    	while($('div.controls').height()>40 && next.next('div.crumb').length>0){
    		crumb.remove();
    		crumb=next;
    		next=crumb.next('div.crumb');
    	}
    	//still not enough, start shorting down the current folder name
    	var crumb=$('div.crumb>a').last();
    	while($('div.controls').height()>40 && crumb.text().length>6){
    		var text=crumb.text()
    		text=text.substr(0,text.length-6)+'...';
    		crumb.text(text);
    	}
    
    var adjustNewFolderSize = function() {
    	if($('#file_newfolder_name').val() != '') {
    		splitSize($('#file_newfolder_name'),$('#file_newfolder_submit'));
    		$('#file_newfolder_name').unbind('keyup', adjustNewFolderSize);
    	};
    }
    
    function splitSize(existingEl, appearingEl) {
    	nw = parseInt($(existingEl).css('width')) - parseInt($(appearingEl).css('width'));
    	$(existingEl).css('width', nw + 'px');
    	$(appearingEl).fadeIn(250);
    }
    
    function unsplitSize(stayingEl, vanishingEl) {
    	nw = parseInt($(stayingEl).css('width')) + parseInt($(vanishingEl).css('width'));
    	$(stayingEl).css('width', nw + 'px');
    	$(vanishingEl).fadeOut(250);
    }
    
    
    function resetFileActionPanel() {
    	$('#file_action_panel form').css({"display":"none"});
    	$('#file_action_panel').attr('activeAction', false);
    }
    
    
    function boolOperationFinished(data, callback) {
    	result = jQuery.parseJSON(data.responseText);
    
    	if(result.status == 'success'){
    
    	} else {
    		alert(result.data.message);
    	}
    }
    
    
    function updateBreadcrumb(breadcrumbHtml) {
    	$('p.nav').empty().html(breadcrumbHtml);
    }
    
    
    function humanFileSize(bytes){
    	if( bytes < 1024 ){
    		return bytes+' B';
    	}
    	bytes = Math.round(bytes / 1024, 1 );
    	if( bytes < 1024 ){
    		return bytes+' kB';
    	}
    	bytes = Math.round( bytes / 1024, 1 );
    	if( bytes < 1024 ){
    		return bytes+' MB';
    	}
    	
    	// Wow, heavy duty for owncloud
    	bytes = Math.round( bytes / 1024, 1 );
    	return bytes+' GB';
    
    	mbytes = Math.round(bytes/(1024*1024/10))/10;
    
    	if(bytes == 0) { return '0'; }
    	else if(mbytes < 0.1) { return '< 0.1'; }
    	else if(mbytes > 1000) { return '> 1000'; }
    	else { return mbytes.toFixed(1); }
    }
    
    
    function formatDate(date){
    	var monthNames = [ "January", "February", "March", "April", "May", "June",
    	"July", "August", "September", "October", "November", "December" ];
    	return monthNames[date.getMonth()]+' '+date.getDate()+', '+date.getFullYear()+', '+((date.getHours()<10)?'0':'')+date.getHours()+':'+date.getMinutes();
    
    	distance: 20, revert: 'invalid', opacity: 0.7,
    
    	stop: function(event, ui) {
    		$('#fileList tr td.filename').addClass('ui-draggable');
    	}
    };
    var folderDropOptions={
    	drop: function( event, ui ) {
    		var file=ui.draggable.text().trim();
    		var target=$(this).text().trim();
    		var dir=$('#dir').val();
    		$.ajax({
    			url: 'ajax/move.php',
    		data: "dir="+dir+"&file="+file+'&target='+dir+'/'+target,
    		complete: function(data){boolOperationFinished(data, function(){
    			var el=$('#fileList tr[data-file="'+file+'"] td.filename');
    			el.draggable('destroy');
    			FileList.remove(file);
    		});}
    		});
    	}
    
    Robin Appelman's avatar
    Robin Appelman committed
    var crumbDropOptions={
    	drop: function( event, ui ) {
    		var file=ui.draggable.text().trim();
    		var target=$(this).data('dir');
    		var dir=$('#dir').val();
    		while(dir.substr(0,1)=='/'){//remove extra leading /'s
    				dir=dir.substr(1);
    		}
    		dir='/'+dir;
    		if(dir.substr(-1,1)!='/'){
    			dir=dir+'/';
    		}
    		if(target==dir){
    			return;
    		}
    		$.ajax({
    			url: 'ajax/move.php',
    		 data: "dir="+dir+"&file="+file+'&target='+target,
    		 complete: function(data){boolOperationFinished(data, function(){
    			 FileList.remove(file);
    		 });}
    		});
    	},
    	tolerance: 'pointer'
    }
    
    
    function procesSelection(){
    
    Robin Appelman's avatar
    Robin Appelman committed
    	var selected=getSelectedFiles();
    	var selectedFiles=selected.filter(function(el){return el.type=='file'});
    	var selectedFolders=selected.filter(function(el){return el.type=='dir'});
    
    	if(selectedFiles.length==0 && selectedFolders.length==0){
    		$('#headerName>span.name').text('Name');
    
    		$('#headerSize').text('Size MB');
    
    		$('#modified').text('Modified');
    
    		$('th').css({background:'#fff',fontWeight:'normal'});
    
    		var totalSize=0;
    
    Robin Appelman's avatar
    Robin Appelman committed
    		for(var i=0;i<selectedFiles.length;i++){
    			totalSize+=selectedFiles[i].size;
    		};
    		for(var i=0;i<selectedFolders.length;i++){
    			totalSize+=selectedFolders[i].size;
    		};
    
    		simpleSize=simpleFileSize(totalSize);
    		$('#headerSize').text(simpleSize+' MB');
    		$('#headerSize').attr('title',humanFileSize(totalSize));
    
    		var selection='';
    
    		if(selectedFolders.length>0){
    			if(selectedFolders.length==1){
    				selection+='1 folder';
    
    				selection+=selectedFolders.length+' folders';
    
    			if(selectedFiles.length>0){
    				selection+=' & ';
    
    		if(selectedFiles.length>0){
    			if(selectedFiles.length==1){
    				selection+='1 file';
    
    				selection+=selectedFiles.length+' files';
    
    		$('#headerName>span.name').text(selection);
    
    		$('th').css({background:'#ddd', fontWeight:'bold'});
    
    /**
     * @brief get a list of selected files
     * @param string property (option) the property of the file requested
     * @return array
     *
    
    Robin Appelman's avatar
    Robin Appelman committed
     * possible values for property: name, mime, size and type
    
     * if property is set, an array with that property for each file is returnd
     * if it's ommited an array of objects with all properties is returned
     */
    function getSelectedFiles(property){
    
    Robin Appelman's avatar
    Robin Appelman committed
    	var elements=$('td.filename input:checkbox:checked').parent().parent();
    
    	var files=[];
    	elements.each(function(i,element){
    		var file={
    
    Robin Appelman's avatar
    Robin Appelman committed
    			name:$(element).data('file'),
    			mime:$(element).data('mime'),
    			type:$(element).data('type'),
    			size:$(element).data('size'),
    
    		};
    		if(property){
    			files.push(file[property]);
    		}else{
    
    Robin Appelman's avatar
    Robin Appelman committed
    			files.push(file);
    
    		}
    	});
    	return files;