debian-mirror-gitlab/app/serializers/discussion_entity.rb

74 lines
2.4 KiB
Ruby
Raw Normal View History

2018-11-18 11:00:15 +05:30
# frozen_string_literal: true
2018-03-17 18:26:18 +05:30
class DiscussionEntity < Grape::Entity
include RequestAwareEntity
2018-11-08 19:23:39 +05:30
include NotesHelper
2018-03-17 18:26:18 +05:30
expose :id, :reply_id
2018-11-08 19:23:39 +05:30
expose :position, if: -> (d, _) { d.diff_discussion? && !d.legacy_diff_discussion? }
expose :line_code, if: -> (d, _) { d.diff_discussion? }
2018-03-17 18:26:18 +05:30
expose :expanded?, as: :expanded
2018-11-08 19:23:39 +05:30
expose :active?, as: :active, if: -> (d, _) { d.diff_discussion? }
expose :project_id
2018-03-17 18:26:18 +05:30
2018-05-09 12:01:36 +05:30
expose :notes do |discussion, opts|
request.note_entity.represent(discussion.notes, opts)
end
2018-03-17 18:26:18 +05:30
2018-11-08 19:23:39 +05:30
expose :discussion_path do |discussion|
discussion_path(discussion)
end
2018-03-17 18:26:18 +05:30
expose :individual_note?, as: :individual_note
2018-11-08 19:23:39 +05:30
expose :resolvable do |discussion|
discussion.resolvable?
end
2018-03-27 19:54:05 +05:30
expose :resolved?, as: :resolved
2018-11-08 19:23:39 +05:30
expose :resolved_by_push?, as: :resolved_by_push
expose :resolved_by, using: NoteUserEntity
expose :resolved_at
2018-03-27 19:54:05 +05:30
expose :resolve_path, if: -> (d, _) { d.resolvable? } do |discussion|
resolve_project_merge_request_discussion_path(discussion.project, discussion.noteable, discussion.id)
end
2018-05-09 12:01:36 +05:30
expose :resolve_with_issue_path, if: -> (d, _) { d.resolvable? } do |discussion|
2018-03-27 19:54:05 +05:30
new_project_issue_path(discussion.project, merge_request_to_resolve_discussions_of: discussion.noteable.iid, discussion_to_resolve: discussion.id)
end
2018-11-08 19:23:39 +05:30
expose :diff_file, using: DiffFileEntity, if: -> (d, _) { d.diff_discussion? }
2018-03-27 19:54:05 +05:30
expose :diff_discussion?, as: :diff_discussion
2018-11-08 19:23:39 +05:30
expose :truncated_diff_lines_path, if: -> (d, _) { !d.expanded? && !render_truncated_diff_lines? } do |discussion|
project_merge_request_discussion_path(discussion.project, discussion.noteable, discussion)
2018-03-27 19:54:05 +05:30
end
2018-11-08 19:23:39 +05:30
expose :truncated_diff_lines, if: -> (d, _) { d.diff_discussion? && d.on_text? && (d.expanded? || render_truncated_diff_lines?) }
expose :image_diff_html, if: -> (d, _) { d.diff_discussion? && d.on_image? } do |discussion|
2018-03-27 19:54:05 +05:30
diff_file = discussion.diff_file
partial = diff_file.new_file? || diff_file.deleted_file? ? 'single_image_diff' : 'replaced_image_diff'
options[:context].render_to_string(
partial: "projects/diffs/#{partial}",
locals: { diff_file: diff_file,
position: discussion.position.to_json,
click_to_comment: false },
layout: false,
formats: [:html]
)
end
2018-11-08 19:23:39 +05:30
expose :for_commit?, as: :for_commit
expose :commit_id
private
def render_truncated_diff_lines?
options[:render_truncated_diff_lines]
end
def current_user
request.current_user
end
2018-03-17 18:26:18 +05:30
end