Commit b3100589 authored by Phil Hughes's avatar Phil Hughes

Use new dropdowns for MR compare

parent 7fe19046
...@@ -2,26 +2,27 @@ class @Compare ...@@ -2,26 +2,27 @@ class @Compare
constructor: (@opts) -> constructor: (@opts) ->
@source_loading = $ ".js-source-loading" @source_loading = $ ".js-source-loading"
@target_loading = $ ".js-target-loading" @target_loading = $ ".js-target-loading"
@source_branch = $ "#merge_request_source_branch"
@target_branch = $ "#merge_request_target_branch"
@target_project = $ "#merge_request_target_project_id"
@initialState() $('.js-compare-dropdown').each (i, dropdown) =>
@cleanBinding() $dropdown = $(dropdown)
@addBinding()
cleanBinding: ->
@source_branch.off "change"
@target_branch.off "change"
@target_project.off "change"
addBinding: -> $dropdown.glDropdown(
@source_branch.on "change", => selectable: true
@getSourceHtml() fieldName: $dropdown.data 'field-name'
@target_branch.on "change", => id: (obj, $el) ->
$el.data 'id'
toggleLabel: (obj, $el) ->
$el.text().trim()
clicked: (e, el) =>
if $dropdown.is '.js-target-branch'
@getTargetHtml() @getTargetHtml()
@target_project.on "change", => else if $dropdown.is '.js-source-branch'
@getSourceHtml()
else if $dropdown.is '.js-target-project'
@getTargetProject() @getTargetProject()
)
@initialState()
initialState: -> initialState: ->
@getSourceHtml() @getSourceHtml()
...@@ -29,13 +30,13 @@ class @Compare ...@@ -29,13 +30,13 @@ class @Compare
getTargetProject: -> getTargetProject: ->
$.get @opts.targetProjectUrl, $.get @opts.targetProjectUrl,
target_project_id: @target_project.val() target_project_id: $("input[name='merge_request[source_project]']").val()
getSourceHtml: -> getSourceHtml: ->
$.ajax( $.ajax(
url: @opts.sourceBranchUrl url: @opts.sourceBranchUrl
data: data:
ref: @source_branch.val() ref: $("input[name='merge_request[source_branch]']").val()
beforeSend: => beforeSend: =>
@source_loading.show() @source_loading.show()
$(".mr_source_commit").html "" $(".mr_source_commit").html ""
...@@ -49,8 +50,8 @@ class @Compare ...@@ -49,8 +50,8 @@ class @Compare
$.ajax( $.ajax(
url: @opts.targetBranchUrl url: @opts.targetBranchUrl
data: data:
target_project_id: @target_project.val() target_project_id: $("input[name='merge_request[target_project_id]']").val()
ref: @target_branch.val() ref: $("input[name='merge_request[target_branch]']").val()
beforeSend: => beforeSend: =>
@target_loading.show() @target_loading.show()
$(".mr_target_commit").html "" $(".mr_target_commit").html ""
......
...@@ -373,7 +373,7 @@ class GitLabDropdown ...@@ -373,7 +373,7 @@ class GitLabDropdown
# Toggle the dropdown label # Toggle the dropdown label
if @options.toggleLabel if @options.toggleLabel
$(@el).find(".dropdown-toggle-text").text @options.toggleLabel(selectedObject) $(@el).find(".dropdown-toggle-text").text @options.toggleLabel(selectedObject, el)
if value? if value?
if !field.length if !field.length
# Create hidden input for form # Create hidden input for form
......
...@@ -242,4 +242,14 @@ ...@@ -242,4 +242,14 @@
width: 50%; width: 50%;
padding-left: 5px; padding-left: 5px;
padding-right: 5px; padding-right: 5px;
.dropdown-menu-toggle {
width: 100%;
}
.dropdown-menu {
left: 5px;
right: 5px;
width: auto;
}
} }
...@@ -9,10 +9,29 @@ ...@@ -9,10 +9,29 @@
.panel-heading .panel-heading
Source branch Source branch
.panel-body.clearfix .panel-body.clearfix
.merge-request-select .merge-request-select.dropdown
= f.select(:source_project_id, [[@merge_request.source_project_path,@merge_request.source_project.id]] , {}, { class: 'source_project select2', disabled: @merge_request.persisted?, required: true }) = f.hidden_field :source_project_id
.merge-request-select = dropdown_toggle @merge_request.source_project_path, { toggle: "dropdown", field_name: "#{f.object_name}[source_project_id]", disabled: @merge_request.persisted? }, { toggle_class: "js-compare-dropdown js-source-project" }
= f.select(:source_branch, @merge_request.source_branches, { include_blank: true }, { class: 'source_branch select2', required: true, data: { placeholder: "Select source branch" } }) .dropdown-menu
= dropdown_title("Select source project")
= dropdown_filter("Search projects")
= dropdown_content do
%ul
%li
%a{ href: "#", data: { id: @merge_request.source_project.id } }
= @merge_request.source_project_path
.merge-request-select.dropdown
= f.hidden_field :source_branch
= dropdown_toggle "Select source branch", { toggle: "dropdown", field_name: "#{f.object_name}[source_branch]" }, { toggle_class: "js-compare-dropdown js-source-branch" }
.dropdown-menu
= dropdown_title("Select source branch")
= dropdown_filter("Search branches")
= dropdown_content do
%ul
- @merge_request.source_branches.each do |branch|
%li
%a{ href: "#", data: { id: branch } }
= branch
.panel-footer .panel-footer
= icon('spinner spin', class: "js-source-loading") = icon('spinner spin', class: "js-source-loading")
%ul.list-unstyled.mr_source_commit %ul.list-unstyled.mr_source_commit
...@@ -23,10 +42,30 @@ ...@@ -23,10 +42,30 @@
Target branch Target branch
.panel-body.clearfix .panel-body.clearfix
- projects = @project.forked_from_project.nil? ? [@project] : [@project, @project.forked_from_project] - projects = @project.forked_from_project.nil? ? [@project] : [@project, @project.forked_from_project]
.merge-request-select .merge-request-select.dropdown
= f.select(:target_project_id, options_from_collection_for_select(projects, 'id', 'path_with_namespace', f.object.target_project_id), {}, { class: 'target_project select2', disabled: @merge_request.persisted?, required: true }) = f.hidden_field :target_project_id
.merge-request-select = dropdown_toggle projects.first.path_with_namespace, { toggle: "dropdown", field_name: "#{f.object_name}[target_project_id]", disabled: @merge_request.persisted? }, { toggle_class: "js-compare-dropdown js-target-project" }
= f.select(:target_branch, @merge_request.target_branches, { include_blank: true }, { class: 'target_branch select2', required: true, data: { placeholder: "Select target branch" } }) .dropdown-menu
= dropdown_title("Select target project")
= dropdown_filter("Search projects")
= dropdown_content do
%ul
- projects.each do |project|
%li
%a{ href: "#" }
= project.path_with_namespace
.merge-request-select.dropdown
= f.hidden_field :target_branch
= dropdown_toggle "Select target branch", { toggle: "dropdown", field_name: "#{f.object_name}[target_branch]" }, { toggle_class: "js-compare-dropdown js-target-branch" }
.dropdown-menu.dropdown-menu-selectable
= dropdown_title("Select target branch")
= dropdown_filter("Search branches")
= dropdown_content do
%ul
- @merge_request.target_branches.each do |branch|
%li
%a{ href: "#", class: "#{("is-active" if :target_branch == branch)}", data: { id: branch } }
= branch
.panel-footer .panel-footer
= icon('spinner spin', class: "js-target-loading") = icon('spinner spin', class: "js-target-loading")
%ul.list-unstyled.mr_target_commit %ul.list-unstyled.mr_target_commit
......
...@@ -218,8 +218,8 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps ...@@ -218,8 +218,8 @@ class Spinach::Features::ProjectSourceBrowseFiles < Spinach::FeatureSteps
end end
step 'I see Browse code link' do step 'I see Browse code link' do
expect(page).to have_link 'Browse Files »' expect(page).to have_link 'Browse Files'
expect(page).not_to have_link 'Browse File »' expect(page).not_to have_link 'Browse File'
expect(page).not_to have_link 'Browse Directory »' expect(page).not_to have_link 'Browse Directory »'
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment