2014-01-30 13:41:04 +04:00
/ *
* Copyright ( c ) 2014
*
* This file is licensed under the Affero General Public License version 3
* or later .
*
* See the COPYING - README file .
*
* /
/* global OC, t, n, FileList, FileActions */
/* global getURLParameter, isPublic */
var Files = {
2013-11-06 13:15:05 +04:00
// file space size sync
_updateStorageStatistics : function ( ) {
Files . _updateStorageStatisticsTimeout = null ;
2013-11-06 13:55:19 +04:00
var currentDir = FileList . getCurrentDirectory ( ) ,
state = Files . updateStorageStatistics ;
if ( state . dir ) {
if ( state . dir === currentDir ) {
return ;
}
// cancel previous call, as it was for another dir
state . call . abort ( ) ;
2013-11-06 13:15:05 +04:00
}
2013-11-06 13:55:19 +04:00
state . dir = currentDir ;
state . call = $ . getJSON ( OC . filePath ( 'files' , 'ajax' , 'getstoragestats.php' ) + '?dir=' + encodeURIComponent ( currentDir ) , function ( response ) {
state . dir = null ;
state . call = null ;
2013-11-06 13:15:05 +04:00
Files . updateMaxUploadFilesize ( response ) ;
} ) ;
} ,
2013-11-06 13:55:19 +04:00
updateStorageStatistics : function ( force ) {
2013-11-06 13:15:05 +04:00
if ( ! OC . currentUser ) {
return ;
}
// debounce to prevent calling too often
if ( Files . _updateStorageStatisticsTimeout ) {
clearTimeout ( Files . _updateStorageStatisticsTimeout ) ;
}
2013-11-06 13:55:19 +04:00
if ( force ) {
Files . _updateStorageStatistics ( ) ;
}
else {
Files . _updateStorageStatisticsTimeout = setTimeout ( Files . _updateStorageStatistics , 250 ) ;
}
2013-11-06 13:15:05 +04:00
} ,
2013-01-18 23:09:03 +04:00
updateMaxUploadFilesize : function ( response ) {
2013-10-22 20:11:03 +04:00
if ( response === undefined ) {
2013-01-18 23:09:03 +04:00
return ;
}
2013-10-22 20:11:03 +04:00
if ( response . data !== undefined && response . data . uploadMaxFilesize !== undefined ) {
2013-01-18 23:09:03 +04:00
$ ( '#max_upload' ) . val ( response . data . uploadMaxFilesize ) ;
2013-12-11 08:17:28 +04:00
$ ( '#free_space' ) . val ( response . data . freeSpace ) ;
2013-01-19 03:31:49 +04:00
$ ( '#upload.button' ) . attr ( 'original-title' , response . data . maxHumanFilesize ) ;
$ ( '#usedSpacePercent' ) . val ( response . data . usedSpacePercent ) ;
Files . displayStorageWarnings ( ) ;
2013-01-18 23:09:03 +04:00
}
2013-10-22 20:11:03 +04:00
if ( response [ 0 ] === undefined ) {
2013-01-18 23:09:03 +04:00
return ;
}
2013-10-22 20:11:03 +04:00
if ( response [ 0 ] . uploadMaxFilesize !== undefined ) {
2013-01-18 23:09:03 +04:00
$ ( '#max_upload' ) . val ( response [ 0 ] . uploadMaxFilesize ) ;
2013-01-19 03:31:49 +04:00
$ ( '#upload.button' ) . attr ( 'original-title' , response [ 0 ] . maxHumanFilesize ) ;
$ ( '#usedSpacePercent' ) . val ( response [ 0 ] . usedSpacePercent ) ;
Files . displayStorageWarnings ( ) ;
2013-01-18 23:09:03 +04:00
}
} ,
2013-10-28 14:22:34 +04:00
/ * *
* Fix path name by removing double slash at the beginning , if any
* /
fixPath : function ( fileName ) {
if ( fileName . substr ( 0 , 2 ) == '//' ) {
return fileName . substr ( 1 ) ;
}
return fileName ;
} ,
2014-01-30 14:42:43 +04:00
/ * *
* Checks whether the given file name is valid .
* @ param name file name to check
* @ return true if the file name is valid .
* Throws a string exception with an error message if
* the file name is not valid
* /
2014-03-04 19:42:40 +04:00
isFileNameValid : function ( name , root ) {
2014-01-30 14:42:43 +04:00
var trimmedName = name . trim ( ) ;
2014-03-04 19:42:40 +04:00
if ( trimmedName === '.'
|| trimmedName === '..'
|| ( root === '/' && trimmedName . toLowerCase ( ) === 'shared' ) )
{
2014-01-30 14:42:43 +04:00
throw t ( 'files' , '"{name}" is an invalid file name.' , { name : name } ) ;
} else if ( trimmedName . length === 0 ) {
2013-10-22 20:11:03 +04:00
throw t ( 'files' , 'File name cannot be empty.' ) ;
2013-01-07 13:39:35 +04:00
}
// check for invalid characters
2014-01-30 14:42:43 +04:00
var invalid _characters =
[ '\\' , '/' , '<' , '>' , ':' , '"' , '|' , '?' , '*' , '\n' ] ;
2012-11-22 16:03:17 +04:00
for ( var i = 0 ; i < invalid _characters . length ; i ++ ) {
2014-01-30 14:42:43 +04:00
if ( trimmedName . indexOf ( invalid _characters [ i ] ) !== - 1 ) {
2013-10-22 20:11:03 +04:00
throw t ( 'files' , "Invalid name, '\\', '/', '<', '>', ':', '\"', '|', '?' and '*' are not allowed." ) ;
2012-11-22 16:03:17 +04:00
}
}
2013-01-06 15:52:00 +04:00
return true ;
2013-01-02 18:09:40 +04:00
} ,
2013-01-19 02:22:34 +04:00
displayStorageWarnings : function ( ) {
2013-01-19 03:31:49 +04:00
if ( ! OC . Notification . isHidden ( ) ) {
return ;
}
2013-01-19 02:22:34 +04:00
var usedSpacePercent = $ ( '#usedSpacePercent' ) . val ( ) ;
if ( usedSpacePercent > 98 ) {
2013-01-11 18:02:34 +04:00
OC . Notification . show ( t ( 'files' , 'Your storage is full, files can not be updated or synced anymore!' ) ) ;
return ;
2013-01-19 02:22:34 +04:00
}
if ( usedSpacePercent > 90 ) {
2013-01-11 18:02:34 +04:00
OC . Notification . show ( t ( 'files' , 'Your storage is almost full ({usedSpacePercent}%)' , { usedSpacePercent : usedSpacePercent } ) ) ;
2013-01-19 02:22:34 +04:00
}
2013-08-12 19:25:27 +04:00
} ,
displayEncryptionWarning : function ( ) {
if ( ! OC . Notification . isHidden ( ) ) {
return ;
}
var encryptedFiles = $ ( '#encryptedFiles' ) . val ( ) ;
2013-09-06 14:27:40 +04:00
var initStatus = $ ( '#encryptionInitStatus' ) . val ( ) ;
if ( initStatus === '0' ) { // enc not initialized, but should be
OC . Notification . show ( t ( 'files_encryption' , 'Encryption App is enabled but your keys are not initialized, please log-out and log-in again' ) ) ;
return ;
}
if ( initStatus === '1' ) { // encryption tried to init but failed
2013-10-04 13:11:24 +04:00
OC . Notification . showHtml ( t ( 'files_encryption' , 'Invalid private key for Encryption App. Please update your private key password in your personal settings to recover access to your encrypted files.' ) ) ;
2013-09-06 14:27:40 +04:00
return ;
}
2013-08-12 19:25:27 +04:00
if ( encryptedFiles === '1' ) {
2013-08-15 15:13:16 +04:00
OC . Notification . show ( t ( 'files_encryption' , 'Encryption was disabled but your files are still encrypted. Please go to your personal settings to decrypt your files.' ) ) ;
2013-08-12 19:25:27 +04:00
return ;
}
2013-08-17 15:07:18 +04:00
} ,
2013-10-22 20:11:03 +04:00
setupDragAndDrop : function ( ) {
2013-08-17 15:07:18 +04:00
var $fileList = $ ( '#fileList' ) ;
//drag/drop of files
2013-10-22 20:11:03 +04:00
$fileList . find ( 'tr td.filename' ) . each ( function ( i , e ) {
2013-08-17 15:07:18 +04:00
if ( $ ( e ) . parent ( ) . data ( 'permissions' ) & OC . PERMISSION _DELETE ) {
$ ( e ) . draggable ( dragOptions ) ;
}
} ) ;
2013-10-22 20:11:03 +04:00
$fileList . find ( 'tr[data-type="dir"] td.filename' ) . each ( function ( i , e ) {
if ( $ ( e ) . parent ( ) . data ( 'permissions' ) & OC . PERMISSION _CREATE ) {
2013-08-17 15:07:18 +04:00
$ ( e ) . droppable ( folderDropOptions ) ;
}
} ) ;
2013-08-27 15:13:00 +04:00
} ,
2013-10-28 23:22:06 +04:00
/ * *
* Returns the download URL of the given file ( s )
* @ param filename string or array of file names to download
* @ param dir optional directory in which the file name is , defaults to the current directory
* /
getDownloadUrl : function ( filename , dir ) {
if ( $ . isArray ( filename ) ) {
filename = JSON . stringify ( filename ) ;
2013-08-27 15:13:00 +04:00
}
2013-10-28 23:22:06 +04:00
var params = {
dir : dir || FileList . getCurrentDirectory ( ) ,
files : filename
} ;
return this . getAjaxUrl ( 'download' , params ) ;
2013-08-27 15:13:00 +04:00
} ,
2013-10-28 23:22:06 +04:00
/ * *
* Returns the ajax URL for a given action
* @ param action action string
* @ param params optional params map
* /
getAjaxUrl : function ( action , params ) {
var q = '' ;
if ( params ) {
q = '?' + OC . buildQueryString ( params ) ;
2013-08-27 15:13:00 +04:00
}
2013-10-28 23:22:06 +04:00
return OC . filePath ( 'files' , 'ajax' , action + '.php' ) + q ;
2012-03-27 23:38:55 +04:00
}
2012-09-06 00:17:33 +04:00
} ;
2011-03-03 01:06:23 +03:00
$ ( document ) . ready ( function ( ) {
2013-09-01 16:36:33 +04:00
// FIXME: workaround for trashbin app
2013-10-22 20:11:03 +04:00
if ( window . trashBinApp ) {
2013-09-01 16:36:33 +04:00
return ;
}
2013-08-12 19:25:27 +04:00
Files . displayEncryptionWarning ( ) ;
2013-01-14 23:30:39 +04:00
Files . bindKeyboardShortcuts ( document , jQuery ) ;
2013-08-17 15:07:18 +04:00
Files . setupDragAndDrop ( ) ;
2012-03-16 19:25:41 +04:00
2011-04-17 19:49:56 +04:00
$ ( '#file_action_panel' ) . attr ( 'activeAction' , false ) ;
2011-07-07 23:43:35 +04:00
2011-08-12 00:22:32 +04:00
// Triggers invisible file input
2013-01-19 01:38:44 +04:00
$ ( '#upload a' ) . on ( 'click' , function ( ) {
2012-12-05 14:17:41 +04:00
$ ( this ) . parent ( ) . children ( '#file_upload_start' ) . trigger ( 'click' ) ;
2011-08-12 00:22:32 +04:00
return false ;
} ) ;
2013-02-22 20:21:57 +04:00
2013-04-29 01:25:58 +04:00
// Trigger cancelling of file upload
2013-04-29 01:28:41 +04:00
$ ( '#uploadprogresswrapper .stop' ) . on ( 'click' , function ( ) {
2013-08-16 13:40:55 +04:00
OC . Upload . cancelUploads ( ) ;
procesSelection ( ) ;
2013-04-29 01:25:58 +04:00
} ) ;
2013-01-18 13:23:31 +04:00
// Show trash bin
2013-07-26 13:13:43 +04:00
$ ( '#trash' ) . on ( 'click' , function ( ) {
2013-01-18 13:23:31 +04:00
window . location = OC . filePath ( 'files_trashbin' , '' , 'index.php' ) ;
2013-01-15 23:35:15 +04:00
} ) ;
2011-08-12 00:22:32 +04:00
2011-08-28 23:21:53 +04:00
var lastChecked ;
2011-06-04 22:16:44 +04:00
// Sets the file link behaviour :
2013-01-30 20:10:40 +04:00
$ ( '#fileList' ) . on ( 'click' , 'td.filename a' , function ( event ) {
2011-08-28 23:21:53 +04:00
if ( event . ctrlKey || event . shiftKey ) {
2013-01-09 18:21:55 +04:00
event . preventDefault ( ) ;
2011-08-28 23:21:53 +04:00
if ( event . shiftKey ) {
var last = $ ( lastChecked ) . parent ( ) . parent ( ) . prevAll ( ) . length ;
var first = $ ( this ) . parent ( ) . parent ( ) . prevAll ( ) . length ;
var start = Math . min ( first , last ) ;
var end = Math . max ( first , last ) ;
var rows = $ ( this ) . parent ( ) . parent ( ) . parent ( ) . children ( 'tr' ) ;
for ( var i = start ; i < end ; i ++ ) {
$ ( rows ) . each ( function ( index ) {
2013-10-22 20:11:03 +04:00
if ( index === i ) {
2011-08-28 23:21:53 +04:00
var checkbox = $ ( this ) . children ( ) . children ( 'input:checkbox' ) ;
$ ( checkbox ) . attr ( 'checked' , 'checked' ) ;
$ ( checkbox ) . parent ( ) . parent ( ) . addClass ( 'selected' ) ;
}
} ) ;
}
}
2011-08-28 22:14:50 +04:00
var checkbox = $ ( this ) . parent ( ) . children ( 'input:checkbox' ) ;
2011-08-28 23:21:53 +04:00
lastChecked = checkbox ;
2011-08-28 22:14:50 +04:00
if ( $ ( checkbox ) . attr ( 'checked' ) ) {
$ ( checkbox ) . removeAttr ( 'checked' ) ;
$ ( checkbox ) . parent ( ) . parent ( ) . removeClass ( 'selected' ) ;
$ ( '#select_all' ) . removeAttr ( 'checked' ) ;
} else {
$ ( checkbox ) . attr ( 'checked' , 'checked' ) ;
$ ( checkbox ) . parent ( ) . parent ( ) . toggleClass ( 'selected' ) ;
2013-10-22 20:11:03 +04:00
var selectedCount = $ ( 'td.filename input:checkbox:checked' ) . length ;
if ( selectedCount === $ ( 'td.filename input:checkbox' ) . length ) {
2011-08-28 22:14:50 +04:00
$ ( '#select_all' ) . attr ( 'checked' , 'checked' ) ;
}
}
procesSelection ( ) ;
} else {
2011-11-02 23:26:17 +04:00
var filename = $ ( this ) . parent ( ) . parent ( ) . attr ( 'data-file' ) ;
2014-01-10 18:02:26 +04:00
var tr = FileList . findFileEl ( filename ) ;
2012-01-01 05:14:00 +04:00
var renaming = tr . data ( 'renaming' ) ;
2013-10-28 23:22:06 +04:00
if ( ! renaming ) {
2013-02-18 14:22:43 +04:00
FileActions . currentFile = $ ( this ) . parent ( ) ;
var mime = FileActions . getCurrentMimeType ( ) ;
var type = FileActions . getCurrentType ( ) ;
var permissions = FileActions . getCurrentPermissions ( ) ;
2012-07-26 00:33:08 +04:00
var action = FileActions . getDefault ( mime , type , permissions ) ;
2013-10-22 20:11:03 +04:00
if ( action ) {
2013-01-09 18:21:55 +04:00
event . preventDefault ( ) ;
2011-08-28 22:14:50 +04:00
action ( filename ) ;
}
2011-07-19 22:57:40 +04:00
}
2011-06-04 22:16:44 +04:00
}
2012-03-16 19:25:41 +04:00
2011-06-04 22:16:44 +04:00
} ) ;
2012-03-16 19:25:41 +04:00
2011-06-04 20:44:14 +04:00
// Sets the select_all checkbox behaviour :
$ ( '#select_all' ) . click ( function ( ) {
2013-10-22 20:11:03 +04:00
if ( $ ( this ) . attr ( 'checked' ) ) {
2011-06-04 20:44:14 +04:00
// Check all
2011-07-22 00:01:55 +04:00
$ ( 'td.filename input:checkbox' ) . attr ( 'checked' , true ) ;
$ ( 'td.filename input:checkbox' ) . parent ( ) . parent ( ) . addClass ( 'selected' ) ;
2013-10-22 20:11:03 +04:00
} else {
2011-06-04 20:44:14 +04:00
// Uncheck all
2011-07-22 00:01:55 +04:00
$ ( 'td.filename input:checkbox' ) . attr ( 'checked' , false ) ;
$ ( 'td.filename input:checkbox' ) . parent ( ) . parent ( ) . removeClass ( 'selected' ) ;
2011-07-07 04:28:57 +04:00
}
2011-07-22 00:01:55 +04:00
procesSelection ( ) ;
2011-06-04 20:44:14 +04:00
} ) ;
2012-03-16 19:25:41 +04:00
2013-01-19 01:38:44 +04:00
$ ( '#fileList' ) . on ( 'change' , 'td.filename input:checkbox' , function ( event ) {
2011-08-28 23:21:53 +04:00
if ( event . shiftKey ) {
var last = $ ( lastChecked ) . parent ( ) . parent ( ) . prevAll ( ) . length ;
var first = $ ( this ) . parent ( ) . parent ( ) . prevAll ( ) . length ;
var start = Math . min ( first , last ) ;
var end = Math . max ( first , last ) ;
var rows = $ ( this ) . parent ( ) . parent ( ) . parent ( ) . children ( 'tr' ) ;
for ( var i = start ; i < end ; i ++ ) {
$ ( rows ) . each ( function ( index ) {
2013-10-22 20:11:03 +04:00
if ( index === i ) {
2011-08-28 23:21:53 +04:00
var checkbox = $ ( this ) . children ( ) . children ( 'input:checkbox' ) ;
$ ( checkbox ) . attr ( 'checked' , 'checked' ) ;
$ ( checkbox ) . parent ( ) . parent ( ) . addClass ( 'selected' ) ;
}
} ) ;
}
}
2011-07-22 00:01:55 +04:00
var selectedCount = $ ( 'td.filename input:checkbox:checked' ) . length ;
2011-07-07 04:28:57 +04:00
$ ( this ) . parent ( ) . parent ( ) . toggleClass ( 'selected' ) ;
2013-10-22 20:11:03 +04:00
if ( ! $ ( this ) . attr ( 'checked' ) ) {
2011-04-18 14:49:52 +04:00
$ ( '#select_all' ) . attr ( 'checked' , false ) ;
2013-10-22 20:11:03 +04:00
} else {
if ( selectedCount === $ ( 'td.filename input:checkbox' ) . length ) {
2011-04-18 14:49:52 +04:00
$ ( '#select_all' ) . attr ( 'checked' , true ) ;
}
}
2011-07-22 00:01:55 +04:00
procesSelection ( ) ;
2011-04-18 14:49:52 +04:00
} ) ;
2012-03-16 19:25:41 +04:00
2011-07-26 18:14:20 +04:00
$ ( '.download' ) . click ( 'click' , function ( event ) {
2014-02-13 23:20:00 +04:00
var files ;
var dir = FileList . getCurrentDirectory ( ) ;
if ( FileList . isAllSelected ( ) ) {
files = OC . basename ( dir ) ;
dir = OC . dirname ( dir ) || '/' ;
2012-10-05 18:12:04 +04:00
}
2014-02-13 23:20:00 +04:00
else {
2013-10-28 23:22:06 +04:00
files = Files . getSelectedFiles ( 'name' ) ;
2014-02-13 23:20:00 +04:00
}
OC . Notification . show ( t ( 'files' , 'Your download is being prepared. This might take some time if the files are big.' ) ) ;
2013-10-28 23:22:06 +04:00
OC . redirect ( Files . getDownloadUrl ( files , dir ) ) ;
2011-04-18 17:40:17 +04:00
return false ;
} ) ;
2012-03-16 19:25:41 +04:00
2013-03-26 19:27:56 +04:00
$ ( '.delete-selected' ) . click ( function ( event ) {
2013-10-28 23:22:06 +04:00
var files = Files . getSelectedFiles ( 'name' ) ;
2011-08-04 02:22:44 +04:00
event . preventDefault ( ) ;
2014-02-13 23:20:00 +04:00
if ( FileList . isAllSelected ( ) ) {
files = null ;
}
2011-08-28 03:32:48 +04:00
FileList . do _delete ( files ) ;
2011-04-18 18:48:35 +04:00
return false ;
} ) ;
2011-06-03 04:44:31 +04:00
2012-03-16 03:03:23 +04:00
// drag&drop support using jquery.fileupload
2012-04-15 18:47:53 +04:00
// TODO use OC.dialogs
2012-03-27 23:38:55 +04:00
$ ( document ) . bind ( 'drop dragover' , function ( e ) {
e . preventDefault ( ) ; // prevent browser from doing anything, if file isn't dropped in dropZone
} ) ;
2012-10-14 23:04:08 +04:00
2012-11-23 03:20:46 +04:00
//do a background scan if needed
scanFiles ( ) ;
2012-08-29 10:42:49 +04:00
2013-01-11 18:02:34 +04:00
// display storage warnings
2014-02-07 20:47:42 +04:00
setTimeout ( Files . displayStorageWarnings , 100 ) ;
2013-01-11 18:02:34 +04:00
OC . Notification . setDefault ( Files . displayStorageWarnings ) ;
2013-01-19 02:22:34 +04:00
2013-11-05 15:18:25 +04:00
// only possible at the moment if user is logged in
if ( OC . currentUser ) {
// start on load - we ask the server every 5 minutes
2013-11-06 13:15:05 +04:00
var updateStorageStatisticsInterval = 5 * 60 * 1000 ;
var updateStorageStatisticsIntervalId = setInterval ( Files . updateStorageStatistics , updateStorageStatisticsInterval ) ;
2013-11-05 15:18:25 +04:00
// Use jquery-visibility to de-/re-activate file stats sync
if ( $ . support . pageVisibility ) {
$ ( document ) . on ( {
'show.visibility' : function ( ) {
2013-11-06 13:15:05 +04:00
if ( ! updateStorageStatisticsIntervalId ) {
updateStorageStatisticsIntervalId = setInterval ( Files . updateStorageStatistics , updateStorageStatisticsInterval ) ;
2013-11-05 15:18:25 +04:00
}
} ,
'hide.visibility' : function ( ) {
2013-11-06 13:15:05 +04:00
clearInterval ( updateStorageStatisticsIntervalId ) ;
updateStorageStatisticsIntervalId = 0 ;
2013-01-11 19:47:28 +04:00
}
2013-11-05 15:18:25 +04:00
} ) ;
}
2013-01-11 19:47:28 +04:00
}
2013-09-20 16:59:17 +04:00
2013-08-01 00:24:52 +04:00
//scroll to and highlight preselected file
if ( getURLParameter ( 'scrollto' ) ) {
FileList . scrollTo ( getURLParameter ( 'scrollto' ) ) ;
}
2011-03-03 01:06:23 +03:00
} ) ;
2011-04-17 00:56:40 +04:00
2013-10-22 20:11:03 +04:00
function scanFiles ( force , dir , users ) {
2013-02-01 02:26:40 +04:00
if ( ! OC . currentUser ) {
return ;
}
2013-10-22 20:11:03 +04:00
if ( ! dir ) {
2012-11-23 03:20:46 +04:00
dir = '' ;
2012-04-26 00:42:00 +04:00
}
2012-11-23 03:20:46 +04:00
force = ! ! force ; //cast to bool
scanFiles . scanning = true ;
2013-06-19 03:26:08 +04:00
var scannerEventSource ;
if ( users ) {
var usersString ;
if ( users === 'all' ) {
usersString = users ;
} else {
2013-06-19 17:02:18 +04:00
usersString = JSON . stringify ( users ) ;
2013-06-19 03:26:08 +04:00
}
scannerEventSource = new OC . EventSource ( OC . filePath ( 'files' , 'ajax' , 'scan.php' ) , { force : force , dir : dir , users : usersString } ) ;
} else {
scannerEventSource = new OC . EventSource ( OC . filePath ( 'files' , 'ajax' , 'scan.php' ) , { force : force , dir : dir } ) ;
}
2012-11-23 03:20:46 +04:00
scanFiles . cancel = scannerEventSource . close . bind ( scannerEventSource ) ;
2013-10-22 20:11:03 +04:00
scannerEventSource . listen ( 'count' , function ( count ) {
console . log ( count + ' files scanned' ) ;
2012-11-23 03:20:46 +04:00
} ) ;
2013-10-22 20:11:03 +04:00
scannerEventSource . listen ( 'folder' , function ( path ) {
console . log ( 'now scanning ' + path ) ;
2012-01-31 02:32:55 +04:00
} ) ;
2013-10-22 20:11:03 +04:00
scannerEventSource . listen ( 'done' , function ( count ) {
2012-02-01 18:33:12 +04:00
scanFiles . scanning = false ;
2013-05-24 16:31:06 +04:00
console . log ( 'done after ' + count + ' files' ) ;
2013-11-06 13:15:05 +04:00
Files . updateStorageStatistics ( ) ;
2012-01-31 02:32:55 +04:00
} ) ;
2013-10-22 20:11:03 +04:00
scannerEventSource . listen ( 'user' , function ( user ) {
2013-06-19 03:26:08 +04:00
console . log ( 'scanning files for ' + user ) ;
} ) ;
2011-11-10 19:40:09 +04:00
}
2012-02-01 18:33:12 +04:00
scanFiles . scanning = false ;
2011-11-10 19:40:09 +04:00
2011-06-04 20:44:14 +04:00
function boolOperationFinished ( data , callback ) {
result = jQuery . parseJSON ( data . responseText ) ;
2013-01-18 23:09:03 +04:00
Files . updateMaxUploadFilesize ( result ) ;
2013-10-22 20:11:03 +04:00
if ( result . status === 'success' ) {
2011-06-04 20:44:14 +04:00
callback . call ( ) ;
2011-04-17 19:49:56 +04:00
} else {
alert ( result . data . message ) ;
}
}
2013-10-22 20:11:03 +04:00
var createDragShadow = function ( event ) {
2013-01-19 00:49:38 +04:00
//select dragged file
2013-01-21 17:58:55 +04:00
var isDragSelected = $ ( event . target ) . parents ( 'tr' ) . find ( 'td input:first' ) . prop ( 'checked' ) ;
if ( ! isDragSelected ) {
//select dragged file
$ ( event . target ) . parents ( 'tr' ) . find ( 'td input:first' ) . prop ( 'checked' , true ) ;
}
2013-02-22 20:21:57 +04:00
2013-10-28 23:22:06 +04:00
var selectedFiles = Files . getSelectedFiles ( ) ;
2013-02-22 20:21:57 +04:00
2013-10-22 20:11:03 +04:00
if ( ! isDragSelected && selectedFiles . length === 1 ) {
2013-01-21 17:58:55 +04:00
//revert the selection
$ ( event . target ) . parents ( 'tr' ) . find ( 'td input:first' ) . prop ( 'checked' , false ) ;
}
2013-02-22 20:21:57 +04:00
2013-01-19 00:49:38 +04:00
//also update class when we dragged more than one file
if ( selectedFiles . length > 1 ) {
$ ( event . target ) . parents ( 'tr' ) . addClass ( 'selected' ) ;
}
2013-02-22 20:21:57 +04:00
2013-01-19 00:49:38 +04:00
// build dragshadow
var dragshadow = $ ( '<table class="dragshadow"></table>' ) ;
var tbody = $ ( '<tbody></tbody>' ) ;
dragshadow . append ( tbody ) ;
2013-02-22 20:21:57 +04:00
2013-01-19 00:49:38 +04:00
var dir = $ ( '#dir' ) . val ( ) ;
2013-02-22 20:21:57 +04:00
2013-10-22 20:11:03 +04:00
$ ( selectedFiles ) . each ( function ( i , elem ) {
2013-12-04 21:27:24 +04:00
var newtr = $ ( '<tr/>' ) . attr ( 'data-dir' , dir ) . attr ( 'data-filename' , elem . name ) . attr ( 'data-origin' , elem . origin ) ;
2013-04-22 23:54:25 +04:00
newtr . append ( $ ( '<td/>' ) . addClass ( 'filename' ) . text ( elem . name ) ) ;
newtr . append ( $ ( '<td/>' ) . addClass ( 'size' ) . text ( humanFileSize ( elem . size ) ) ) ;
2013-01-19 00:49:38 +04:00
tbody . append ( newtr ) ;
if ( elem . type === 'dir' ) {
newtr . find ( 'td.filename' ) . attr ( 'style' , 'background-image:url(' + OC . imagePath ( 'core' , 'filetypes/folder.png' ) + ')' ) ;
} else {
2013-08-24 01:19:21 +04:00
var path = getPathForPreview ( elem . name ) ;
2013-10-28 14:22:34 +04:00
Files . lazyLoadPreview ( path , elem . mime , function ( previewpath ) {
2013-07-02 13:13:22 +04:00
newtr . find ( 'td.filename' ) . attr ( 'style' , 'background-image:url(' + previewpath + ')' ) ;
2013-10-28 14:22:34 +04:00
} , null , null , elem . etag ) ;
2013-01-19 00:49:38 +04:00
}
} ) ;
2013-02-22 20:21:57 +04:00
2013-01-19 00:49:38 +04:00
return dragshadow ;
2013-10-22 20:11:03 +04:00
} ;
2013-01-19 00:49:38 +04:00
//options for file drag/drop
2013-12-04 21:27:24 +04:00
//start&stop handlers needs some cleaning up
2011-07-07 23:43:35 +04:00
var dragOptions = {
2013-01-21 17:58:55 +04:00
revert : 'invalid' , revertDuration : 300 ,
2013-10-28 18:41:52 +04:00
opacity : 0.7 , zIndex : 100 , appendTo : 'body' , cursorAt : { left : 24 , top : 18 } ,
2013-01-19 00:49:38 +04:00
helper : createDragShadow , cursor : 'move' ,
2013-12-04 21:27:24 +04:00
start : function ( event , ui ) {
var $selectedFiles = $ ( 'td.filename input:checkbox:checked' ) ;
if ( $selectedFiles . length > 1 ) {
$selectedFiles . parents ( 'tr' ) . fadeTo ( 250 , 0.2 ) ;
}
else {
$ ( this ) . fadeTo ( 250 , 0.2 ) ;
}
} ,
stop : function ( event , ui ) {
var $selectedFiles = $ ( 'td.filename input:checkbox:checked' ) ;
if ( $selectedFiles . length > 1 ) {
$selectedFiles . parents ( 'tr' ) . fadeTo ( 250 , 1 ) ;
}
else {
$ ( this ) . fadeTo ( 250 , 1 ) ;
}
$ ( '#fileList tr td.filename' ) . addClass ( 'ui-draggable' ) ;
}
2013-10-22 20:11:03 +04:00
} ;
2013-02-25 18:08:14 +04:00
// sane browsers support using the distance option
2013-03-28 22:13:37 +04:00
if ( $ ( 'html.ie' ) . length === 0 ) {
2013-02-25 18:08:14 +04:00
dragOptions [ 'distance' ] = 20 ;
2013-06-25 14:24:14 +04:00
}
2013-01-19 00:49:38 +04:00
2011-07-07 23:43:35 +04:00
var folderDropOptions = {
2013-12-04 21:27:24 +04:00
hoverClass : "canDrop" ,
2011-07-07 23:43:35 +04:00
drop : function ( event , ui ) {
2013-01-19 00:49:38 +04:00
//don't allow moving a file into a selected folder
if ( $ ( event . target ) . parents ( 'tr' ) . find ( 'td input:first' ) . prop ( 'checked' ) === true ) {
return false ;
}
2013-02-22 20:21:57 +04:00
2013-10-31 18:56:02 +04:00
var target = $ ( this ) . closest ( 'tr' ) . data ( 'file' ) ;
2013-02-22 20:21:57 +04:00
2013-01-19 00:49:38 +04:00
var files = ui . helper . find ( 'tr' ) ;
2013-10-22 20:11:03 +04:00
$ ( files ) . each ( function ( i , row ) {
2013-01-19 00:49:38 +04:00
var dir = $ ( row ) . data ( 'dir' ) ;
var file = $ ( row ) . data ( 'filename' ) ;
2013-12-04 21:27:24 +04:00
//slapdash selector, tracking down our original element that the clone budded off of.
var origin = $ ( 'tr[data-id=' + $ ( row ) . data ( 'origin' ) + ']' ) ;
var td = origin . children ( 'td.filename' ) ;
var oldBackgroundImage = td . css ( 'background-image' ) ;
td . css ( 'background-image' , 'url(' + OC . imagePath ( 'core' , 'loading.gif' ) + ')' ) ;
2013-01-19 01:16:04 +04:00
$ . post ( OC . filePath ( 'files' , 'ajax' , 'move.php' ) , { dir : dir , file : file , target : dir + '/' + target } , function ( result ) {
2013-01-19 00:49:38 +04:00
if ( result ) {
if ( result . status === 'success' ) {
//recalculate folder size
2014-01-10 18:02:26 +04:00
var oldFile = FileList . findFileEl ( target ) ;
var newFile = FileList . findFileEl ( file ) ;
var oldSize = oldFile . data ( 'size' ) ;
var newSize = oldSize + newFile . data ( 'size' ) ;
oldFile . data ( 'size' , newSize ) ;
oldFile . find ( 'td.filesize' ) . text ( humanFileSize ( newSize ) ) ;
2013-01-19 00:49:38 +04:00
FileList . remove ( file ) ;
procesSelection ( ) ;
$ ( '#notification' ) . hide ( ) ;
} else {
$ ( '#notification' ) . hide ( ) ;
$ ( '#notification' ) . text ( result . data . message ) ;
$ ( '#notification' ) . fadeIn ( ) ;
}
} else {
2013-09-19 13:13:11 +04:00
OC . dialogs . alert ( t ( 'files' , 'Error moving file' ) , t ( 'files' , 'Error' ) ) ;
2013-01-19 00:49:38 +04:00
}
2013-12-04 21:27:24 +04:00
td . css ( 'background-image' , oldBackgroundImage ) ;
2013-01-19 00:49:38 +04:00
} ) ;
2011-07-07 23:43:35 +04:00
} ) ;
2013-01-19 00:49:38 +04:00
} ,
tolerance : 'pointer'
2013-10-22 20:11:03 +04:00
} ;
2013-01-19 00:49:38 +04:00
2013-10-22 20:11:03 +04:00
function procesSelection ( ) {
2013-10-28 23:22:06 +04:00
var selected = Files . getSelectedFiles ( ) ;
2013-10-22 20:11:03 +04:00
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 ) {
2014-01-17 20:46:44 +04:00
$ ( '#headerName span.name' ) . text ( t ( 'files' , 'Name' ) ) ;
2011-08-28 06:16:39 +04:00
$ ( '#headerSize' ) . text ( t ( 'files' , 'Size' ) ) ;
2011-08-09 19:54:02 +04:00
$ ( '#modified' ) . text ( t ( 'files' , 'Modified' ) ) ;
2012-12-13 22:44:55 +04:00
$ ( 'table' ) . removeClass ( 'multiselect' ) ;
2011-07-28 14:14:55 +04:00
$ ( '.selectedActions' ) . hide ( ) ;
2014-01-17 20:46:44 +04:00
$ ( '#select_all' ) . removeAttr ( 'checked' ) ;
2012-12-20 13:53:50 +04:00
}
else {
2011-07-28 14:14:55 +04:00
$ ( '.selectedActions' ) . show ( ) ;
2013-10-22 20:11:03 +04:00
var totalSize = 0 ;
for ( var i = 0 ; i < selectedFiles . length ; i ++ ) {
2011-07-26 18:43:12 +04:00
totalSize += selectedFiles [ i ] . size ;
2014-01-30 13:41:04 +04:00
}
2013-10-22 20:11:03 +04:00
for ( var i = 0 ; i < selectedFolders . length ; i ++ ) {
2011-07-26 18:43:12 +04:00
totalSize += selectedFolders [ i ] . size ;
2014-01-30 13:41:04 +04:00
}
2013-07-19 00:15:26 +04:00
$ ( '#headerSize' ) . text ( humanFileSize ( totalSize ) ) ;
2013-10-22 20:11:03 +04:00
var selection = '' ;
if ( selectedFolders . length > 0 ) {
2013-08-09 22:37:18 +04:00
selection += n ( 'files' , '%n folder' , '%n folders' , selectedFolders . length ) ;
2013-10-22 20:11:03 +04:00
if ( selectedFiles . length > 0 ) {
selection += ' & ' ;
2011-07-22 00:01:55 +04:00
}
}
2013-10-22 20:11:03 +04:00
if ( selectedFiles . length > 0 ) {
2013-08-09 22:37:18 +04:00
selection += n ( 'files' , '%n file' , '%n files' , selectedFiles . length ) ;
2011-07-22 00:01:55 +04:00
}
2013-11-11 20:14:40 +04:00
$ ( '#headerName span.name' ) . text ( selection ) ;
2011-07-28 14:14:55 +04:00
$ ( '#modified' ) . text ( '' ) ;
2012-12-13 22:44:55 +04:00
$ ( 'table' ) . addClass ( 'multiselect' ) ;
2011-07-22 00:01:55 +04:00
}
2011-07-26 18:14:20 +04:00
}
2011-07-25 22:24:59 +04:00
/ * *
* @ brief get a list of selected files
2013-10-22 20:11:03 +04:00
* @ param { string } property ( option ) the property of the file requested
* @ return { array }
2011-07-25 22:24:59 +04:00
*
2011-07-26 18:43:12 +04:00
* possible values for property : name , mime , size and type
2011-07-25 22:24:59 +04:00
* 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
* /
2013-10-28 23:22:06 +04:00
Files . getSelectedFiles = function ( property ) {
2011-07-26 18:43:12 +04:00
var elements = $ ( 'td.filename input:checkbox:checked' ) . parent ( ) . parent ( ) ;
2011-07-25 22:24:59 +04:00
var files = [ ] ;
2013-10-22 20:11:03 +04:00
elements . each ( function ( i , element ) {
2011-07-25 22:24:59 +04:00
var file = {
2011-11-05 02:44:41 +04:00
name : $ ( element ) . attr ( 'data-file' ) ,
2011-07-26 18:43:12 +04:00
mime : $ ( element ) . data ( 'mime' ) ,
type : $ ( element ) . data ( 'type' ) ,
2013-10-28 18:41:52 +04:00
size : $ ( element ) . data ( 'size' ) ,
2013-12-04 21:27:24 +04:00
etag : $ ( element ) . data ( 'etag' ) ,
2013-12-04 22:30:06 +04:00
origin : $ ( element ) . data ( 'id' )
2011-07-25 22:24:59 +04:00
} ;
2013-10-22 20:11:03 +04:00
if ( property ) {
2011-07-25 22:24:59 +04:00
files . push ( file [ property ] ) ;
2013-10-22 20:11:03 +04:00
} else {
2011-07-26 18:43:12 +04:00
files . push ( file ) ;
2011-07-25 22:24:59 +04:00
}
} ) ;
return files ;
2011-07-28 02:21:11 +04:00
}
2011-07-29 03:10:08 +04:00
2013-10-28 14:22:34 +04:00
Files . getMimeIcon = function ( mime , ready ) {
if ( Files . getMimeIcon . cache [ mime ] ) {
ready ( Files . getMimeIcon . cache [ mime ] ) ;
2013-10-22 20:11:03 +04:00
} else {
$ . get ( OC . filePath ( 'files' , 'ajax' , 'mimeicon.php' ) , { mime : mime } , function ( path ) {
2014-02-19 17:47:29 +04:00
if ( SVGSupport ( ) ) {
path = path . substr ( 0 , path . length - 4 ) + '.svg' ;
}
2013-10-28 14:22:34 +04:00
Files . getMimeIcon . cache [ mime ] = path ;
ready ( Files . getMimeIcon . cache [ mime ] ) ;
2011-10-08 23:18:47 +04:00
} ) ;
2011-07-29 03:36:31 +04:00
}
2011-07-30 14:14:09 +04:00
}
2013-10-28 14:22:34 +04:00
Files . getMimeIcon . cache = { } ;
2012-04-15 19:30:07 +04:00
2013-08-24 01:19:21 +04:00
function getPathForPreview ( name ) {
var path = $ ( '#dir' ) . val ( ) + '/' + name ;
return path ;
}
2013-10-28 23:22:06 +04:00
/ * *
* Generates a preview URL based on the URL space .
* @ param urlSpec map with { x : width , y : height , file : file path }
* @ return preview URL
* /
Files . generatePreviewUrl = function ( urlSpec ) {
urlSpec = urlSpec || { } ;
if ( ! urlSpec . x ) {
urlSpec . x = $ ( '#filestable' ) . data ( 'preview-x' ) ;
}
if ( ! urlSpec . y ) {
urlSpec . y = $ ( '#filestable' ) . data ( 'preview-y' ) ;
}
2014-04-04 19:10:46 +04:00
urlSpec . y *= window . devicePixelRatio ;
urlSpec . x *= window . devicePixelRatio ;
2013-10-28 23:22:06 +04:00
urlSpec . forceIcon = 0 ;
return OC . generateUrl ( '/core/preview.png?' ) + $ . param ( urlSpec ) ;
}
2013-10-28 14:22:34 +04:00
Files . lazyLoadPreview = function ( path , mime , ready , width , height , etag ) {
2013-09-19 16:46:33 +04:00
// get mime icon url
2013-10-28 14:22:34 +04:00
Files . getMimeIcon ( mime , function ( iconURL ) {
2014-04-04 19:10:46 +04:00
var previewURL ,
2013-10-28 23:22:06 +04:00
urlSpec = { } ;
2013-09-19 16:46:33 +04:00
ready ( iconURL ) ; // set mimeicon URL
2013-09-20 16:59:17 +04:00
2013-10-28 14:22:34 +04:00
urlSpec . file = Files . fixPath ( path ) ;
if ( etag ) {
// use etag as cache buster
urlSpec . c = etag ;
}
else {
console . warn ( 'Files.lazyLoadPreview(): missing etag argument' ) ;
}
2013-10-28 23:22:06 +04:00
previewURL = Files . generatePreviewUrl ( urlSpec ) ;
2013-10-28 14:22:34 +04:00
previewURL = previewURL . replace ( '(' , '%28' ) ;
previewURL = previewURL . replace ( ')' , '%29' ) ;
// preload image to prevent delay
// this will make the browser cache the image
var img = new Image ( ) ;
img . onload = function ( ) {
2014-02-19 17:47:29 +04:00
// if loading the preview image failed (no preview for the mimetype) then img.width will < 5
if ( img . width > 5 ) {
ready ( previewURL ) ;
}
2014-04-04 19:10:46 +04:00
} ;
2013-10-28 14:22:34 +04:00
img . src = previewURL ;
2013-08-14 15:25:07 +04:00
} ) ;
2014-01-30 13:41:04 +04:00
} ;
2013-07-02 13:13:22 +04:00
2013-10-22 20:11:03 +04:00
function getUniqueName ( name ) {
2014-01-10 18:02:26 +04:00
if ( FileList . findFileEl ( name ) . exists ( ) ) {
2014-01-30 13:41:04 +04:00
var numMatch ;
2012-04-15 19:30:07 +04:00
var parts = name . split ( '.' ) ;
2012-06-29 17:23:04 +04:00
var extension = "" ;
if ( parts . length > 1 ) {
extension = parts . pop ( ) ;
}
2012-04-15 19:30:07 +04:00
var base = parts . join ( '.' ) ;
numMatch = base . match ( /\((\d+)\)/ ) ;
var num = 2 ;
2013-10-22 20:11:03 +04:00
if ( numMatch && numMatch . length > 0 ) {
2012-04-15 19:30:07 +04:00
num = parseInt ( numMatch [ numMatch . length - 1 ] ) + 1 ;
2013-10-22 20:11:03 +04:00
base = base . split ( '(' ) ;
2012-04-15 19:30:07 +04:00
base . pop ( ) ;
2013-01-30 16:29:24 +04:00
base = $ . trim ( base . join ( '(' ) ) ;
2012-04-15 19:30:07 +04:00
}
2012-06-29 17:23:04 +04:00
name = base + ' (' + num + ')' ;
if ( extension ) {
name = name + '.' + extension ;
}
2012-04-15 19:30:07 +04:00
return getUniqueName ( name ) ;
}
return name ;
}
2013-07-26 13:13:43 +04:00
function checkTrashStatus ( ) {
2013-10-22 20:11:03 +04:00
$ . post ( OC . filePath ( 'files_trashbin' , 'ajax' , 'isEmpty.php' ) , function ( result ) {
2013-07-26 13:13:43 +04:00
if ( result . data . isEmpty === false ) {
$ ( "input[type=button][id=trash]" ) . removeAttr ( "disabled" ) ;
}
} ) ;
2013-07-30 02:34:36 +04:00
}
2013-08-17 15:07:18 +04:00
2013-10-28 23:22:06 +04:00
// override core's fileDownloadPath (legacy)
function fileDownloadPath ( dir , file ) {
return Files . getDownloadUrl ( file , dir ) ;
2013-08-17 15:07:18 +04:00
}
2013-12-04 21:27:24 +04:00