FileActions={
actions:{},
defaults:{},
icons:{},
currentFile:null,
register:function(mime,name,icon,action){
if(!FileActions.actions[mime]){
FileActions.actions[mime]={};
}
FileActions.actions[mime][name]=action;
FileActions.icons[name]=icon;
},
setDefault:function(mime,name){
FileActions.defaults[mime]=name;
},
get:function(mime,type){
var actions={};
if(FileActions.actions.all){
actions=$.extend( actions, FileActions.actions.all )
}
if(mime){
if(FileActions.actions[mime]){
actions=$.extend( actions, FileActions.actions[mime] )
}
var mimePart=mime.substr(0,mime.indexOf('/'));
if(FileActions.actions[mimePart]){
actions=$.extend( actions, FileActions.actions[mimePart] )
}
}
if(type){//type is 'dir' or 'file'
if(FileActions.actions[type]){
actions=$.extend( actions, FileActions.actions[type] )
}
}
return actions;
},
getDefault:function(mime,type){
if(mime){
var mimePart=mime.substr(0,mime.indexOf('/'));
}
var name=false;
if(mime && FileActions.defaults[mime]){
name=FileActions.defaults[mime];
}else if(mime && FileActions.defaults[mimePart]){
name=FileActions.defaults[mimePart];
}else if(type && FileActions.defaults[type]){
name=FileActions.defaults[type];
}else{
name=FileActions.defaults.all;
}
var actions=this.get(mime,type);
return actions[name];
},
display:function(parent){
FileActions.currentFile=parent;
var actions=FileActions.get(FileActions.getCurrentMimeType(),FileActions.getCurrentType());
var defaultAction=FileActions.getDefault(FileActions.getCurrentMimeType(),FileActions.getCurrentType());
for(name in actions){
if(actions[name]!=defaultAction && name!='Delete'){
var img=FileActions.icons[name];
var html='';
var element=$(html);
if(img){
element.append($(''));
}
element.data('action',name);
element.click(function(event){
event.stopPropagation();
event.preventDefault();
var action=actions[$(this).data('action')];
var currentFile=FileActions.getCurrentFile();
FileActions.hide();
action(currentFile);
});
parent.children('a.name').append(element);
}
}
if(actions['Delete']){
var img=FileActions.icons['Delete'];
var html='';
var element=$(html);
if(img){
element.append($(''));
}
element.data('action','Delete');
element.click(function(event){
event.stopPropagation();
event.preventDefault();
var action=actions[$(this).data('action')];
var currentFile=FileActions.getCurrentFile();
FileActions.hide();
action(currentFile);
});
parent.parent().children().last().append(element);
}
return false;
},
hide:function(){
$('.file_action').remove();
},
getCurrentFile:function(){
return FileActions.currentFile.parent().attr('data-file');
},
getCurrentMimeType:function(){
return FileActions.currentFile.parent().attr('data-mime');
},
getCurrentType:function(){
return FileActions.currentFile.parent().attr('data-type');
}
}
FileActions.register('all','Download',OC.imagePath('core','actions/download'),function(filename){
window.location='ajax/download.php?files='+filename+'&dir='+$('#dir').val();
});
FileActions.register('all','Delete',OC.imagePath('core','actions/delete'),function(filename){
$( "#delete-confirm" ).dialog({
resizable: false,
height:200,
title:"Delete "+filename,
modal: true,
buttons: {
"Delete": function() {
$( this ).dialog( "close" );
$.ajax({
url: 'ajax/delete.php',
data: "dir="+encodeURIComponent($('#dir').val())+"&file="+encodeURIComponent(filename),
complete: function(data){
boolOperationFinished(data, function(){
FileList.remove(filename);
});
}
});
},
Cancel: function() {
$( this ).dialog( "close" );
}
}
});
});
FileActions.register('all','Rename',OC.imagePath('core','actions/rename'),function(filename){
FileList.rename(filename);
});
FileActions.setDefault('all','Download');
FileActions.register('dir','Open','',function(filename){
window.location='index.php?dir='+$('#dir').val()+'/'+filename;
});
FileActions.setDefault('dir','Open');