summaryrefslogtreecommitdiff
path: root/app
diff options
context:
space:
mode:
authorRiyad Preukschas <riyad@informatik.uni-bremen.de>2012-09-14 17:01:34 +0200
committerRiyad Preukschas <riyad@informatik.uni-bremen.de>2012-09-14 21:41:57 +0200
commit07eec9c66a910b5a808852f498e1dc9c88b701d2 (patch)
treec2861d2d33484599ba022271e85e8c936bc9d95f /app
parent7563abbe49fc16280877be89342d552e0609d57c (diff)
downloadgitlab-ce-07eec9c66a910b5a808852f498e1dc9c88b701d2.tar.gz
Update Notes JS for reversed notes
Diffstat (limited to 'app')
-rw-r--r--app/assets/javascripts/notes.js27
-rw-r--r--app/contexts/notes/load_context.rb7
-rw-r--r--app/models/note.rb2
-rw-r--r--app/views/notes/index.js.haml2
4 files changed, 27 insertions, 11 deletions
diff --git a/app/assets/javascripts/notes.js b/app/assets/javascripts/notes.js
index 7cbf44b98bf..81bb1d6d1b0 100644
--- a/app/assets/javascripts/notes.js
+++ b/app/assets/javascripts/notes.js
@@ -4,14 +4,17 @@ var NoteList = {
target_params: null,
target_id: 0,
target_type: null,
+ top_id: 0,
bottom_id: 0,
loading_more_disabled: false,
+ reversed: false,
init:
function(tid, tt, path) {
this.notes_path = path + ".js";
this.target_id = tid;
this.target_type = tt;
+ this.reversed = $("#notes-list").hasClass("reversed");
this.target_params = "&target_type=" + this.target_type + "&target_id=" + this.target_id;
// get initial set of notes
@@ -69,12 +72,18 @@ var NoteList = {
* Replaces the content of #notes-list with the given html.
*/
setContent:
- function(last_id, html) {
+ function(first_id, last_id, html) {
+ this.top_id = first_id;
this.bottom_id = last_id;
$("#notes-list").html(html);
- // Init infinite scrolling
+ // init infinite scrolling
this.initLoadMore();
+
+ // init getting new notes
+ if (this.reversed) {
+ this.initRefreshNew();
+ }
},
@@ -114,7 +123,7 @@ var NoteList = {
$.ajax({
type: "GET",
url: this.notes_path,
- data: "loading_more=1&after_id=" + this.bottom_id + this.target_params,
+ data: "loading_more=1&" + (this.reversed ? "before_id" : "after_id") + "=" + this.bottom_id + this.target_params,
complete: function(){ $('.notes-status').removeClass("loading")},
beforeSend: function() { $('.notes-status').addClass("loading") },
dataType: "script"});
@@ -142,7 +151,9 @@ var NoteList = {
this.loading_more_disabled = true;
// from now on only get new notes
- this.initRefreshNew();
+ if (!this.reversed) {
+ this.initRefreshNew();
+ }
},
@@ -164,14 +175,14 @@ var NoteList = {
},
/**
- * Gets the new set of notes (i.e. all notes after ).
+ * Gets the new set of notes.
*/
getNew:
function() {
$.ajax({
type: "GET",
url: this.notes_path,
- data: "loading_new=1&after_id=" + this.bottom_id + this.target_params,
+ data: "loading_new=1&after_id=" + (this.reversed ? this.top_id : this.bottom_id) + this.target_params,
dataType: "script"});
},
@@ -189,7 +200,9 @@ var NoteList = {
*/
appendNewNote:
function(id, html) {
- if(id != this.bottom_id) {
+ if (this.reversed) {
+ $("#new-notes-list").prepend(html);
+ } else {
$("#new-notes-list").append(html);
}
}
diff --git a/app/contexts/notes/load_context.rb b/app/contexts/notes/load_context.rb
index c2d7644b6ba..6d26e16a56c 100644
--- a/app/contexts/notes/load_context.rb
+++ b/app/contexts/notes/load_context.rb
@@ -4,6 +4,7 @@ module Notes
target_type = params[:target_type]
target_id = params[:target_id]
after_id = params[:after_id]
+ before_id = params[:before_id]
@notes = case target_type
@@ -17,14 +18,16 @@ module Notes
project.snippets.find(target_id).notes.fresh
when "wall"
# this is the only case, where the order is DESC
- project.common_notes.order("created_at DESC").limit(50)
+ project.common_notes.order("created_at DESC, id DESC").limit(50)
when "wiki"
project.wikis.reverse.map {|w| w.notes.fresh }.flatten[0..20]
end
@notes = if after_id
@notes.where("id > ?", after_id)
- else
+ elsif before_id
+ @notes.where("id < ?", before_id)
+ else
@notes
end
end
diff --git a/app/models/note.rb b/app/models/note.rb
index 9aad8949f3c..34edb94edca 100644
--- a/app/models/note.rb
+++ b/app/models/note.rb
@@ -36,7 +36,7 @@ class Note < ActiveRecord::Base
scope :today, where("created_at >= :date", date: Date.today)
scope :last_week, where("created_at >= :date", date: (Date.today - 7.days))
scope :since, lambda { |day| where("created_at >= :date", date: (day)) }
- scope :fresh, order("created_at ASC")
+ scope :fresh, order("created_at ASC, id ASC")
scope :inc_author_project, includes(:project, :author)
scope :inc_author, includes(:author)
diff --git a/app/views/notes/index.js.haml b/app/views/notes/index.js.haml
index 3d6859eb9a3..3814dbd46a2 100644
--- a/app/views/notes/index.js.haml
+++ b/app/views/notes/index.js.haml
@@ -9,7 +9,7 @@
- else
:plain
- NoteList.setContent(#{@notes.last.id}, "#{escape_javascript(render 'notes/notes')}");
+ NoteList.setContent(#{@notes.first.id}, #{@notes.last.id}, "#{escape_javascript(render 'notes/notes')}");
- else
- if loading_more_notes?