diff options
author | Julius Härtl <jus@bitgrid.net> | 2018-11-08 13:30:39 +0100 |
---|---|---|
committer | Julius Härtl <jus@bitgrid.net> | 2018-11-16 14:12:41 +0100 |
commit | 3e11337b3b4c36df20d5565d60d05995b0314363 (patch) | |
tree | 560eb9976da313fa391c83ad62a52d2e52b2bffc | |
parent | 09efdfb4e640a748d9f7af1d120a4315028d969a (diff) | |
download | nextcloud-server-3e11337b3b4c36df20d5565d60d05995b0314363.tar.gz nextcloud-server-3e11337b3b4c36df20d5565d60d05995b0314363.zip |
Allow sorting in the file picker
Signed-off-by: Julius Härtl <jus@bitgrid.net>
-rw-r--r-- | core/css/styles.scss | 41 | ||||
-rw-r--r-- | core/js/oc-dialogs.js | 52 | ||||
-rw-r--r-- | core/templates/filepicker.html | 42 |
3 files changed, 119 insertions, 16 deletions
diff --git a/core/css/styles.scss b/core/css/styles.scss index 9b7da393698..62d2bb45c96 100644 --- a/core/css/styles.scss +++ b/core/css/styles.scss @@ -773,6 +773,47 @@ code { margin-bottom: 50px; } .filelist { + thead { + tr { + border-bottom: 1px solid var(--color-border); + background-color: var(--color-main-background); + th { + width: auto; + border: none; + } + } + } + th .columntitle { + display: block; + padding: 15px; + height: 50px; + box-sizing: border-box; + -moz-box-sizing: border-box; + vertical-align: middle; + } + th .columntitle.name { + padding-left: 5px; + margin-left: 50px; + } + + th .sort-indicator { + width: 10px; + height: 8px; + margin-left: 5px; + display: inline-block; + vertical-align: text-bottom; + opacity: .3; + } + .sort-indicator.hidden, + th:hover .sort-indicator.hidden, + th:focus .sort-indicator.hidden { + visibility: hidden; + } + th:hover .sort-indicator.hidden, + th:focus .sort-indicator.hidden { + visibility: visible; + } + td { padding: 14px; border-bottom: 1px solid var(--color-border); diff --git a/core/js/oc-dialogs.js b/core/js/oc-dialogs.js index dee74502a6f..e46dd9a57ea 100644 --- a/core/js/oc-dialogs.js +++ b/core/js/oc-dialogs.js @@ -192,6 +192,9 @@ var OCdialogs = { */ filepicker:function(title, callback, multiselect, mimetypeFilter, modal, type) { var self = this; + + this.filepicker.sortField = 'name'; + this.filepicker.sortOrder = 'asc'; // avoid opening the picker twice if (this.filepicker.loading) { return; @@ -252,6 +255,7 @@ var OCdialogs = { } self.$filePicker.ready(function() { + self.$fileListHeader = self.$filePicker.find('.filelist thead tr'); self.$filelist = self.$filePicker.find('.filelist tbody'); self.$dirTree = self.$filePicker.find('.dirtree'); self.$dirTree.on('click', 'div:not(:last-child)', self, function (event) { @@ -260,6 +264,12 @@ var OCdialogs = { self.$filelist.on('click', 'tr', function(event) { self._handlePickerClick(event, $(this), type); }); + self.$fileListHeader.on('click', 'a', function(event) { + var dir = self.$filePicker.data('path'); + self.filepicker.sortField = $(event.currentTarget).data('sort'); + self.filepicker.sortOrder = self.filepicker.sortOrder === 'asc' ? 'desc' : 'asc'; + self._fillFilePicker(dir); + }); self._fillFilePicker(''); }); @@ -824,7 +834,7 @@ var OCdialogs = { var self = this; $.get(OC.filePath('core', 'templates', 'filepicker.html'), function(tmpl) { self.$filePickerTemplate = $(tmpl); - self.$listTmpl = self.$filePickerTemplate.find('.filelist tr:first-child').detach(); + self.$listTmpl = self.$filePickerTemplate.find('.filelist tbody tr:first-child').detach(); defer.resolve(self.$filePickerTemplate); }) .fail(function(jqXHR, textStatus, errorThrown) { @@ -892,20 +902,50 @@ var OCdialogs = { if (typeof(filter) === "string") { filter = [filter]; } + self.$fileListHeader.find('.sort-indicator').addClass('hidden').removeClass('icon-triangle-n').removeClass('icon-triangle-s'); + self.$fileListHeader.find('[data-sort=' + self.filepicker.sortField + '] .sort-indicator').removeClass('hidden'); + if (self.filepicker.sortOrder === 'asc') { + self.$fileListHeader.find('[data-sort=' + self.filepicker.sortField + '] .sort-indicator').addClass('icon-triangle-s'); + } else { + self.$fileListHeader.find('[data-sort=' + self.filepicker.sortField + '] .sort-indicator').addClass('icon-triangle-n'); + } self.filepicker.filesClient.getFolderContents(dir).then(function(status, files) { if (filter && filter.length > 0 && filter.indexOf('*') === -1) { files = files.filter(function (file) { return file.type === 'dir' || filter.indexOf(file.mimetype) !== -1; }); } - files = files.sort(function(a, b) { - if (a.type === 'dir' && b.type !== 'dir') { + + var Comparators = { + name: function(fileInfo1, fileInfo2) { + if (fileInfo1.type === 'dir' && fileInfo2.type !== 'dir') { + return -1; + } + if (fileInfo1.type !== 'dir' && fileInfo2.type === 'dir') { + return 1; + } + return OC.Util.naturalSortCompare(fileInfo1.name, fileInfo2.name); + }, + size: function(fileInfo1, fileInfo2) { + return fileInfo1.size - fileInfo2.size; + }, + mtime: function(fileInfo1, fileInfo2) { + return fileInfo1.mtime - fileInfo2.mtime; + } + }; + var comparator = Comparators[self.filepicker.sortField] || Comparators.name; + files = files.sort(function(file1, file2) { + var isFavorite = function(fileInfo) { + return fileInfo.tags && fileInfo.tags.indexOf(OC.TAG_FAVORITE) >= 0; + }; + + if (isFavorite(file1) && !isFavorite(file2)) { return -1; - } else if(a.type !== 'dir' && b.type === 'dir') { + } else if (!isFavorite(file1) && isFavorite(file2)) { return 1; - } else { - return a.name.localeCompare(b.name, undefined, {numeric: true}); } + + return self.filepicker.sortOrder === 'asc' ? comparator(file1, file2) : -comparator(file1, file2); }); self._fillSlug(); diff --git a/core/templates/filepicker.html b/core/templates/filepicker.html index 4c66dfc707b..090e6bce773 100644 --- a/core/templates/filepicker.html +++ b/core/templates/filepicker.html @@ -8,17 +8,39 @@ <h2>{emptytext}</h2> </div> <table id="filestable" class="filelist list-container view-grid"> + <thead> + <tr> + <th id="headerName" class="column-name"> + <div id="headerName-container"> + <a class="name sort columntitle" data-sort="name"> + <span>Name</span> + <span class="sort-indicator hidden icon-triangle-n"></span> + </a> + </div> + </th> + <th id="headerSize" class="column-size"> + <a class="size sort columntitle" data-sort="size"> + <span>Size</span> + <span class="sort-indicator hidden icon-triangle-n"></span></a> + </th> + <th id="headerDate" class="column-mtime"> + <a id="modified" class="columntitle" data-sort="mtime"> + <span>Modified</span> + <span class="sort-indicator hidden icon-triangle-n"></span></a> + </th> + </tr> + </thead> <tbody> - <tr data-entryname="{filename}" data-type="{type}"> - <td class="filename" - style="background-image:url({icon})">{filename} - </td> - <td class="filesize" - style="color:rgb({sizeColor}, {sizeColor}, {sizeColor})"> - {size} - </td> - <td class="date">{date}</td> - </tr> + <tr data-entryname="{filename}" data-type="{type}"> + <td class="filename" + style="background-image:url({icon})">{filename} + </td> + <td class="filesize" + style="color:rgb({sizeColor}, {sizeColor}, {sizeColor})"> + {size} + </td> + <td class="date">{date}</td> + </tr> </tbody> </table> </div> |