2018-11-18 11:00:15 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
class MergeRequestDiffEntity < Grape::Entity
|
|
|
|
include Gitlab::Routing
|
|
|
|
include GitHelper
|
|
|
|
include MergeRequestsHelper
|
|
|
|
|
|
|
|
expose :version_index do |merge_request_diff|
|
|
|
|
@merge_request_diffs = options[:merge_request_diffs]
|
|
|
|
diff = options[:merge_request_diff]
|
|
|
|
|
|
|
|
next unless diff.present?
|
|
|
|
next unless @merge_request_diffs.size > 1
|
|
|
|
|
|
|
|
version_index(merge_request_diff)
|
|
|
|
end
|
|
|
|
|
|
|
|
expose :created_at
|
|
|
|
expose :commits_count
|
|
|
|
|
|
|
|
expose :latest?, as: :latest
|
|
|
|
|
|
|
|
expose :short_commit_sha do |merge_request_diff|
|
|
|
|
short_sha(merge_request_diff.head_commit_sha)
|
|
|
|
end
|
|
|
|
|
|
|
|
expose :version_path do |merge_request_diff|
|
|
|
|
start_sha = options[:start_sha]
|
|
|
|
project = merge_request.target_project
|
|
|
|
|
|
|
|
next unless project
|
|
|
|
|
|
|
|
merge_request_version_path(project, merge_request, merge_request_diff, start_sha)
|
|
|
|
end
|
|
|
|
|
|
|
|
expose :compare_path do |merge_request_diff|
|
|
|
|
project = merge_request.target_project
|
|
|
|
diff = options[:merge_request_diff]
|
|
|
|
|
|
|
|
if project && diff
|
|
|
|
merge_request_version_path(project, merge_request, diff, merge_request_diff.head_commit_sha)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def merge_request
|
|
|
|
options[:merge_request]
|
|
|
|
end
|
|
|
|
end
|