diff options
author | Julius Härtl <jus@bitgrid.net> | 2019-08-21 16:59:49 +0200 |
---|---|---|
committer | Julius Härtl <jus@bitgrid.net> | 2019-08-21 16:59:49 +0200 |
commit | f5352b9c6738e22f94115ffe6afdd0a792cc6834 (patch) | |
tree | 98d08ec8b9b010b32c545365d67f1b57384942e1 /core/src/OC | |
parent | 9ac15bc4e9d78c77d982bb017034c8ac1d8e4b54 (diff) | |
download | nextcloud-server-f5352b9c6738e22f94115ffe6afdd0a792cc6834.tar.gz nextcloud-server-f5352b9c6738e22f94115ffe6afdd0a792cc6834.zip |
filepicker: Add option to also choose folders without a mimetype limit
Signed-off-by: Julius Härtl <jus@bitgrid.net>
Diffstat (limited to 'core/src/OC')
-rw-r--r-- | core/src/OC/dialogs.js | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/core/src/OC/dialogs.js b/core/src/OC/dialogs.js index 6308927093b..04bac6d63da 100644 --- a/core/src/OC/dialogs.js +++ b/core/src/OC/dialogs.js @@ -195,8 +195,9 @@ const Dialogs = { * @param modal make the dialog modal * @param type Type of file picker : Choose, copy, move, copy and move * @param path path to the folder that the the file can be picket from + * @param options additonal options that need to be set */ - filepicker: function (title, callback, multiselect, mimetypeFilter, modal, type, path) { + filepicker: function (title, callback, multiselect, mimetypeFilter, modal, type, path, options) { var self = this; this.filepicker.sortField = 'name'; @@ -221,6 +222,9 @@ const Dialogs = { this.filelist = null; path = path || ''; + options = Object.assign({ + allowDirectoryChooser: false + }, options) $.when(this._getFilePickerTemplate()).then(function ($tmpl) { self.filepicker.loading = false; @@ -244,7 +248,7 @@ const Dialogs = { nameCol: t('core', 'Name'), sizeCol: t('core', 'Size'), modifiedCol: t('core', 'Modified') - }).data('path', path).data('multiselect', multiselect).data('mimetype', mimetypeFilter); + }).data('path', path).data('multiselect', multiselect).data('mimetype', mimetypeFilter).data('allowDirectoryChooser', options.allowDirectoryChooser) if (modal === undefined) { modal = false; @@ -457,7 +461,7 @@ const Dialogs = { // Hence this is one of the approach to get the choose button. var getOcDialog = self.$filePicker.closest('.oc-dialog'); var buttonEnableDisable = getOcDialog.find('.primary'); - if (self.$filePicker.data('mimetype').indexOf("httpd/unix-directory") !== -1) { + if (self.$filePicker.data('mimetype').indexOf("httpd/unix-directory") !== -1 && !self.$filePicker.data('.allowDirectoryChooser')) { buttonEnableDisable.prop("disabled", false); } else { buttonEnableDisable.prop("disabled", true); @@ -1178,7 +1182,7 @@ const Dialogs = { } else if ($element.data('type') === 'dir') { this._fillFilePicker(this.$filePicker.data('path') + '/' + $element.data('entryname')); this._changeButtonsText(type, $element.data('entryname')); - if (this.$filePicker.data('mimetype').indexOf("httpd/unix-directory") !== -1) { + if (this.$filePicker.data('mimetype').indexOf("httpd/unix-directory") !== -1 || this.$filePicker.data('allowDirectoryChooser')) { buttonEnableDisable.prop("disabled", false); } else { buttonEnableDisable.prop("disabled", true); |