1 = form_for [@project, @merge_request], html: { class: "merge-request-form form-horizontal" } do |f|
2 -if @merge_request.errors.any?
5 - @merge_request.errors.full_messages.each do |msg|
8 .merge-request-branches
13 = f.select(:source_project_id, [[@merge_request.source_project_path,@merge_request.source_project.id]] , {}, { class: 'source_project select2 span3', disabled: @merge_request.persisted? })
16 = f.select(:source_branch, @merge_request.source_project.repository.branch_names, { include_blank: "Select branch" }, {class: 'source_branch select2 span2'})
17 .mr_source_commit.prepend-top-10
20 %i.icon-long-arrow-right
24 - projects = @project.forked_from_project.nil? ? [@project] : [ @project,@project.forked_from_project]
25 = f.select(:target_project_id, options_from_collection_for_select(projects, 'id', 'path_with_namespace'), {}, { class: 'target_project select2 span3', disabled: @merge_request.persisted? })
28 = f.select(:target_branch, @target_branches, { include_blank: "Select branch" }, {class: 'target_branch select2 span2'})
29 .mr_target_commit.prepend-top-10
32 .merge-request-form-info
34 = f.label :title, class: 'control-label' do
36 .col-sm-10= f.text_field :title, class: "form-control pad js-gfm-input", maxlength: 255, rows: 5, required: true
38 = f.label :description, "Description", class: 'control-label'
40 = f.text_area :description, class: "form-control js-gfm-input", rows: 14
41 %p.hint Description is parsed with #{link_to "GitLab Flavored Markdown", help_markdown_path, target: '_blank'}.
45 .merge-request-assignee
46 = f.label :assignee_id, class: 'control-label' do
50 = f.select(:assignee_id, assignee_options(@merge_request), { include_blank: "Select a user" }, {class: 'select2'})
52 = link_to 'Assign to me', '#', class: 'btn btn-small assign-to-me-link'
54 .merge-request-milestone
55 = f.label :milestone_id, class: 'control-label' do
58 .col-sm-10= f.select(:milestone_id, milestone_options(@merge_request), { include_blank: "Select milestone" }, {class: 'select2'})
62 - if @merge_request.new_record?
63 = f.submit 'Submit merge request', class: "btn btn-create"
65 = f.submit 'Save changes', class: "btn btn-save"
66 - if @merge_request.new_record?
67 = link_to project_merge_requests_path(@source_project), class: "btn btn-cancel" do
70 = link_to project_merge_request_path(@target_project, @merge_request), class: "btn btn-cancel" do
74 disableButtonIfEmptyField("#merge_request_title", ".btn-save");
76 var source_branch = $("#merge_request_source_branch")
77 , target_branch = $("#merge_request_target_branch")
78 , target_project = $("#merge_request_target_project_id");
80 $.get("#{branch_from_project_merge_requests_path(@source_project)}", {ref: source_branch.val() });
81 $.get("#{branch_to_project_merge_requests_path(@source_project)}", {target_project_id: target_project.val(),ref: target_branch.val() });
83 target_project.on("change", function() {
84 $.get("#{update_branches_project_merge_requests_path(@source_project)}", {target_project_id: $(this).val() });
86 source_branch.on("change", function() {
87 $.get("#{branch_from_project_merge_requests_path(@source_project)}", {ref: $(this).val() });
89 target_branch.on("change", function() {
90 $.get("#{branch_to_project_merge_requests_path(@source_project)}", {target_project_id: target_project.val(),ref: $(this).val() });
92 $('.assign-to-me-link').on('click', function(e){
93 $('#merge_request_assignee_id').val("#{current_user.id}").trigger("change");