summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorpdessauw <pdessauw@gmail.com>2014-09-03 15:07:22 -0400
committerpdessauw <pdessauw@gmail.com>2014-09-03 15:07:22 -0400
commit63dff87953941e1a79ecf11c33b7a777bdd57528 (patch)
tree5594247f439c1a37cb5bac03b7346990faab21f2
parenta9a2397c1cae3dab12d3d85f3bfe18cb9e00f502 (diff)
parent0d078e48ce71d35bf240ec2b3d48a37f1b96115a (diff)
downloadnextcloud-server-63dff87953941e1a79ecf11c33b7a777bdd57528.tar.gz
nextcloud-server-63dff87953941e1a79ecf11c33b7a777bdd57528.zip
Merge pull request #9195 from owncloud/fix-733
Scroll to uploaded file in file list
-rw-r--r--apps/files/css/upload.css24
-rw-r--r--apps/files/js/file-upload.js8
-rw-r--r--apps/files/js/filelist.js50
3 files changed, 82 insertions, 0 deletions
diff --git a/apps/files/css/upload.css b/apps/files/css/upload.css
index bdc258b5064..98754b910de 100644
--- a/apps/files/css/upload.css
+++ b/apps/files/css/upload.css
@@ -137,3 +137,27 @@
.oc-dialog .oc-dialog-buttonrow .cancel {
float:left;
}
+
+.highlightUploaded {
+ -webkit-animation: highlightAnimation 2s 1;
+ -moz-animation: highlightAnimation 2s 1;
+ -o-animation: highlightAnimation 2s 1;
+ animation: highlightAnimation 2s 1;
+}
+
+@-webkit-keyframes highlightAnimation {
+ 0% { background-color: rgba(255, 255, 140, 1); }
+ 100% { background-color: rgba(0, 0, 0, 0); }
+}
+@-moz-keyframes highlightAnimation {
+ 0% { background-color: rgba(255, 255, 140, 1); }
+ 100% { background-color: rgba(0, 0, 0, 0); }
+}
+@-o-keyframes highlightAnimation {
+ 0% { background-color: rgba(255, 255, 140, 1); }
+ 100% { background-color: rgba(0, 0, 0, 0); }
+}
+@keyframes highlightAnimation {
+ 0% { background-color: rgba(255, 255, 140, 1); }
+ 100% { background-color: rgba(0, 0, 0, 0); }
+}
diff --git a/apps/files/js/file-upload.js b/apps/files/js/file-upload.js
index ff999bae4ff..310799b9513 100644
--- a/apps/files/js/file-upload.js
+++ b/apps/files/js/file-upload.js
@@ -427,6 +427,14 @@ OC.Upload = {
data.textStatus = 'servererror';
data.errorThrown = result[0].data.message; // error message has been translated on server
fu._trigger('fail', e, data);
+ } else { // Successful upload
+ // Checking that the uploaded file is the last one and contained in the current directory
+ if (data.files[0] === data.originalFiles[data.originalFiles.length - 1] &&
+ result[0].directory === FileList.getCurrentDirectory()) {
+ // Scroll to the last uploaded file and highlight all of them
+ var fileList = _.pluck(data.originalFiles, 'name');
+ FileList.highlightFiles(fileList);
+ }
}
},
/**
diff --git a/apps/files/js/filelist.js b/apps/files/js/filelist.js
index fd11a80248d..037e04db21c 100644
--- a/apps/files/js/filelist.js
+++ b/apps/files/js/filelist.js
@@ -1856,6 +1856,56 @@
self.updateStorageStatistics();
});
+ },
+
+ /**
+ * Scroll to the last file of the given list
+ * Highlight the list of files
+ * @param files array of filenames
+ */
+ highlightFiles: function(files) {
+ // Detection of the uploaded element
+ var filename = files[files.length - 1];
+ var $fileRow = this.findFileEl(filename);
+
+ while(!$fileRow.exists() && this._nextPage(false) !== false) { // Checking element existence
+ $fileRow = this.findFileEl(filename);
+ }
+
+ if (!$fileRow.exists()) { // Element not present in the file list
+ return;
+ }
+
+ var currentOffset = this.$container.scrollTop();
+ var additionalOffset = this.$el.find("#controls").height()+this.$el.find("#controls").offset().top;
+
+ // Animation
+ var _this = this;
+ this.$container.animate({
+ // Scrolling to the top of the new element
+ scrollTop: currentOffset + $fileRow.offset().top - $fileRow.height() * 2 - additionalOffset
+ }, {
+ duration: 500,
+ complete: function() {
+ // Highlighting function
+ var highlightRow = function($fileRow) {
+ $fileRow.addClass("highlightUploaded");
+ setTimeout(function() {
+ $fileRow.removeClass("highlightUploaded");
+ }, 2500);
+ };
+
+ // Loop over uploaded files
+ for(var i=0; i<files.length; i++) {
+ var $fileRow = _this.findFileEl(files[i]);
+
+ if($fileRow.length !== 0) { // Checking element existence
+ highlightRow($fileRow);
+ }
+ }
+
+ }
+ });
}
};