gitlab-org--gitlab-foss/app/helpers/notes_helper.rb

159 lines
4.0 KiB
Ruby
Raw Normal View History

module NotesHelper
def note_target_fields(note)
if note.noteable
hidden_field_tag(:target_type, note.noteable.class.name.underscore) +
hidden_field_tag(:target_id, note.noteable.id)
end
end
def note_editable?(note)
Ability.can_edit_note?(current_user, note)
end
def note_supports_quick_actions?(note)
Notes::QuickActionsService.supported?(note, current_user)
end
def noteable_json(noteable)
{
id: noteable.id,
class: noteable.class.name,
resources: noteable.class.table_name,
project_id: noteable.project.id
}.to_json
end
def diff_view_data
return {} unless @new_diff_note_attrs
@new_diff_note_attrs.slice(:noteable_id, :noteable_type, :commit_id)
end
def diff_view_line_data(line_code, position, line_type)
return if @diff_notes_disabled
data = {
line_code: line_code,
line_type: line_type
}
if @use_legacy_diff_notes
2017-03-31 01:33:45 +00:00
data[:note_type] = LegacyDiffNote.name
else
2017-03-31 01:33:45 +00:00
data[:note_type] = DiffNote.name
data[:position] = position.to_json
end
2017-03-31 01:33:45 +00:00
data
end
def add_diff_note_button(line_code, position, line_type)
return if @diff_notes_disabled
button_tag '',
class: 'add-diff-note js-add-diff-note-button',
type: 'submit', name: 'button',
data: diff_view_line_data(line_code, position, line_type),
title: 'Add a comment to this line' do
icon('comment-o')
end
end
def link_to_reply_discussion(discussion, line_type = nil)
return unless current_user
data = {
discussion_id: discussion.reply_id,
discussion_project_id: discussion.project&.id,
line_type: line_type
}
2016-05-10 22:41:46 +00:00
button_tag 'Reply...', class: 'btn btn-text-field js-discussion-reply-button',
data: data, title: 'Add a reply'
end
def note_max_access_for_user(note)
note.project.team.human_max_access(note.author_id)
end
def note_first_contribution_for_user?(note)
note.noteable.author_id == note.author_id &&
note.project.merge_requests.merged.where(author_id: note.author_id).empty?
end
def discussion_path(discussion)
if discussion.for_merge_request?
return unless discussion.diff_discussion?
version_params = discussion.merge_request_version_params
return unless version_params
path_params = version_params.merge(anchor: discussion.line_code)
diffs_project_merge_request_path(discussion.project, discussion.noteable, path_params)
elsif discussion.for_commit?
2017-04-06 23:18:53 +00:00
anchor = discussion.line_code if discussion.diff_discussion?
2017-04-08 19:58:08 +00:00
project_commit_path(discussion.project, discussion.noteable, anchor: anchor)
end
end
2017-05-03 08:48:01 +00:00
2017-08-17 17:27:11 +00:00
def notes_url(params = {})
2017-05-03 08:48:01 +00:00
if @snippet.is_a?(PersonalSnippet)
2017-08-17 17:27:11 +00:00
snippet_notes_path(@snippet, params)
2017-05-03 08:48:01 +00:00
else
2017-08-17 17:27:11 +00:00
params.merge!(target_id: @noteable.id, target_type: @noteable.class.name.underscore)
2017-08-17 17:27:11 +00:00
project_noteable_notes_path(@project, params)
2017-05-03 08:48:01 +00:00
end
end
def note_url(note, project = @project)
2017-05-03 08:48:01 +00:00
if note.noteable.is_a?(PersonalSnippet)
snippet_note_path(note.noteable, note)
else
project_note_path(project, note)
2017-05-03 08:48:01 +00:00
end
end
def noteable_note_url(note)
Gitlab::UrlBuilder.build(note)
end
2017-05-03 08:48:01 +00:00
def form_resources
if @snippet.is_a?(PersonalSnippet)
[@note]
else
[@project.namespace.becomes(Namespace), @project, @note]
end
end
def new_form_url
return nil unless @snippet.is_a?(PersonalSnippet)
snippet_notes_path(@snippet)
end
def can_create_note?
if @snippet.is_a?(PersonalSnippet)
can?(current_user, :comment_personal_snippet, @snippet)
else
can?(current_user, :create_note, @project)
end
end
2017-07-25 10:56:41 +00:00
def initial_notes_data(autocomplete)
{
notesUrl: notes_url,
notesIds: @notes.map(&:id),
now: Time.now.to_i,
diffView: diff_view,
autocomplete: autocomplete
}
end
def discussion_resolved_intro(discussion)
discussion.resolved_by_push? ? 'Automatically resolved' : 'Resolved'
end
end