Commit 16e21ed1 authored by Phil Hughes's avatar Phil Hughes

Merge branch 'fix-assign-yourself-bug' into 'multiple_assignees_review'

Fix assign yourself bug

See merge request !1781
parents 925dea21 ce374e96
...@@ -446,15 +446,34 @@ GitLabDropdown = (function() { ...@@ -446,15 +446,34 @@ GitLabDropdown = (function() {
} }
}; };
GitLabDropdown.prototype.filteredFullData = function() {
return this.fullData.filter(r => typeof r === 'object'
&& !Object.prototype.hasOwnProperty.call(r, 'beforeDivider')
&& !Object.prototype.hasOwnProperty.call(r, 'header')
);
};
GitLabDropdown.prototype.opened = function(e) { GitLabDropdown.prototype.opened = function(e) {
var contentHtml; var contentHtml;
this.resetRows(); this.resetRows();
this.addArrowKeyEvent(); this.addArrowKeyEvent();
const dropdownToggle = this.dropdown.find('.dropdown-menu-toggle');
const hasFilterBulkUpdate = dropdownToggle.hasClass('js-filter-bulk-update');
const hasMultiSelect = dropdownToggle.hasClass('js-multiselect');
// Makes indeterminate items effective // Makes indeterminate items effective
if (this.fullData && this.dropdown.find('.dropdown-menu-toggle').hasClass('js-filter-bulk-update')) { if (this.fullData && hasFilterBulkUpdate) {
this.parseData(this.fullData); this.parseData(this.fullData);
} }
// Process the data to make sure rendered data
// matches the correct layout
if (this.fullData && hasMultiSelect) {
const inputValue = this.filterInput.val();
this.options.processData.call(this.options, inputValue, this.filteredFullData(), this.parseData.bind(this));
}
contentHtml = $('.dropdown-content', this.dropdown).html(); contentHtml = $('.dropdown-content', this.dropdown).html();
if (this.remote && contentHtml === "") { if (this.remote && contentHtml === "") {
this.remote.execute(); this.remote.execute();
......
...@@ -278,10 +278,7 @@ import eventHub from './sidebar/event_hub'; ...@@ -278,10 +278,7 @@ import eventHub from './sidebar/event_hub';
if (this.multiSelect && inputValue === '') { if (this.multiSelect && inputValue === '') {
// Remove non-users from the fullData array // Remove non-users from the fullData array
const users = glDropdown.fullData.filter(r => typeof r === 'object' const users = glDropdown.filteredFullData();
&& !Object.prototype.hasOwnProperty.call(r, 'beforeDivider')
&& !Object.prototype.hasOwnProperty.call(r, 'header')
);
const callback = glDropdown.parseData.bind(glDropdown); const callback = glDropdown.parseData.bind(glDropdown);
// Update the data model // Update the data model
......
...@@ -42,6 +42,21 @@ feature 'Issue Sidebar', feature: true do ...@@ -42,6 +42,21 @@ feature 'Issue Sidebar', feature: true do
expect(page).to have_content(user2.name) expect(page).to have_content(user2.name)
end end
end end
it 'assigns yourself' do
find('.block.assignee .dropdown-menu-toggle').click
click_button 'assign yourself'
wait_for_ajax
find('.block.assignee .edit-link').click
page.within '.dropdown-menu-user' do
expect(page.find('.dropdown-header')).to be_visible
expect(page.find('.dropdown-menu-user-link.is-active')).to have_content(user.name)
end
end
end end
context 'as a allowed user' do context 'as a allowed user' do
......
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