diff options
Diffstat (limited to 'core/js/oc-dialogs.js')
-rw-r--r-- | core/js/oc-dialogs.js | 87 |
1 files changed, 86 insertions, 1 deletions
diff --git a/core/js/oc-dialogs.js b/core/js/oc-dialogs.js index 5e1bc420970..ed09b4121a7 100644 --- a/core/js/oc-dialogs.js +++ b/core/js/oc-dialogs.js @@ -205,6 +205,7 @@ var OCdialogs = { } var emptyText = t('core', 'No files in here'); + var newText = t('files', 'New folder'); if (type === this.FILEPICKER_TYPE_COPY || type === this.FILEPICKER_TYPE_MOVE || type === this.FILEPICKER_TYPE_COPY_MOVE) { emptyText = t('core', 'No more subfolders in here'); } @@ -212,6 +213,8 @@ var OCdialogs = { this.filepicker.loading = true; this.filepicker.filesClient = (OCA.Sharing && OCA.Sharing.PublicApp && OCA.Sharing.PublicApp.fileList)? OCA.Sharing.PublicApp.fileList.filesClient: OC.Files.getClient(); + this.filelist = null; + $.when(this._getFilePickerTemplate()).then(function($tmpl) { self.filepicker.loading = false; var dialogName = 'oc-dialog-filepicker-content'; @@ -229,7 +232,8 @@ var OCdialogs = { self.$filePicker = $tmpl.octemplate({ dialog_name: dialogName, title: title, - emptytext: emptyText + emptytext: emptyText, + newtext: newText }).data('path', '').data('multiselect', multiselect).data('mimetype', mimetypeFilter); if (modal === undefined) { @@ -254,6 +258,86 @@ var OCdialogs = { self._getGridSettings(); } + var newButton = self.$filePicker.find('.actions.creatable .button-add'); + newButton.on('focus', function() { + self.$filePicker.ocdialog('setEnterCallback', function() { + event.stopImmediatePropagation(); + event.preventDefault(); + newButton.click(); + }); + }); + newButton.on('blur', function() { + self.$filePicker.ocdialog('unsetEnterCallback'); + }); + + OC.registerMenu(newButton,self.$filePicker.find('.menu'),function () { + $input.focus(); + self.$filePicker.ocdialog('setEnterCallback', function() { + event.stopImmediatePropagation(); + event.preventDefault(); + self.$form.submit(); + }); + var newName = $input.val(); + lastPos = newName.lastIndexOf('.'); + if (lastPos === -1) { + lastPos = newName.length; + } + $input.selectRange(0, lastPos); + }); + var $form = self.$filePicker.find('.filenameform'); + var $input = $form.find('input[type=\'text\']'); + var $submit = $form.find('input[type=\'submit\']'); + $submit.on('click',function(event) { + event.stopImmediatePropagation(); + event.preventDefault(); + $form.submit(); + }); + + var checkInput = function () { + var filename = $input.val(); + try { + if (!Files.isFileNameValid(filename)) { + // Files.isFileNameValid(filename) throws an exception itself + } else if (self.filelist.find(function(file){return file.name === this;},filename)) { + throw t('files', '{newName} already exists', {newName: filename}, undefined, { + escape: false + }); + } else { + return true; + } + } catch (error) { + $input.attr('title', error); + $input.tooltip({placement: 'right', trigger: 'manual', 'container': '.newFolderMenu'}); + $input.tooltip('fixTitle'); + $input.tooltip('show'); + $input.addClass('error'); + } + return false; + }; + + $form.on('submit', function(event) { + event.stopPropagation(); + event.preventDefault(); + + if (checkInput()) { + var newname = $input.val(); + self.filepicker.filesClient.createDirectory(self.$filePicker.data('path') + "/" + newname).always(function (status) { + self._fillFilePicker(self.$filePicker.data('path') + newname ); + }); + OC.hideMenus(); + self.$filePicker.ocdialog('unsetEnterCallback'); + self.$filePicker.click(); + $input.val(newText); + } + }); + $input.keypress(function(event) { + if (event.keyCode === 13 || event.which === 13) { + event.stopImmediatePropagation(); + event.preventDefault(); + $form.submit(); + } + }); + self.$filePicker.ready(function() { self.$fileListHeader = self.$filePicker.find('.filelist thead tr'); self.$filelist = self.$filePicker.find('.filelist tbody'); @@ -912,6 +996,7 @@ var OCdialogs = { self.$fileListHeader.find('[data-sort=' + self.filepicker.sortField + '] .sort-indicator').addClass('icon-triangle-s'); } self.filepicker.filesClient.getFolderContents(dir).then(function(status, files) { + self.filelist = files; if (filter && filter.length > 0 && filter.indexOf('*') === -1) { files = files.filter(function (file) { return file.type === 'dir' || filter.indexOf(file.mimetype) !== -1; |