Skip to content

Commit

Permalink
Make note anchors actually work
Browse files Browse the repository at this point in the history
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
  • Loading branch information
dzaporozhets committed Dec 25, 2013
1 parent 73af33e commit f7e7dc7
Show file tree
Hide file tree
Showing 9 changed files with 59 additions and 66 deletions.
3 changes: 0 additions & 3 deletions app/assets/javascripts/notes.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,9 +13,6 @@ var NoteList = {

NoteList.setupMainTargetNoteForm();

// get initial set of notes
NoteList.getContent();

// Unbind events to prevent firing twice
$(document).off("click", ".js-add-diff-note-button");
$(document).off("click", ".js-discussion-reply-button");
Expand Down
3 changes: 2 additions & 1 deletion app/controllers/projects/commit_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,8 @@ def show
@line_notes = result[:line_notes]
@branches = result[:branches]
@notes_count = result[:notes_count]
@target_type = :commit
@target_type = "Commit"
@notes = project.notes.for_commit_id(@commit.id).not_inline.fresh
@target_id = @commit.id

@comments_allowed = @reply_allowed = true
Expand Down
3 changes: 2 additions & 1 deletion app/controllers/projects/issues_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,8 @@ def edit

def show
@note = @project.notes.new(noteable: @issue)
@target_type = :issue
@notes = @issue.notes.inc_author.fresh
@target_type = 'Issue'
@target_id = @issue.id

respond_with(@issue)
Expand Down
7 changes: 4 additions & 3 deletions app/controllers/projects/merge_requests_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -198,16 +198,17 @@ def validates_merge_request
def define_show_vars
# Build a note object for comment form
@note = @project.notes.new(noteable: @merge_request)
@notes = @merge_request.mr_and_commit_notes.inc_author.fresh
@discussions = Note.discussions_from_notes(@notes)
@target_type = 'MergeRequest'
@target_id = @merge_request.id

# Get commits from repository
# or from cache if already merged
@commits = @merge_request.commits

@allowed_to_merge = allowed_to_merge?
@show_merge_controls = @merge_request.opened? && @commits.any? && @allowed_to_merge

@target_type = :merge_request
@target_id = @merge_request.id
end

def allowed_to_merge?
Expand Down
34 changes: 1 addition & 33 deletions app/controllers/projects/notes_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ def index
@target_id = params[:target_id]

if params[:target_type] == "merge_request"
@discussions = discussions_from_notes
@discussions = Note.discussions_from_notes(@notes)
end

respond_to do |format|
Expand Down Expand Up @@ -76,36 +76,4 @@ def delete_attachment
def preview
render text: view_context.markdown(params[:note])
end

protected

def discussion_notes_for(note)
@notes.select do |other_note|
note.discussion_id == other_note.discussion_id
end
end

def discussions_from_notes
discussion_ids = []
discussions = []

@notes.each do |note|
next if discussion_ids.include?(note.discussion_id)

# don't group notes for the main target
if note_for_main_target?(note)
discussions << [note]
else
discussions << discussion_notes_for(note)
discussion_ids << note.discussion_id
end
end

discussions
end

# Helps to distinguish e.g. commit notes in mr notes list
def note_for_main_target?(note)
(@target_type.camelize == note.noteable_type && !note.for_diff_line?)
end
end
3 changes: 2 additions & 1 deletion app/controllers/projects/snippets_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,8 @@ def update

def show
@note = @project.notes.new(noteable: @snippet)
@target_type = :snippet
@notes = @snippet.notes.fresh
@target_type = 'Snippet'
@target_id = @snippet.id
end

Expand Down
69 changes: 46 additions & 23 deletions app/models/note.rb
Original file line number Diff line number Diff line change
Expand Up @@ -56,29 +56,52 @@ class Note < ActiveRecord::Base
serialize :st_diff
before_create :set_diff, if: ->(n) { n.line_code.present? }

def self.create_status_change_note(noteable, project, author, status, source)
body = "_Status changed to #{status}#{' by ' + source.gfm_reference if source}_"

create({
noteable: noteable,
project: project,
author: author,
note: body,
system: true
}, without_protection: true)
end
class << self
def create_status_change_note(noteable, project, author, status, source)
body = "_Status changed to #{status}#{' by ' + source.gfm_reference if source}_"

create({
noteable: noteable,
project: project,
author: author,
note: body,
system: true
}, without_protection: true)
end

# +noteable+ was referenced from +mentioner+, by including GFM in either +mentioner+'s description or an associated Note.
# Create a system Note associated with +noteable+ with a GFM back-reference to +mentioner+.
def create_cross_reference_note(noteable, mentioner, author, project)
create({
noteable: noteable,
commit_id: (noteable.sha if noteable.respond_to? :sha),
project: project,
author: author,
note: "_mentioned in #{mentioner.gfm_reference}_",
system: true
}, without_protection: true)
end

# +noteable+ was referenced from +mentioner+, by including GFM in either +mentioner+'s description or an associated Note.
# Create a system Note associated with +noteable+ with a GFM back-reference to +mentioner+.
def self.create_cross_reference_note(noteable, mentioner, author, project)
create({
noteable: noteable,
commit_id: (noteable.sha if noteable.respond_to? :sha),
project: project,
author: author,
note: "_mentioned in #{mentioner.gfm_reference}_",
system: true
}, without_protection: true)
def discussions_from_notes(notes)
discussion_ids = []
discussions = []

notes.each do |note|
next if discussion_ids.include?(note.discussion_id)

# don't group notes for the main target
if !note.for_diff_line? && note.noteable_type == "MergeRequest"
discussions << [note]
else
discussions << notes.select do |other_note|
note.discussion_id == other_note.discussion_id
end
discussion_ids << note.discussion_id
end
end

discussions
end
end

# Determine whether or not a cross-reference note already exists.
Expand All @@ -89,7 +112,7 @@ def self.cross_reference_exists?(noteable, mentioner)
def commit_author
@commit_author ||=
project.users.find_by_email(noteable.author_email) ||
project.users.find_by_name(noteable.author_name)
project.users.find_by_name(noteable.author_name)
rescue
nil
end
Expand Down
2 changes: 1 addition & 1 deletion app/views/projects/notes/_notes.html.haml
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
- if note_for_main_target?(note)
= render discussion_notes
- else
= render 'discussion', discussion_notes: discussion_notes
= render 'projects/notes/discussion', discussion_notes: discussion_notes
- else
- @notes.each do |note|
- next unless note.author
Expand Down
1 change: 1 addition & 0 deletions app/views/projects/notes/_notes_with_form.html.haml
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
%ul#notes-list.notes
= render "projects/notes/notes"
.js-notes-busy

.js-main-target-form
Expand Down

0 comments on commit f7e7dc7

Please sign in to comment.