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');