diff options
author | Phil Hughes <me@iamphill.com> | 2017-06-08 16:48:29 +0100 |
---|---|---|
committer | Phil Hughes <me@iamphill.com> | 2017-06-08 18:06:47 +0100 |
commit | dfa4a440f032020cf000841d7e1c799d142f92c8 (patch) | |
tree | 85431b177a0d2f4c34fab9ecc4299361a8b23d54 /app | |
parent | fd072e2221147f52edf74d4dcedb2ffa3799ab2f (diff) | |
download | gitlab-ce-dfa4a440f032020cf000841d7e1c799d142f92c8.tar.gz |
Fixed dropdown filter input not focusing after transitionissuable-sidebar-edit-button-field-focus
Closes #33216
Diffstat (limited to 'app')
-rw-r--r-- | app/assets/javascripts/gl_dropdown.js | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/app/assets/javascripts/gl_dropdown.js b/app/assets/javascripts/gl_dropdown.js index d34561e5512..3babe273100 100644 --- a/app/assets/javascripts/gl_dropdown.js +++ b/app/assets/javascripts/gl_dropdown.js @@ -248,7 +248,7 @@ GitLabDropdown = (function() { return function(data) { _this.fullData = data; _this.parseData(_this.fullData); - _this.focusTextInput(); + _this.focusTextInput(true); if (_this.options.filterable && _this.filter && _this.filter.input && _this.filter.input.val() && _this.filter.input.val().trim() !== '') { return _this.filter.input.trigger('input'); } @@ -728,8 +728,20 @@ GitLabDropdown = (function() { return [selectedObject, isMarking]; }; - GitLabDropdown.prototype.focusTextInput = function() { - if (this.options.filterable) { this.filterInput.focus(); } + GitLabDropdown.prototype.focusTextInput = function(triggerFocus = false) { + if (this.options.filterable) { + $(':focus').blur(); + + this.dropdown.one('transitionend', () => { + this.filterInput.focus(); + }); + + if (triggerFocus) { + // This triggers after a ajax request + // in case of slow requests, the dropdown transition could already be finished + this.dropdown.trigger('transitionend'); + } + } }; GitLabDropdown.prototype.addInput = function(fieldName, value, selectedObject) { |