Commit 1d009999 authored by Nathan Friend's avatar Nathan Friend Committed by Jose Ivan Vargas

Small improvements to milestone combobox

This commit makes a few small improvements to the milestone combobox
component. Most notably, the search box is focused when the dropdown is
opened.
parent 394217b4
...@@ -13,6 +13,8 @@ import { __, sprintf } from '~/locale'; ...@@ -13,6 +13,8 @@ import { __, sprintf } from '~/locale';
import Api from '~/api'; import Api from '~/api';
import { deprecatedCreateFlash as createFlash } from '~/flash'; import { deprecatedCreateFlash as createFlash } from '~/flash';
const SEARCH_DEBOUNCE_MS = 250;
export default { export default {
components: { components: {
GlNewDropdown, GlNewDropdown,
...@@ -95,12 +97,15 @@ export default { ...@@ -95,12 +97,15 @@ export default {
// lodash attaches to the function, which is // lodash attaches to the function, which is
// made inaccessible by Vue. More info: // made inaccessible by Vue. More info:
// https://stackoverflow.com/a/52988020/1063392 // https://stackoverflow.com/a/52988020/1063392
this.debouncedSearchMilestones = debounce(this.searchMilestones, 100); this.debouncedSearchMilestones = debounce(this.searchMilestones, SEARCH_DEBOUNCE_MS);
}, },
mounted() { mounted() {
this.fetchMilestones(); this.fetchMilestones();
}, },
methods: { methods: {
focusSearchBox() {
this.$refs.searchBox.$el.querySelector('input').focus();
},
fetchMilestones() { fetchMilestones() {
this.requestCount += 1; this.requestCount += 1;
...@@ -183,7 +188,7 @@ export default { ...@@ -183,7 +188,7 @@ export default {
</script> </script>
<template> <template>
<gl-new-dropdown> <gl-new-dropdown v-bind="$attrs" class="project-milestone-combobox" @shown="focusSearchBox">
<template slot="button-content"> <template slot="button-content">
<span ref="buttonText" class="flex-grow-1 ml-1 text-muted">{{ <span ref="buttonText" class="flex-grow-1 ml-1 text-muted">{{
selectedMilestonesLabel selectedMilestonesLabel
...@@ -198,6 +203,7 @@ export default { ...@@ -198,6 +203,7 @@ export default {
<gl-new-dropdown-divider /> <gl-new-dropdown-divider />
<gl-search-box-by-type <gl-search-box-by-type
ref="searchBox"
v-model.trim="searchQuery" v-model.trim="searchQuery"
class="gl-m-3" class="gl-m-3"
:placeholder="this.$options.translations.searchMilestones" :placeholder="this.$options.translations.searchMilestones"
......
...@@ -18,7 +18,9 @@ module Spec ...@@ -18,7 +18,9 @@ module Spec
module Helpers module Helpers
module Features module Features
module ReleasesHelpers module ReleasesHelpers
# Returns the element that currently has keyboard focus # Returns the element that currently has keyboard focus.
# Reminder that this returns a Selenium::WebDriver::Element
# _not_ a Capybara::Node::Element
def focused_element def focused_element
page.driver.browser.switch_to.active_element page.driver.browser.switch_to.active_element
end end
...@@ -39,7 +41,8 @@ module Spec ...@@ -39,7 +41,8 @@ module Spec
# Wait for the dropdown to be rendered # Wait for the dropdown to be rendered
page.find('.ref-selector .dropdown-menu') page.find('.ref-selector .dropdown-menu')
focused_element.send_keys(branch_name) # Pressing Enter in the search box shouldn't submit the form
focused_element.send_keys(branch_name, :enter)
# Wait for the search to return # Wait for the search to return
page.find('.ref-selector .dropdown-item', text: branch_name, match: :first) page.find('.ref-selector .dropdown-item', text: branch_name, match: :first)
...@@ -63,12 +66,16 @@ module Spec ...@@ -63,12 +66,16 @@ module Spec
focused_element.send_keys(:enter) focused_element.send_keys(:enter)
# Wait for the dropdown to be rendered # Wait for the dropdown to be rendered
page.find('.gl-new-dropdown .dropdown-menu') page.find('.project-milestone-combobox .dropdown-menu')
focused_element.send_keys(:tab, milestone_title) # Clear any existing input
focused_element.attribute('value').length.times { focused_element.send_keys(:backspace) }
# Pressing Enter in the search box shouldn't submit the form
focused_element.send_keys(milestone_title, :enter)
# Wait for the search to return # Wait for the search to return
page.find('.gl-new-dropdown .dropdown-item', text: milestone_title, match: :first) page.find('.project-milestone-combobox .dropdown-item', text: milestone_title, match: :first)
focused_element.send_keys(:arrow_down, :arrow_down, :enter) focused_element.send_keys(:arrow_down, :arrow_down, :enter)
......
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