81e9c28425
This commit moves the rendering of the button back to the server, and shows/hides it using opacity rather than display. It also removes the transform applied to the button on hover (scale). Previously, both of these factors automatically triggered a reflow, which creates a performance bottleneck on pages with larger DOM size. MR: !12103
138 lines
3.5 KiB
Ruby
138 lines
3.5 KiB
Ruby
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
|
|
data[:note_type] = LegacyDiffNote.name
|
|
else
|
|
data[:note_type] = DiffNote.name
|
|
data[:position] = position.to_json
|
|
end
|
|
|
|
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, line_type: line_type }
|
|
|
|
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 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_namespace_project_merge_request_path(discussion.project.namespace, discussion.project, discussion.noteable, path_params)
|
|
elsif discussion.for_commit?
|
|
anchor = discussion.line_code if discussion.diff_discussion?
|
|
|
|
namespace_project_commit_path(discussion.project.namespace, discussion.project, discussion.noteable, anchor: anchor)
|
|
end
|
|
end
|
|
|
|
def notes_url
|
|
if @snippet.is_a?(PersonalSnippet)
|
|
snippet_notes_path(@snippet)
|
|
else
|
|
namespace_project_noteable_notes_path(
|
|
namespace_id: @project.namespace,
|
|
project_id: @project,
|
|
target_id: @noteable.id,
|
|
target_type: @noteable.class.name.underscore
|
|
)
|
|
end
|
|
end
|
|
|
|
def note_url(note, project = @project)
|
|
if note.noteable.is_a?(PersonalSnippet)
|
|
snippet_note_path(note.noteable, note)
|
|
else
|
|
namespace_project_note_path(project.namespace, project, note)
|
|
end
|
|
end
|
|
|
|
def noteable_note_url(note)
|
|
Gitlab::UrlBuilder.build(note)
|
|
end
|
|
|
|
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
|
|
end
|