diffs_controller.rb 2.0 KB
Newer Older
D
Douwe Maan 已提交
1 2 3 4 5 6 7 8 9 10 11 12
class Projects::MergeRequests::DiffsController < Projects::MergeRequests::ApplicationController
  include DiffForPath
  include DiffHelper
  include RendersNotes

  before_action :apply_diff_view_cookie!
  before_action :define_diff_vars
  before_action :define_diff_comment_vars

  def show
    @environment = @merge_request.environments_for(current_user).last

13
    render json: { html: view_to_html_string("projects/merge_requests/diffs/_diffs") }
D
Douwe Maan 已提交
14 15 16 17 18 19 20 21 22
  end

  def diff_for_path
    render_diff_for_path(@diffs)
  end

  private

  def define_diff_vars
23 24
    @merge_request_diffs = @merge_request.merge_request_diffs.viewable.select_without_diff.order_id_desc

25
    @compare = commit || find_merge_request_diff_compare
26 27 28 29 30 31
    return render_404 unless @compare

    @diffs = @compare.diffs(diff_options)
  end

  def find_merge_request_diff_compare
D
Douwe Maan 已提交
32
    @merge_request_diff =
33 34
      if diff_id = params[:diff_id].presence
        @merge_request.merge_request_diffs.viewable.find_by(id: diff_id)
D
Douwe Maan 已提交
35 36 37 38
      else
        @merge_request.merge_request_diff
      end

39 40
    return unless @merge_request_diff

D
Douwe Maan 已提交
41 42
    @comparable_diffs = @merge_request_diffs.select { |diff| diff.id < @merge_request_diff.id }

43
    if @start_sha = params[:start_sha].presence
D
Douwe Maan 已提交
44 45 46 47 48 49 50 51
      @start_version = @comparable_diffs.find { |diff| diff.head_commit_sha == @start_sha }

      unless @start_version
        @start_sha = @merge_request_diff.head_commit_sha
        @start_version = @merge_request_diff
      end
    end

52 53 54 55 56
    if @start_sha
      @merge_request_diff.compare_with(@start_sha)
    else
      @merge_request_diff
    end
D
Douwe Maan 已提交
57 58 59 60 61
  end

  def define_diff_comment_vars
    @new_diff_note_attrs = {
      noteable_type: 'MergeRequest',
62 63
      noteable_id: @merge_request.id,
      commit_id: @commit&.id
D
Douwe Maan 已提交
64 65 66 67 68 69 70
    }

    @diff_notes_disabled = false

    @use_legacy_diff_notes = !@merge_request.has_complete_diff_refs?

    @grouped_diff_discussions = @merge_request.grouped_diff_discussions(@compare.diff_refs)
71
    @notes = prepare_notes_for_rendering(@grouped_diff_discussions.values.flatten.flat_map(&:notes), @merge_request)
D
Douwe Maan 已提交
72 73
  end
end