# frozen_string_literal: true module NotesHelper MAX_PRERENDERED_NOTES = 10 def note_target_title(note) # The design title is already present in `Event#note_target_reference`. return if note.nil? || note.for_design? note.title end 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_supports_quick_actions?(note) Notes::QuickActionsService.supported?(note) 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 sprite_icon('comment', size: 12) 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 } 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.max_member_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_project_merge_request_path(discussion.project, discussion.noteable, path_params) elsif discussion.for_commit? anchor = discussion.diff_discussion? ? discussion.line_code : "note_#{discussion.first_note.id}" project_commit_path(discussion.project, discussion.noteable, anchor: anchor) end end def notes_url(params = {}) if @snippet.is_a?(PersonalSnippet) gitlab_snippet_notes_path(@snippet, params) else params.merge!(target_id: @noteable.id, target_type: @noteable.class.name.underscore) project_noteable_notes_path(@project, params) end end def note_url(note, project = @project) if note.noteable.is_a?(PersonalSnippet) gitlab_snippet_note_path(note.noteable, note) else project_note_path(project, note) end end def noteable_note_url(note) Gitlab::UrlBuilder.build(note) if note.id end def form_resources if @snippet.is_a?(PersonalSnippet) [@note] else [@project, @note] end end def new_form_url return unless @snippet.is_a?(PersonalSnippet) gitlab_snippet_notes_path(@snippet) end def can_create_note? noteable = @issue || @merge_request || @snippet || @project can?(current_user, :create_note, noteable) end def initial_notes_data(autocomplete) { notesUrl: notes_url, notesIds: @noteable.notes.pluck(:id), # rubocop: disable CodeReuse/ActiveRecord now: Time.now.to_i, diffView: diff_view, enableGFM: { emojis: true, members: autocomplete, issues: autocomplete, mergeRequests: autocomplete, epics: autocomplete, milestones: autocomplete, labels: autocomplete } } end def discussions_path(issuable) if issuable.is_a?(Issue) discussions_project_issue_path(@project, issuable, format: :json) else discussions_project_merge_request_path(@project, issuable, format: :json) end end def notes_data(issuable) data = { discussionsPath: discussions_path(issuable), registerPath: new_session_path(:user, redirect_to_referer: 'yes', anchor: 'register-pane'), newSessionPath: new_session_path(:user, redirect_to_referer: 'yes'), markdownDocsPath: help_page_path('user/markdown'), quickActionsDocsPath: help_page_path('user/project/quick_actions'), closePath: close_issuable_path(issuable), reopenPath: reopen_issuable_path(issuable), notesPath: notes_url, prerenderedNotesCount: issuable.capped_notes_count(MAX_PRERENDERED_NOTES), lastFetchedAt: Time.now.to_i } if issuable.is_a?(MergeRequest) data.merge!( draftsPath: project_merge_request_drafts_path(@project, issuable), draftsPublishPath: publish_project_merge_request_drafts_path(@project, issuable), draftsDiscardPath: discard_project_merge_request_drafts_path(@project, issuable) ) end data end def discussion_resolved_intro(discussion) discussion.resolved_by_push? ? 'Automatically resolved' : 'Resolved' end def rendered_for_merge_request? params[:from_merge_request].present? end def serialize_notes? rendered_for_merge_request? || params['html'].nil? end end NotesHelper.prepend_if_ee('EE::NotesHelper')